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

521

    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. Maatalous- ja yritystuet pois, työeläkevaroilla valtion velka pois

      Suomi saadaan eheytettyä kädenkäänteessä, kun uskalletaan tehdä rohkeita ratkaisuja. Maatalous- ja yritystuet ovat hait
      Maailman menoa
      23
      3073
    2. Tykkäsin rakas

      Tuottaa sulle nautintoa❤️🔥olet paras ja nautin itsekkin suunnattomasti
      Suhteet
      41
      2694
    3. Mies mä oon ihan helppo

      Miehelle johon oon ihastunut. Olen harvoin ihastunut, mutta suhun olen. Ei tarvitse kuin pyytää, niin...
      Ikävä
      38
      1513
    4. Hyvää iltaa!

      Mikä on päivän viisaus?
      Ikävä
      84
      1350
    5. Olet onnellinen sinkku

      Näin se on nähtävä.
      Ikävä
      63
      1261
    6. Mies olen aika erakko nykyään

      Vanhentunutkin olen muutamana viime vuonna parikyt vuotta. Kun en ennenkään kelvannut, niin tuskin nytkään kelpaan. Lisä
      Tunteet
      40
      1009
    7. Lavroville taitaa olla jo ikkuna raollaan?

      Lavrovin syytä välttää korkeita paikkoja ja ikkunoiden läheisyyttä.Ettei vain keikahda ikkunasta pihalle.
      Maailman menoa
      126
      922
    8. Haittaako jos

      kaivattusi käy tosi usein pissalla ja/tai kakalla?
      Ikävä
      33
      829
    9. Ylen johdon hulppeat bonukset alkavat taas

      Suora kopio Iltalehdestä: "Asiasta kertoo Iltalehdelle Ylen hallituksen puheenjohtaja Matti Apunen. Mitä tulospalkkioi
      Yle
      29
      673
    10. Skenaario

      Elämä ja kuolema ovat merkillisin nyytti olevaisuutta. Mutta kun kumpaakaan ei ole, syntyy lapsuksia, joita korjaamaan
      Sinkut
      59
      621
    Aihe