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

470

    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. Miksi jollain jää "talvi päälle"

      Huvittaa kastoa ullkona jotain vahempaa äijää joka pukeutuu edelleen kun olisi +5 astetta lämmittä vaikka on helle keli
      Maailman menoa
      274
      2830
    2. Mitä et hyväksy miehessä/naisessa josta olet kiinnostunut?

      Itse en halua, että miehellä olisi lapsia!
      Ikävä
      212
      1818
    3. Se katse silloin

      Oli hetki, jolloin katseemme kohtasivat. Oli talvi vielä. Kerta toisensa jälkeen palaan tuohon jaettuun katseeseen. Tunt
      Ikävä
      59
      1502
    4. Tiesitkö? Farmi Suomi Kirsikka Simberg on tämän julkkisnaisen tytär - Katso tyrmäävät mallikuvat!

      Oho, aikamoinen ylläri. Tiesitkö?! Kirsikka Simberg on yksi tämän kauden Farmi Suomi -kisaajista. Hänellä ei ole tuttu t
      Suomalaiset julkkikset
      1
      1261
    5. Kaipaaville

      Kerro sun tunteesi ja ajatukset tähän jos et uskalla irl!
      Ikävä
      77
      1188
    6. Tuhdit oluet kauppoihin. Miksi vastustaa?

      8% oluet kauppoihin mutta mikä siinä on että osa politikoista vstustaa ? Kauppa kuitenkin hinnoittelee vahvan oluen ni
      Maailman menoa
      254
      1126
    7. Miten haluaisit

      Että reagoisin jos näkisin sinut nyt?
      Ikävä
      80
      1032
    8. Sinua tulen kyllä ikävöimään pitkään nainen

      mutta oli pakko tehdä päätös oman mielenrauhan vuoksi. Toivottavasti saat elämältä kaiken mitä haluat.
      Ikävä
      52
      973
    9. Tärkeä kysymys!

      Haluatko sinä, mies, minut?
      Ikävä
      78
      895
    10. Kärsämäki rosvojen ja tuhopolttajien kylä?

      Poliisi ampui uhkaava miestä Kärsämäellä. Ja vasta joku poltti rivitalon. Mikä riivaa Kärsämäkisiä? Joko tuulimyllyjen
      Kärsämäki
      15
      770
    Aihe