SELECT * FROM a JOIN b LEFT JOIN c ON(a.b_id = b.id AND a.c_id = c.id)
SELECT * FROM a JOIN b ON(a.b_id = b.id) LEFT JOIN c ON(a.c_id = c.id)
Tuo ylimmäinen palauttaapi vaik mitä tietoa alimmainen toimii kunnol. Pitääkö tuo on lause määrittää aina sen kuten alimmaisessa on tehty?
Ilmeisesti alimmainen joinaa a tauluun b ehdoin a.b_id = b.id ja sitten left joinaa c taulun ehdoin a.c_id = c.id
Eikös tuo ylempi pitäisi tehdä saman?
Mitä eroa näillä?
3
364
Vastaukset
- I.Proqatlis
MySQL-tietokantako kyseessä? Minulla on versio 5.0.15 eikä se edes salli tuota ylempää vaihtoehtoa, vaan sanoo, että on-lauseessa on tuntematon sarake (a-taulun sarake).
Jos sinä kirjoitat tuon ylemmän vaihtoehdon mukaisesti
SELECT * FROM a JOIN b;
niin tämä tarkoittaa, että sinä haluat yhdistää jok'ikisen a-taulun rivin jok'ikisen b-taulun rivin kanssa. Ei kai tämä ole tarkoitus?
On-lauseella kerrotaan, mitkä rivit tauluissa yhdistetään eli mitkä rivit a-taulussa kuuluvat yhteen b-taulun rivien kanssa.- I.Proqatlis
Tällainen sen sijaan toimii:
SELECT * FROM a JOIN (b JOIN c )
ON (b.id=a.b_id AND c.id=a.c_id) - nEa3
I.Proqatlis kirjoitti:
Tällainen sen sijaan toimii:
SELECT * FROM a JOIN (b JOIN c )
ON (b.id=a.b_id AND c.id=a.c_id)Muistaakseni MySQL 5.0.26 en nyt pääse palvelimelle katsomaan mikä, kuitenkin 5 versio.
Kyl mul tuo ylempä toimii, mutta kokeilin vähän isommalla taulukolla niin kyselyn suorittaminen kesti todella kauan ja palautti miljoonia rivejä, vaik tauluissa vain parisen tuhatta. Joten kai se tekee tuon minkä selostit, et yhdistää jokaikiseen. Mutta aika outoa sinänsä sillä tuossahan on tuo ON lause.
"Jos sinä kirjoitat tuon ylemmän vaihtoehdon mukaisesti
SELECT * FROM a JOIN b;
niin tämä tarkoittaa, että sinä haluat yhdistää jok'ikisen a-taulun rivin jok'ikisen b-taulun rivin kanssa. Ei kai tämä ole tarkoitus?"
Ei ole, tarkoitus on perus JOIN ja LEFT JOIN noilla yllämainituin ehdoin. Tuolla ylemmällä kokeilin ensiks ja ihmettelin pitkään miks toimii ihmeellisesti ja sit näin jossain tuolla alemmalla tavalla tehtynä niin sillähän toimi.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
- 1562821
En kai koskaan saa sinua
Koska et usko että riitäisit minulle. Olet aina pitänyt itseäsi liian risana ja heikkona. Katkot korkeutesi, ja poraat k1541719Terveystalon lääkärit ylilaskuttaneet
Tämän pörriäiset osaavat, laskuttamisen. Terveystalo myöntää asian. https://www.hs.fi/suomi/art-2000011134269.html "K1461694Saran ökytyyli käänsi katseita.
On nyt kyllä Sara kasvoistaan, kuvan perusteella todellakin pyöristynyt ainakin kuvan perusteella.1511459- 721420
Työttömille lusmuille luvassa lisää keppiä
Hallitus aikoo kiristää velvoitteiden laiminlyönnistä seuraavia työttömyysturvan karensseja ensi vuodesta alkaen. Hall3251308The Summit Suomi: Maxie avaa hyytävästä tilanteesta kuvauksissa: "Veri roiskui ja tajusi, että..."
Oletko seurannut The Summit Suomea? Tykkäätkö vai et tai mitä mieltä ylipäätään olet sarjasta? Moni katsoja on kaikonnut181211Tekisi niin mieli laittaa sulle viestiä
En vaan ole varma ollaanko siihen vielä valmiita, vaikka halua löytyykin täältä suunnalta, ja ikävää, ja kaikkea muuta m661026- 1561016
Miksi ihmeessä?
Erika Vikman diskattiin, ei osallistu Euroviisuihin – tilalle Gettomasa ja paluun tekevä Cheek25985