Mitä eroa näillä?

nEa3

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?

3

345

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • 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

    1. Kotkalainen Demari Riku Pirinen vangittu Saksassa lapsipornosta

      https://www.kymensanomat.fi/paikalliset/8081054 Kotkalainen Demari Riku Pirinen vangittu Saksassa lapsipornon hallussapi
      Kotka
      94
      2410
    2. Olen tosi outo....

      Päättelen palstajuttujen perusteella mitä mieltä minun kaipauksen kohde minusta on. Joskus kuvittelen tänne selkeitä tap
      Ikävä
      21
      2300
    3. Vanhalle ukon rähjälle

      Satutit mua niin paljon kun erottiin. Oletko todella niin itsekäs että kuvittelet että huolisin sut kaiken tapahtuneen
      Ikävä
      19
      1898
    4. Maisa on SALAKUVATTU huumepoliisinsa kanssa!

      https://www.seiska.fi/vain-seiskassa/ensimmainen-yhteiskuva-maisa-torpan-ja-poliisikullan-lahiorakkaus-roihuaa/1525663
      Kotimaiset julkkisjuorut
      77
      1532
    5. Oletko sä luovuttanut

      Mun suhteeni
      Ikävä
      106
      1497
    6. Hommaatko kinkkua jouluksi?

      Itse tein pakastimeen n. 3Kg:n murekkeen sienillä ja juustokuorrutuksella. Voihan se olla, että jonkun pienen, valmiin k
      Sinkut
      161
      1258
    7. Aatteleppa ite!

      Jos ei oltaisikaan nyt NATOssa, olisimme puolueettomana sivustakatsojia ja elelisimme tyytyväisenä rauhassa maassamme.
      Maailman menoa
      257
      1062
    8. Mitä sanoisit

      Ihastukselle, jos näkisitte?
      Tunteet
      70
      981
    9. Onko se ikä

      Alkanut haitata?
      Ikävä
      78
      929
    10. Omalääkäri hallituksen utopia?

      Suurissa kaupungeissa ja etelässä moinen onnistunee. Suuressa osassa Suomea on taas paljon keikkalääkäreitä. Mitenkäs ha
      Maailman menoa
      174
      903
    Aihe