INT UNSIGNED määritelmän null arvo?

Eli miten asia meneekään...

Olen PHP:llä tehnyt tietokantasovellusta joka käyttää MySQL-tietokantaa. Taulun luontivaiheessa olen määritellyt parille kentälle määritelmän INT UNSIGNED ja TINYINT UNSIGNED. Nyt jos näihin sarakkeisiin ei tallenneta mitään tietoa niin tietokantaan tulee 0 (nolla) kyseisille kohdille.

Miten saan määritettyä, että jos vaikkapa INT UNSIGNED kenttään ei tallenneta mitään tietoa niin defaulttina se on sitten tyhjä eikä nolla?

6

878

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • .........h

      Suoritappas tämmöinen kysely

      ALTER TABLE taulusi CHANGE sarakkeesi sarakkeesi INT UNSIGNED NULL DEFAULT NULL

      Ja tuosta sit muuttelet INT kohdan vastaamaan sarakkeen tyyppiä, tosin jos sulla on käytässä phpMyAmin(tai muu tietokannan hallinta ohjelma) niin sillä muutos on paljon helpompaa ja turvallisempaa, koska ei tarvitse itse noita kyselyitä kirjoittaa, tosin MySQL aikapitkälle estää virheelliset kyselyt.

      Valitse taulu -> rakenne -> paina sarakkeen kohdalla kynä(muokkaa) kuvaketta -> oletusarvo kohtaan vain NULL -> tallenna

    • .........

      Suoritappas tämmöinen kysely

      ALTER TABLE taulusi CHANGE sarakkeesi sarakkeesi INT UNSIGNED NULL DEFAULT NULL

      Ja tuosta sit muuttelet INT kohdan vastaamaan sarakkeen tyyppiä, tosin jos sulla on käytässä phpMyAmin(tai muu tietokannan hallinta ohjelma) niin sillä muutos on paljon helpompaa ja turvallisempaa, koska ei tarvitse itse noita kyselyitä kirjoittaa, tosin MySQL aikapitkälle estää virheelliset kyselyt.

      Valitse taulu -> rakenne -> paina sarakkeen kohdalla kynä(muokkaa) kuvaketta -> oletusarvo kohtaan vain NULL -> tallenna

      • xxxxxxxxxxxxxxxxxxxx

        Kävin vielä phpmyadminin kautta tarkastamassa että siellä oli kentän kohdalla NULL ja oletusarvona NULL.

        Löytyisikö muuta ratkaisua?

        Vai pitääkö tehdä purkkaratkaisu ja estää PHP-koodissa negatiiviset luvut ja kirjata tyhjät luvut sitten vaikkapa -1.


      • .........
        xxxxxxxxxxxxxxxxxxxx kirjoitti:

        Kävin vielä phpmyadminin kautta tarkastamassa että siellä oli kentän kohdalla NULL ja oletusarvona NULL.

        Löytyisikö muuta ratkaisua?

        Vai pitääkö tehdä purkkaratkaisu ja estää PHP-koodissa negatiiviset luvut ja kirjata tyhjät luvut sitten vaikkapa -1.

        Kyl tuon pitäis toimia, teit jotakin väärin, mitenkäs lisäsit tietoa?

        CREATE TABLE testi (
        id tinyint(4) NOT NULL AUTO_INCREMENT,
        x int(11) NOT NULL,
        y tinyint(4) DEFAULT NULL,
        PRIMARY KEY (id)
        ) ENGINE=MyISAM DEFAULT CHARSET=utf8;

        INSERT INTO testi (x) VALUES (222);
        INSERT INTO testi (x,y) VALUES (222, NULL);
        INSERT INTO testi (x,y) VALUES (222, ' ');
        INSERT INTO testi (x,y) VALUES (222, 0);
        INSERT INTO testi (x,y) VALUES (222, 'NULL'); (error)
        INSERT INTO testi (x,y) VALUES (222, ''); (error)

        SELECT * FROM testi;
        id | x | y
        1 | 222 | NULL
        2 | 222 | NULL
        3 | 222 | 0
        4 | 222 | 0

        Ja älä ala kikkailemaan -1 = NULL tai vastaavaa siitä seuraa ongelmia sekä koodistasi tulee epäselvempää koska -1 ei ole -1 vaan jotain ihan muuta.


      • x_x_x_x_x__x__X__x__X
        ......... kirjoitti:

        Kyl tuon pitäis toimia, teit jotakin väärin, mitenkäs lisäsit tietoa?

        CREATE TABLE testi (
        id tinyint(4) NOT NULL AUTO_INCREMENT,
        x int(11) NOT NULL,
        y tinyint(4) DEFAULT NULL,
        PRIMARY KEY (id)
        ) ENGINE=MyISAM DEFAULT CHARSET=utf8;

        INSERT INTO testi (x) VALUES (222);
        INSERT INTO testi (x,y) VALUES (222, NULL);
        INSERT INTO testi (x,y) VALUES (222, ' ');
        INSERT INTO testi (x,y) VALUES (222, 0);
        INSERT INTO testi (x,y) VALUES (222, 'NULL'); (error)
        INSERT INTO testi (x,y) VALUES (222, ''); (error)

        SELECT * FROM testi;
        id | x | y
        1 | 222 | NULL
        2 | 222 | NULL
        3 | 222 | 0
        4 | 222 | 0

        Ja älä ala kikkailemaan -1 = NULL tai vastaavaa siitä seuraa ongelmia sekä koodistasi tulee epäselvempää koska -1 ei ole -1 vaan jotain ihan muuta.

        eli php-koodissa kun tietoja lisätään tietokantaan niin VALUES-kohdan jälkeen on minulla kaikki arvot hipsujen sisällä eli tyyliin:
        ... VALUES ('$value1', 'value2', 'value3', ...)

        Nyt kun kokeilin lisätä suoraan tuonne NULL ilman hipsuja niin juttu toimii. Mutta mitenkäs tuota lisäystä voi nyt muuttaa niin, että se toimisi oikein, kun hipsuja ei voi poistaa ympäriltä jos arvo != NULL?


      • .........
        x_x_x_x_x__x__X__x__X kirjoitti:

        eli php-koodissa kun tietoja lisätään tietokantaan niin VALUES-kohdan jälkeen on minulla kaikki arvot hipsujen sisällä eli tyyliin:
        ... VALUES ('$value1', 'value2', 'value3', ...)

        Nyt kun kokeilin lisätä suoraan tuonne NULL ilman hipsuja niin juttu toimii. Mutta mitenkäs tuota lisäystä voi nyt muuttaa niin, että se toimisi oikein, kun hipsuja ei voi poistaa ympäriltä jos arvo != NULL?

        Juu ei hipsuja numerotyyppisten tietojen ympärille, jos hipsut on numeron ympärillä niin se on silloin merkkijono ei numero, tietokanta tosin muuttaa sen takaisin numeroksi, turhaa työtä vain.

        Helpoin ja hyvin tapa on tehdä tehdä http://fi.php.net/manual/en/function.PDOStatement-execute.php Esimerkki 1699 (jostain syystä PHP-manuaalista saa joskus vanhaa versiota, tuo ei ole enään eksperimentaalinen). MySQLi functio sisältää myös tuommoisen, mutta PDO kannattaa ennemmin käyttää kun ei ole sidottu pelkkään MySQL.

        Mikäli sinulla on vanha PHP tai pystyt käyttämään vain MySQL functiota niin voit tehdä oman function mielummin luokka joka hoitaa tuon asian, esim.


        function x($data)
        {
           if (strlen($data) == 0) {
              return 'NULL';
           }
           elseif (is_numeric($data)) {
              return $data;
           }
           else {
              return "'" . mysql_real_escape_string($data) . "'";      
           }
        }

        $value1 = x($_GET['testi']);

        Tuo functio palauttaa tyhjällä NULL(merkkijono), numeroilla numeron, muutoin hipsutetun ja escapetetun merkkijonon.

        Tietenkin kannattaa miettiä tuon laajentamista että söisi valinnaisen toisen parametrin millä pystyisi antamaan jotain ehtoja, ettei turhaan yritetä INT tyyppiseen soluun viedä tekstiä jne...

        Tai sitten vaan ihan
        if (!$y) {
        INSERT INTO testi (x) VALUES (222);
        }
        else
        {
        INSERT INTO testi (x, y) VALUES (222, $y);
        }

        Paljon ratkasee mitä olet tekemässä ja mikä siihen parhaiten soveltuu.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Tunnustusten lauantai

      Mitä haluat sanoa kaivatullesi?
      Ikävä
      236
      3151
    2. Kenellä oli ryppyinen paita, josta Halla-aho mielensä pahoitti?

      Ei ollut Keskisarja, jonka paita vain repsotti housujen päällä puolittain. Muistatteko tapausta?
      Maailman menoa
      17
      2897
    3. Miksi Halla-aho on niin hyvin menestynyt - mutta punavihreä ei?

      Hyvin näkee kuinka punavihreää ottaa pahasti päähän kun Virta on taas töppäillyt pahasti. Ja kun punavihreä ei pärjää, n
      Maailman menoa
      25
      2157
    4. Ruoan arvonlisävero menee käytännössä tukijussille

      Ilman juomia elintarvikkeiden myynti vuonna 2025 oli reilut 15 miljardia euroa. Tuolla tasolla arvonlisävero pyörii pari
      Maailman menoa
      26
      2068
    5. Vihreät REPEÄMÄSSÄ oijoijoi....Virran sekoilut on liikaa

      Jo ennestään vihreiden kannatus on suossa vaikka puolue istuu oppositiossa, nyt tuli Virran temppu kun häipyi tuosta vaa
      Maailman menoa
      64
      1947
    6. Sofia Virta SUURI POLIITIKKO

      Osallistumalla Erikoisjoukkoihin nostaa Vihreät kauaksi ohi perussuomalaisista, joka on muutenkin hajoamassa omaan mahdo
      Maailman menoa
      76
      1712
    7. Ruotsissa uusi vakava ongelma: Vanhusten seksuaalinen hyväksikäyttö

      palvelutaloissa ja kotihoidossa. Tämäkin on ihan puhtaasti väärän maahanmuuton vaikutusta, sillä tekijät ovat kaikki keh
      Maailman menoa
      28
      1569
    8. Mitä ikävöit eniten ikäväsi kohteesta?

      Rahaa, turvallisuutta, kauniita katseita,seksiä, läheisyyttä vai jotain muuta?
      Ikävä
      119
      1439
    9. Työeläkkeiden maksaminen lopetettava ASAP.

      "Vanhimmat sukupolvet ovat saaneet vastinetta eläke­maksuilleen monin­kertaisesti nykyisiin ja tuleviin sukupolviin verr
      Maailman menoa
      41
      1377
    10. Mika Poutala salasi osallistumisensa Erikoisjoukkoihin

      Poutala ryhtyi ministeriksi 13.6.2025 ja 5.8.2025 ilmoitettiin hänen olevan seuraavalla Erikoisjoukot-kaudella. http
      Maailman menoa
      42
      1253
    Aihe