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
Toisesta taulusta tiedon hakeminen? (mysql)
9
505
Vastaukset
- qwertysql
Kannattaa tutustua tähän: http://dev.mysql.com/doc/refman/5.0/en/join.html
- 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.vierasjoukkueidKORJAUS, 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.vierasjoukkueidEsim 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.vierasjoukkueidItse 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.vierasjoukkueidKiitos! 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
Poliisi: Kymmenhenkinen pohjalaisperhe ollut vuoden kateissa kansainvälinen etsintäkuulutus Poliis
Poliisi: Kymmenhenkinen pohjalaisperhe ollut vuoden kateissa – kansainvälinen etsintäkuulutus Poliisi pyytää yleisön apu2912625Tässä totuus jälleensyntymisestä - voit yllättyä
Jumalasta syntyminen Raamatussa ei tässä Joh. 3:3. ole alkukielen mukaan ollenkaan sanaa uudestisyntyminen, vaan pelkä3001389- 1081261
En kadu sitä, että kohtasin hänet
mutta kadun sitä, että aloin kirjoittamaan tänne palstalle. Jollain tasolla se saa vain asiat enemmän solmuun ja tekee n831241Noniin rakas
Annetaanko pikkuhiljaa jo olla, niin ehkä säilyy vienot hymyt kohdatessa. En edelleenkään halua sulle tai kenellekään mi991215Oisko mitenkään mahdollisesti ihan pikkuisen ikävä..
...edes ihan pikkuisen pikkuisen ikävä sulla mua??.. Että miettisit vaikka vähän missähän se nyt on ja oiskohan hauska n581195- 451063
Helena Koivu : Ja kohta mennään taas
Kohta kohtalon päivä lähestyy kuinka käy Helena Koivulle ? Kenen puolella olet? Jos vastauksesi on Helenan niin voisi74963Au pair -työ Thaimaassa herättää kiivasta keskustelua somessa: "4cm torakoita, huumeita, tauteja..."
Au pairit -sarjan uusi kausi herättää keskustelua Suomi24 Keskustelupalvelussa. Mielipiteitä ladataan puolesta ja vastaa22900- 33807