Eli pitäisi tallentaa henkilöiden nimet ja kuka on kenen veli/sisko.
Eli jos haetaan Matti, niin tietokanta palauttaa, että Matin sisko on Liisa.
Ja jos haetaan Liisa, niin palautetaan, että Liisan veli on Matti
jne... Millainen kanta ja millaiset kyselyt tarvitaan?
Millainen tietokanta?
9
884
Vastaukset
- dfghdfhg
Taulu1:
Id integer
Name Varhcar(50)
Id| Name
------------
1 | Ville
2 | Liisa
3 | Maija
4 | Kalle
5 | Hermanni
Taulu2
Id1 integer
Id2 integer
Status VarChar(50)
Id1|Id2| Status
----------------
1 | 2 | Sisko
1 | 3 | Sisko
1 | 4 | Veli
1 | 5 | Isä
2 | 1 | Veli
2 | 3 | Sisko
2 | 4 | Veli
2 | 5 | Isä
3 | 1 | Veli
3 | 2 | Sisko
3 | 4 | Veli
3 | 5 | Isä
4 | 1 | Veli
4 | 2 | Sisko
4 | 3 | Sisko
4 | 5 | Isä
5 | 1 | Poika
5 | 2 | Tytär
5 | 3 | Tytär
5 | 4 | Poika
SELECT A.Name, B.Name, C.Status FROM Person A, Person B, Link C
WHERE (A.Name='Hermanni') AND (C.Id1=A.Id) AND (C.Id2=B.Id)
Son sitten eriasia minkälaisella käyttöliittymällä meinaat toteuttaa mutta noin nyt ainakin käy.
voihan sinne tehdä automatiikan joka määrittelee Liisan villen siskoksi jos käyttöliittymästä liitetään Liisa Villen veljeksi niin ei tarvi käsin tehdä jokaista kytkentää.
Mutta kysymyksestä nyt ei tarkemmin selvinnyt minkälaista tässä haetaan.
Ristiinkytkennän välttää myös jos A.Name vaihdetaan ohjelmassa haluttaessa B.Name:ksi tosin status katoaa.
Mutta periaatehan on tuossa sitten muita härpäkkeitä voi tarpeen mukaan lisäillä.- Kekkeruusihhhh
Tuo mahdollistaa vaikka minkälaiset suhteet henkilöiden välille. Parempi olisi varmaan käyttää suhteita isä/äiti ja sitten tehdä kyselyitä henkilöihin joilla on samat vanhemmat. Ja tässähän ei sitten tarvitse edes muita tauluja vaan vittaukset samaan tauluun riittää.
- kekkeruuusis
Kekkeruusihhhh kirjoitti:
Tuo mahdollistaa vaikka minkälaiset suhteet henkilöiden välille. Parempi olisi varmaan käyttää suhteita isä/äiti ja sitten tehdä kyselyitä henkilöihin joilla on samat vanhemmat. Ja tässähän ei sitten tarvitse edes muita tauluja vaan vittaukset samaan tauluun riittää.
/* taulun luonti rekursiivisilla suhteilla isa/aiti samaan tauluun */
CREATE TABLE henkilot(
id integer PRIMARY KEY,
nimi varchar(50) NOT NULL,
sukupuoli char(1) CHECK(sukupuoli in ('m', 'n')),
aiti integer,
isa integer,
FOREIGN KEY(aiti) REFERENCES henkilot(id),
FOREIGN KEY(isa) REFERENCES henkilot(id)
)
/* kantaisa ja -aiti*/
INSERT INTO henkilot(id, nimi, sukupuoli) VALUES (1, 'Aatami', 'm')
INSERT INTO henkilot(id, nimi, sukupuoli) VALUES (2, 'Eeva', 'n')
/* näiden lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (3, 'Kain', 'm', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (4, 'Abel', 'm', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (5, 'Hanna', 'n', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (6, 'Kerttu', 'n', 2, 1)
/* Kainin & Hannan lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (7, 'Simo', 'm', 5, 3)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (8, 'Arja', 'n', 5, 3)
/* Abelin & Kertun lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (9, 'Pertti', 'm', 6, 4)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (10, 'Anna', 'n', 6, 4)
/* Haetaan eevan ja aatamin lapset */
SELECT * FROM henkilot WHERE aiti=2 and isa=1
/* Simon veljet / siskot */
SELECT aiti,isa FROM henkilot WHERE id=7 /* ensin haetana simon aiti ja isa */
SELECT * FROM henkilot WHERE aiti=5 and isa=3 /* tulee Simo että Arja - tässä voisi tietenkin rajata sukupuolella jos haluaa esim vain siskot */
Samalla periaatteella voi sitten hakea serkut tätit yms.. eli tallenna se suku hierarkisesti niin pääset vähemmällä ;) - kekekekekeed
kekkeruuusis kirjoitti:
/* taulun luonti rekursiivisilla suhteilla isa/aiti samaan tauluun */
CREATE TABLE henkilot(
id integer PRIMARY KEY,
nimi varchar(50) NOT NULL,
sukupuoli char(1) CHECK(sukupuoli in ('m', 'n')),
aiti integer,
isa integer,
FOREIGN KEY(aiti) REFERENCES henkilot(id),
FOREIGN KEY(isa) REFERENCES henkilot(id)
)
/* kantaisa ja -aiti*/
INSERT INTO henkilot(id, nimi, sukupuoli) VALUES (1, 'Aatami', 'm')
INSERT INTO henkilot(id, nimi, sukupuoli) VALUES (2, 'Eeva', 'n')
/* näiden lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (3, 'Kain', 'm', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (4, 'Abel', 'm', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (5, 'Hanna', 'n', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (6, 'Kerttu', 'n', 2, 1)
/* Kainin & Hannan lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (7, 'Simo', 'm', 5, 3)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (8, 'Arja', 'n', 5, 3)
/* Abelin & Kertun lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (9, 'Pertti', 'm', 6, 4)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (10, 'Anna', 'n', 6, 4)
/* Haetaan eevan ja aatamin lapset */
SELECT * FROM henkilot WHERE aiti=2 and isa=1
/* Simon veljet / siskot */
SELECT aiti,isa FROM henkilot WHERE id=7 /* ensin haetana simon aiti ja isa */
SELECT * FROM henkilot WHERE aiti=5 and isa=3 /* tulee Simo että Arja - tässä voisi tietenkin rajata sukupuolella jos haluaa esim vain siskot */
Samalla periaatteella voi sitten hakea serkut tätit yms.. eli tallenna se suku hierarkisesti niin pääset vähemmällä ;)Voi jeesus, nyt vasta huomasin että tämäkin aloitus oli vuoden vanha :DDDDDDD
- -------
kekkeruuusis kirjoitti:
/* taulun luonti rekursiivisilla suhteilla isa/aiti samaan tauluun */
CREATE TABLE henkilot(
id integer PRIMARY KEY,
nimi varchar(50) NOT NULL,
sukupuoli char(1) CHECK(sukupuoli in ('m', 'n')),
aiti integer,
isa integer,
FOREIGN KEY(aiti) REFERENCES henkilot(id),
FOREIGN KEY(isa) REFERENCES henkilot(id)
)
/* kantaisa ja -aiti*/
INSERT INTO henkilot(id, nimi, sukupuoli) VALUES (1, 'Aatami', 'm')
INSERT INTO henkilot(id, nimi, sukupuoli) VALUES (2, 'Eeva', 'n')
/* näiden lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (3, 'Kain', 'm', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (4, 'Abel', 'm', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (5, 'Hanna', 'n', 2, 1)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (6, 'Kerttu', 'n', 2, 1)
/* Kainin & Hannan lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (7, 'Simo', 'm', 5, 3)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (8, 'Arja', 'n', 5, 3)
/* Abelin & Kertun lapset */
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (9, 'Pertti', 'm', 6, 4)
INSERT INTO henkilot(id, nimi, sukupuoli, aiti, isa) VALUES (10, 'Anna', 'n', 6, 4)
/* Haetaan eevan ja aatamin lapset */
SELECT * FROM henkilot WHERE aiti=2 and isa=1
/* Simon veljet / siskot */
SELECT aiti,isa FROM henkilot WHERE id=7 /* ensin haetana simon aiti ja isa */
SELECT * FROM henkilot WHERE aiti=5 and isa=3 /* tulee Simo että Arja - tässä voisi tietenkin rajata sukupuolella jos haluaa esim vain siskot */
Samalla periaatteella voi sitten hakea serkut tätit yms.. eli tallenna se suku hierarkisesti niin pääset vähemmällä ;)Hmmm saanenko kysyä miksi sukupuoli ei ole ENUM tyyppiä?
Eikös noitten sukulaissuhteiden hakemiseen kannattaisi tehdä ihan proseduuri, jolloin pystyisi hakemaan helposti tarpeeksi pitkälle sukupuussa, kuten tädit jne... mitä nyt haluaakin tietää.
Eikös se yleinen ohje ole, että kaikki tietokannan omat komennot isolla jolloin ne helposti erottaa. - kekkkeee
------- kirjoitti:
Hmmm saanenko kysyä miksi sukupuoli ei ole ENUM tyyppiä?
Eikös noitten sukulaissuhteiden hakemiseen kannattaisi tehdä ihan proseduuri, jolloin pystyisi hakemaan helposti tarpeeksi pitkälle sukupuussa, kuten tädit jne... mitä nyt haluaakin tietää.
Eikös se yleinen ohje ole, että kaikki tietokannan omat komennot isolla jolloin ne helposti erottaa.Toki sen sukupuolen voi esittää haluamallaan tavalla. Tuo oli vain nopia esimerkki eikä enumeja ole välttämättä joka tietokannassa. Pääpointti oli kuitenkin tuo rekursiivinen yhteys jonka avulla sukulaisuussuhteet voi esittää yksiselitteisesti.
Proseduureja / näkymiä käytetään tarpeen mukaan. Pääasia on kuitenkin että ne tiedot ovat siellä oikeus ja eheys varmistetaan jollakin tavalla. Ei tuossa laittamassani esimerkissä ole juuri muuta kuin minimit millä nämä tiedot voisi tallentaa eikä sisällä hirveitä tarkistuksia (mikään ei estä esim lasta olemasta oman äitinsä isä jne. :)
"Eikös se yleinen ohje ole, että kaikki tietokannan omat komennot isolla jolloin ne helposti erottaa."
Nojoo, ainakin perinteisesti noin on taidettu yleensä tehdä. Itse en sille paljoa painoa laita koska useimmat editorit sisältävät tarvittavat syntaksiväritykset tehden käytännön melko tarpeettomaksi.
- Legacy-käyttäjä
Käytä valmista sukuohjelmaa.
http://www.legacyfamilytreestore.com/SearchResults.asp?Cat=1&Click=1192- Ilmainen vaihtoehto
www.juuret.fi. Ohjelman ikkunassa kiinteä 4:3 kuvasuhde, mutta muuten ok.
Hanki Sukujutut tai Acces-ohjelma
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
IL - Patteriauto syttyi parkkihallissa Tampereella - 50 autoa LUNASTUKSEEN!
"Palon aikaan parkkihallissa oli 90 autoa, joista noin 50 tuhoutui palossa korjauskelvottomiksi. Lisäksi palo vaurioitti27545872Kristillisistä Siionisteista asiallista tietoa Hesarissa.
KD ja Persut ovat kaiken takana avoimesti!5111460Persut JYTKYTTÄÄ ylös, ohi kepun! +2,1 %
Persut palasi kolmen suurimman joukkoon ja on matkalla kohti kevään 2027 eduskuntavaalivoittoa. Sosialistit ovat syöksy23311038Sanna Marin saa ylistystä Hillary Clintonilta
Jos joku ei tiedä kuka tämä rouva Hillary Clinton on, niin kerrottakoon "fun fact", eli hän on se keneltä Donald Trump399840Ja jälleen uusi latauksessa olleen sähköauton palo! Nyt Keravan Prisman parkkihallissa.
IS 3.10.2025 Latauksessa ollut sähköauto syttyi yöllä tuleen Keravan Prisman parkkihallissa, Keski-Uudenmaan pelastusla908678Gallup, PS:lle JÄRISYTTÄVÄ nousu, SDP suurin laskija
https://yle.fi/a/74-20186114 PS kovaa vauhtia nousemassa ennen 2027 vaaleja suurimmaksi puolueeksi. Nyt mennään jo etua2876738Borat ärhäkkänä, syyttelee kokoomusta vilpin suojelusta
Hänen mukaansa kokoomus seuraa ”toimettomana vierestä, kun vilpilliset firmat vievät urakat rehellisten nenän edestä”, j23549Kalja-Kristus Kutsuu Luokseen
Nyt on Oikea Hetki Ottaa Ryppyys Vastaan! Lue Pelastusryyppy ja tee Promillista elämäsi Herra! Pelastusryyppy on teksti33440Perussuomalaisiin minä luotan
Bensaa raaskii taas tankata ja ensi vuonna laskee ruoan verotus. Nämä muutokset parantavat pienituloisten asemaa.253163Persut on SYYLLISIÄ KAIKKEEN NEGATIIVISEEN SUOMESSA
, ne haluaa neuvostoliiton putinin kanssa takaisin, shit voi valvoa kaikkea ja kaikkia, no tietty makeeta mannaa itselle43023