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

510

    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. Kysymys muille miehille

      Onko teille varattu nainen ongelma? Mikään muu naisessa ei töki kun se että hän on varattu. Kamppailen houkutuksen kanss
      Ikävä
      140
      7929
    2. Kaipaisin nyt kosketusta

      jota ei koskaan ole ollut. Saisinpa tuntea kätesi niskallani ja silittelemässä päätäni. Sulaisin varmasti siihen.
      Ikävä
      31
      3126
    3. Imaami kysyy, miksi pojat uivat ilman valvontaa

      Kalajoen särkät ovat usean kilometrin pituiset. Siellä on kylttejä, joissa varoitetaan rannan vaaroista. Siellä ei ole
      Maailman menoa
      383
      2199
    4. Mansikkatiloilla hyväksikäytetään ukrainalaisia

      Työolot ovat surkeita ja palkka kelvoton. https://yle.fi/a/74-20172942
      Maailman menoa
      284
      1760
    5. Kerrostaloihin ilmalämpöpumput

      Ulkomailla näkee paljon ilmalämpöpumppuja kerrostalojen ulkoseinissä. Mikä estää taloyhtiötä hankkimasta niitä asuntoih
      Sinkut
      147
      1583
    6. Tukalaa kuumuutta

      Tietäisitpä vaan kuinka kuumana olen käynyt viime päivät. Eikä johdu helteestä, vaan sinusta. Mitäköhän taikoja olet teh
      Ikävä
      21
      1431
    7. Sokea "ystävälle"

      Oletko oikeasti noin sokea?
      Ikävä
      100
      1229
    8. Sinä, ihastukseni

      Mitä haluaisit tehdä kanssani ensimmäisenä?
      Ihastuminen
      15
      1228
    9. En ymmärrä käytöstäsi

      Se on ollut eräänlaista hyväksikäyttöä. Että seura kyllä kelpaa palstan välityksellä silloin kun ei ole parempaakaan tek
      Ikävä
      137
      1152
    10. Tiedät ettei tule toimimaan.

      Mielenterveys ei kummallakaan kestä.
      Ikävä
      18
      1112
    Aihe