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

852

    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. Kiva kun SDP alkaa hallitsemaan Suomea

      Vanhat hyvät ajat taas palaavat ja kansa vaurastuu. Muistatteko vielä Sorsan aikakauden? Silloin Suomessa tehtiin jopa
      Maailman menoa
      317
      8827
    2. Säästäminen on typerää, muistakaa äänestää demareita

      Säästäminen on typerää, koska aiheuttaa vain talouden taantumista ja lopulta tappaa potilaan. Demareiden tapa on satsat
      Maailman menoa
      82
      5402
    3. Olli Rehn: Eläkkeistä pitää leikata. Nyt tuli Lindtmanille kauhun paikka

      jos johtaa seuraavaa hallitusta. Purra: eläkkeisiin ei kosketa. Eikä tällä hallituskaudella varmasti kosketa, mutta seur
      Maailman menoa
      309
      4856
    4. SDP:n budjetin peruskivi: "Rahaa nimittäin on!"

      Demarien talouspolitiikan ydin on usein tiivistetty klassiseen meemiin: rahaa on, kunhan se on jonkun muun rahaa. Vuoden
      Maailman menoa
      70
      3370
    5. Sara Sieppi umpirehellisenä Amazing Race -kulissien takaisesta elämästä

      Sara Sieppi oli mukana Amazing Race Suomi -realityssä. Somevaikuttajalla oli takana raskasta aikaa ja isoja suruja, eikä
      Suomalaiset julkkikset
      3
      2822
    6. Herkkua vai hötöä? Kaksi Beck-leffaa tällä vkolla tv:stä

      Beck-elokuvat tuntuvat olevan suomalaisten makuun. Tällä viikolla televisiosta tulee kaksi ruotsalaista taidonnäytettä,
      Elokuva
      4
      2182
    7. Sdp, Vihreät ja vasemmistoliitto muuttumassa naisten puolueiksi?

      Sdp 64 % naisia, vihreät 70 % naisia ja vasemmistoliitto 60 % naisia. Ilmankos ne puolueet ajaa autoilevien kantasuomal
      Maailman menoa
      47
      2112
    8. Hatunnosto! Mari Hynynen (os. Perankoski) ja Jouni Hynynen auttavat vähäosaisia upealla tavalla!

      Hatunnosto! Mari ja Jouni Hynynen ovat Vailla vakinaista asuntoa ry:n uudet kummit. Hynysiä motivoi halu lisätä ymmärr
      Maailman menoa
      7
      2098
    9. Ajattelin silloin

      että jos olet kiinnostunut, ihan oikeasti, niin kuulen sinusta vielä.
      Ikävä
      113
      2066
    10. TTP avajaiset

      Tuhannen Taalan Paikka avautuu 1.3-26. Onpa tosi mukavaa! Kiitos Jaanalle kun olet niin aktiivinen ja jaksat yrittää ja
      Haapavesi
      40
      1963
    Aihe