Avatar billede AnyFellow Mester
16. februar 2012 - 20:43 Der er 4 kommentarer og
1 løsning

MySQL gemmer '0' i int(3) felt

Hej

Jeg har et problem jeg ikke helt ved hvordan jeg skal håndtere.

Lidt simplificeret har jeg 3 tabeller:
- produkttabel
- varianttabel
- pristabel

Nøglen i produktabellen og varianttabellen er af typen int(3).
Feltet autonummereres.

I min pristabel er der 3 felter:
produkt_id
variant_id
pris

Mit problem består i at jeg godt kan have et produkt uden en variant.

Når jeg så laver en post i min pris-tabel, bliver variant_id sat til '0', selvom jeg ikke indsætter en værdi i feltet.

Så vidt jeg har kunnet læse mig frem til, er det en normal opførsel for et felt af denne type, idet int ikke tillades at indeholde null.

Jeg kan ikke være den første i verdenshistorien der har dette problem. Hvad kan jeg gøre, ud over at starte nummereringen af variant_id i min varianttabel med '1'?
Avatar billede arne_v Ekspert
16. februar 2012 - 21:16 #1
En INT kan godt vaere NULL. Men en primary key kan ikke vaere NULL!

Jeg tror at den paeneste loesning er raekker i varianttabel med variant_id=1 og variant_tekst='The one and only'.
Avatar billede AnyFellow Mester
16. februar 2012 - 21:48 #2
Ikke forstået.

Hvordan løser det mit problem med variant_id i pristabellen. Jeg kan ikke undgå at denne er en del af nøglen.
Avatar billede arne_v Ekspert
16. februar 2012 - 21:56 #3
Fordi saa er der et variant_id til dem hvor der kun er en variant.
Avatar billede AnyFellow Mester
16. februar 2012 - 22:02 #4
Åh, på den måde.

Ja det vil nok være en okay løsning.

Læg et svar og der er point på vej.
Avatar billede arne_v Ekspert
16. februar 2012 - 23:48 #5
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester