Toisesta taulusta tiedon hakeminen? (mysql)

KanLuka

Olen tekemässä relaatiotietokantaa ja aika alkutaipaleilla vielä mennään. Toivottavasti joku osaa autella miestä mäessä ongelmani kanssa. Eli, miten onnistuu tiedon haku toisesta taulusta johon olen viiteavaimella viitannut. Jos esim pitäsi tulostaa sivuille pelaajalista, olen onnistunut saamaan ruudulle ainoastaan joukkuekohdalle joukkueen id-numeron:
1 63 Kari Ketola 3

9

527

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • qwertysql
    • IJ

      SELECT p.id
                     , p.pelinumero
                     , p.nimi
                     , j.nimi
            FROM pelaaja AS p
      INNER
            JOIN joukkue AS j
                  ON j.id = p.joukkueid

      • KanLuka

        Jees, kiitos molemmille! Ymmärrän homman nyt huomattavasti paremmin. Mutta..

        On taulut joukkue ja ottelut:

        * * * JOUKKUE-TAULU
        - ID (INT, AUTO_INCREMENT, PRIMARY KEY)
        - NIMI (VARCHAR)
        esim:
        1 (ID) Orimattilan Pedot (NIMI)
        2 Porin Karhut
        3 Lapuan Virkiä

        *** OTTELUT-TAULU
        - ID (INT, AUTO_INCREMENT, PRIMARY KEY)
        - KOTIJOUKKUEID (INT, FOREIGN KEY)
        - VIERASJOUKKUEID (INT, FOREIGN KEY)

        Pitäisi saada haettua ottelun id ja kotijoukkue vs vierasjoukkue. Olen yrittänyt seuraavanlaisella haulla, joka ei siis ole onnistunut. Miten ko.juttu menee tässä tapauksessa, kun haetaan samasta joukkue taulusta sekä vierasjoukkue että kotijoukkue?

        SELECT o.ottelu_id, j.nimi, j.nimi
        FROM ottelu AS o
        INNER JOIN joukkue AS j
        ON j.id=o.kotijoukkueid AND j.id=o.vierasjoukkueid


      • KanLuka
        KanLuka kirjoitti:

        Jees, kiitos molemmille! Ymmärrän homman nyt huomattavasti paremmin. Mutta..

        On taulut joukkue ja ottelut:

        * * * JOUKKUE-TAULU
        - ID (INT, AUTO_INCREMENT, PRIMARY KEY)
        - NIMI (VARCHAR)
        esim:
        1 (ID) Orimattilan Pedot (NIMI)
        2 Porin Karhut
        3 Lapuan Virkiä

        *** OTTELUT-TAULU
        - ID (INT, AUTO_INCREMENT, PRIMARY KEY)
        - KOTIJOUKKUEID (INT, FOREIGN KEY)
        - VIERASJOUKKUEID (INT, FOREIGN KEY)

        Pitäisi saada haettua ottelun id ja kotijoukkue vs vierasjoukkue. Olen yrittänyt seuraavanlaisella haulla, joka ei siis ole onnistunut. Miten ko.juttu menee tässä tapauksessa, kun haetaan samasta joukkue taulusta sekä vierasjoukkue että kotijoukkue?

        SELECT o.ottelu_id, j.nimi, j.nimi
        FROM ottelu AS o
        INNER JOIN joukkue AS j
        ON j.id=o.kotijoukkueid AND j.id=o.vierasjoukkueid

        KORJAUS, haku siis tietenkin:

        SELECT o.id, j.nimi, j.nimi
        FROM ottelu AS o
        INNER JOIN joukkue AS j
        ON j.id=o.kotijoukkueid AND j.id=o.vierasjoukkueid


      • sqlmy
        KanLuka kirjoitti:

        KORJAUS, haku siis tietenkin:

        SELECT o.id, j.nimi, j.nimi
        FROM ottelu AS o
        INNER JOIN joukkue AS j
        ON j.id=o.kotijoukkueid AND j.id=o.vierasjoukkueid

        Esim tässä löytyy vastaus
        www.cs.helsinki.fi/u/laine/tikape/k00/sql2.pdf


      • IJ
        KanLuka kirjoitti:

        KORJAUS, haku siis tietenkin:

        SELECT o.id, j.nimi, j.nimi
        FROM ottelu AS o
        INNER JOIN joukkue AS j
        ON j.id=o.kotijoukkueid AND j.id=o.vierasjoukkueid

        Itse tekisin näin:

        SELECT o.id
                       , koti.nimi
                       , vieras.nimi
              FROM ottelut AS o
        INNER
              JOIN joukkue AS koti
                    ON koti.id = o.kotijoukkueid
        INNER
              JOIN joukkue AS vieras
                    ON vieras.id = o.vierasjoukkueid


      • KanLuka
        IJ kirjoitti:

        Itse tekisin näin:

        SELECT o.id
                       , koti.nimi
                       , vieras.nimi
              FROM ottelut AS o
        INNER
              JOIN joukkue AS koti
                    ON koti.id = o.kotijoukkueid
        INNER
              JOIN joukkue AS vieras
                    ON vieras.id = o.vierasjoukkueid

        Kiitos! Näinhän se menee. Pitänee jatkaa kuitenkin hyvässä vauhdissa olevaa opiskelua :)

        Vielä sen verran, että millä lauseella saan haettua esim. kaikki Lapuan Virkiän (id3) ottelut? Onnistun ainoastaan hakemaan koti tai vierasottelut..


      • KanLuka
        KanLuka kirjoitti:

        Kiitos! Näinhän se menee. Pitänee jatkaa kuitenkin hyvässä vauhdissa olevaa opiskelua :)

        Vielä sen verran, että millä lauseella saan haettua esim. kaikki Lapuan Virkiän (id3) ottelut? Onnistun ainoastaan hakemaan koti tai vierasottelut..

        Ei enää mitään. Olenko oikeassa?:

        WHERE koti.id = "3" OR vieras.id = "3"
        TAI
        WHERE koti.nimi = "Lapuan Virkiä" OR vieras.nimi = "Lapuan Virkiä"

        Onko merkitystä hakeeko id:llä vai nimellä? ainakaan tulokseen ei vaikuta.


      • tietäjävänäinen
        KanLuka kirjoitti:

        Ei enää mitään. Olenko oikeassa?:

        WHERE koti.id = "3" OR vieras.id = "3"
        TAI
        WHERE koti.nimi = "Lapuan Virkiä" OR vieras.nimi = "Lapuan Virkiä"

        Onko merkitystä hakeeko id:llä vai nimellä? ainakaan tulokseen ei vaikuta.

        ID:llä hakeminen on nopeampaa. Ero tulee esiin jos tietokannassa on paljon tietoja. Kannattaa aina kuin vain on mahdollista käyttää numeerisia arvoja hauissa.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Porvarimediat paniikissa demareiden huiman kannatuksen vuoksi

      Piti sitten keksiä "nimettömiin lähteisiin" perustuen taas joku satu. Ovat kyllä noloja, ja unohtivat sen, että vaalit
      Maailman menoa
      98
      6328
    2. KATASTROFI - Tytti Tuppurainen itse yksi pahimmista kiusaajista!!!

      STT:n lähteiden mukaan SDP:n eduskuntaryhmän puheenjohtaja Tytti Tuppurainen on käyttäytynyt toistuvasti epäasiallisesti
      Maailman menoa
      355
      5825
    3. Mikä siinä on ettei persuille leikkaukset käy?

      On esitetty leikkauksia mm. haitallisiin maataloustukiin, kuin myös muihin yritystukiin. Säästöjä saataisiin lisäksi lei
      Maailman menoa
      60
      2813
    4. Lääppijä Lindtman jäi kiinni itse teosta

      Lindtman kyselemättä ja epäasiallisesti koskettelee viestintäpäällikköä. https://www.is.fi/politiikka/art-2000011780852
      Maailman menoa
      107
      2248
    5. Juuri nyt! Tytti Tuppurainen on käyttäytynyt toistuvasti epäasiallisesti

      Ai että mä nautin, Tytti erot vireille! "Käytös on kohdistunut avustajia ja toisia kansanedustajia kohtaan, uutisoi STT
      Maailman menoa
      107
      1938
    6. Onko kaivattusi

      liian vetovoimainen seksuaalisesti?
      Ikävä
      125
      1754
    7. Puolen vuoden koeaika

      Voisi toimia meillä. Ensin pitäis selvittää "vaatimukset" puolin ja toisin, ennen kuin mitään aloittaa. Ja matalalla pro
      Ikävä
      19
      1633
    8. Tytti Tuppurainen nöyryyttää avustajiaan

      Tytti Tuppurainen nöyryyttää SDP:n eduskuntaryhmän kokouksissa sekä avustajia että kansanedustajia. Hän nolaa ihmisiä ju
      Kotimaiset julkkisjuorut
      181
      1300
    9. On todella hassua

      Ajatella että pitäisit erityisen kuumana tai seksikkäänä?
      Ikävä
      73
      1197
    10. Huomaatteko Demari Tytti ei esitä pahoitteluitaan

      Samanlainen ilmeisesti kuin Marin eli Uhriutuu no he ovat Demareita ja muiden yläpuolella siis omasta mielestään
      Maailman menoa
      33
      1098
    Aihe