Millainen tietokanta?

asfasddfasd

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?

9

870

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • 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ä
      • 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

    1. Useita puukotettu Tampereella

      Mikäs homma tämä nyt taas on? "Useaa henkilöä on puukotettu Tampereen keskustassa kauppakeskus Ratinan lähistöllä." ht
      Tampere
      152
      2954
    2. Asiakas iski kaupassa varastelua tehneen kanveesiin.

      https://www.iltalehti.fi/kotimaa/a/33a85463-e4d5-45ed-8014-db51fe8079ec Oikein. Näin sitä pitää. Kyllä kaupoissa valtava
      Maailman menoa
      368
      2050
    3. Leipivaaran päällä on kuoleman hiljaista.

      Suru vai suuri helpotus...
      Puolanka
      41
      1805
    4. Kuka rääkkää eläimiä Puolangalla?

      Poliisi ampui toistakymmentä nälkiintynyttä eläintä Puolangalla Tilalta oli ollut karkuteillä lähes viisikymmentä nälkii
      Puolanka
      37
      1772
    5. Meneeköhän sulla

      oikeasti pinnan alla yhtä huonosti kuin mulla? Tai yhtä huonosti mutta jollain eri tyylillä? Ei olisi pitänyt jättää sua
      Ikävä
      32
      1421
    6. Jos ei tiedä mitä toisesta haluaa

      Älä missään nimessä anna mitään merkkejä kiinnostuksesta. Ole haluamatta mitään. Täytyy ajatella toistakin. Ei kukaan em
      Ikävä
      93
      1221
    7. Määpä tiijän että rakastat

      Minua nimittäin. Samoin hei! Olet mun vastakappaleeni.
      Ikävä
      54
      1173
    8. Muutama kysymys ja huomio hindulaisesta kulttuurista.

      Vedakirjoituksia pidetään historiallisina teksteinä, ei siis "julistuksena" kuten esimerkiksi Raamattua, vaan kuten koul
      Hindulaisuus
      328
      975
    9. Jumala puhui minulle

      Hän kertoi sinusta asioita, joiden takia jaksan, uskon ja luotan. Hän kuvaili sinua minulle ja pakahduin onnesta kuulles
      Ikävä
      110
      948
    10. Annan meille mahdollisuuden

      Olen avoimin mielin ja katson miten asiat etenevät. Mutta tällä kertaa sun on tehtävä eka siirto.Sen jälkeen olen täysil
      Ikävä
      53
      792
    Aihe