Miten teen suraavasta taulusta sellaisen että se huolii sukupuoleksi vain vaihtoehdot 'Mies' tai 'Nainen' ? Siihen pitäisi kai lisätä jotain tyyliin: check('Mies' | 'Nainen') - vai mitä pitäisi lisätä...Oraclea käytän. Kiitoksia jos joku sattuu tietämään. CREATE TABLE OPPILAS ( oppilasnro char(4) not null, etunimi char(10), sukunimi char(10), sukupuoli char(1), primary key (oppilasnro)); CREATE TABLE OPPILAS ( oppilasnro char(4) not null, etunimi char(10), sukunimi char(10), ----> sukupuoli char(1), ('Mies'|'Nainen) primary key (oppilasnro)); !!???
SQL taulun luontikysymys
3
776
Vastaukset
- on kauan
tuosta kun SQL:ää olen viimeksi käyttänyt, etten nyt ihan varmaksi muista. Pari asiaa kuitenkin näen jo tuosta lauseesta heti kättelyssä. sukupuoli char(1), ('Mies'|'Nainen) - kentän pituudeksi annetaan 1 kirjain ja sallitut vaihtoehdot ovat neljä- tai kuusikirjaimisia. Toinen, tuon 'Nainen) pitää olla 'Nainen') Toimisiko niinkin yksinkertaisesti kuin: sukupuoli char(1), ('M'|'N')?
- The Rat
En muista kuulleeni, että oracle suoraan tuollaista tukisi create tablessa. Kannattaa googlata, jos vaikka olisin väärässä (hyvinkin mahdollista). Sinänsä arvojen tarkistukset on hyvä tehdä triggerillä kuitenkin. Before insert ja before update pitäisi riittää. Ajatellaan vaikka tilannetta, että myöhemmin lisäät hetun tuohon tauluun (kuvitteellinen tilanne siis). Jos sukupuolirajaus on jo triggerissä, voit samalla helposti tehdä pienen lisätarkistuksen hetun suhteen... Tai jos sukupuolia tulee lisää. :)
- SQL Guru
http://www.techonthenet.com/oracle/check.php
Siellä tosiaan on toi Check-constraint
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Oletko kertonut jo muille tunteistasi?
Ystävillesi esimerkiksi? Minä en ole vielä kertonut kenellekään tästä meidän jutusta.774622- 1801897
- 1241590
- 1241125
Miten minusta tuntuu että kaikki tietää sun tunteista mua kohtaan
Paitsi suoraan minä itse, vai mitä hlvettiä täällä tapahtuu ja miksi ihmiset susta kyselee minulta 🤔❤️161061- 351036
- 78933
- 52896
Hyvää huomenta!
Mietin miten suhtaudut minuun, jos kerron tunteista. Voinko enää sen jälkeen olla samassa paikassa kanssasi, jos koet as78872- 4828