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

502

    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. Tänään pyörit ajatuksissa enemmän, kun erehdyin lukemaan palstaa

      En saisi, silti toivon että sinä vielä palaat ja otetaan oikeasti selvää, hioituuko särmät ja sulaudummeko yhteen. Vuod
      Ikävä
      22
      5214
    2. Huomenta ihana

      Kauniskasvoinen ihanuus 😘 saan sut vielä
      Ikävä
      25
      4378
    3. Hei rakas...

      Miten on työpäivä sujunut? Rakastan sinua 💗
      Ikävä
      27
      2501
    4. Edelleen sitä on vaikea uskoa

      Että olisit oikeasti rakastunut muhun
      Ikävä
      34
      2264
    5. Toiveikas vai toivoton

      torstai? Ajatuksia?
      Ikävä
      37
      2008
    6. Vitsi mihin menit. Heti takasin.

      Mä näin sut tuu takasin! Oli kiire, niin en ehtiny sin perään!
      Ikävä
      15
      1918
    7. En ole koskaan kokenut

      Ennen mitään tällaista rakastumista. Tiedän että kaipaan sinua varmaan loppu elämän. Toivottavasti ei tarvitsisi vain ka
      Ikävä
      19
      1607
    8. Mukavaa päivää

      Mun rakkauden kohteelle ❤️ toivottavasti olet onnellinen
      Ikävä
      12
      1531
    9. Voi ei! Jari Sillanpää heitti keikan Helsingissä - Hämmästyttävä hetki lavalla...

      Ex-tangokuningas on parhaillaan konserttikiertueella. Hän esiintyi Savoy teatterissa äitienpäivänä. Sillanpää jakoi kons
      Suomalaiset julkkikset
      21
      1267
    10. Kerranki asiat oikein

      Ilkka ja muut pienpuolueeet...teitte hyvän työn kun valitsitte pätevän henkilön virkaan eikä kepulle passelia!! Jatkakaa
      Haapavesi
      10
      1184
    Aihe