Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: różnica w left join między mysql 4 a 5
Forum PHP.pl > Forum > Bazy danych > MySQL
nospor
w mysql4 można było pisac tak:
  1. SELECT * FROM table1, table2 LEFT JOIN table3 ON table3.idtable1=table1.id

Niestety dla mysql5 skutkuje to błędem: Unknown column 'table1.id' in 'on clause'

Zeby to zadziałalo nalezy zmienic kolejnosc w from

  1. SELECT * FROM table2, table1 LEFT JOIN table3 ON table3.idtable1=table1.id


I jest git. Troche poronione ale git.

No a teraz sytuacja, gdzie w on clause korzystamy z dwoch tabel:
  1. SELECT * FROM table1, table2 LEFT JOIN table3 ON (table3.idtable1=table1.id AND table3.idtable2=table2.id)

Dostaniemy blad: Unknown column 'table1.id' in 'on clause'
No dobra, zamieniamy wiec w from kolejnosc:
  1. SELECT * FROM table2, table1 LEFT JOIN table3 ON (table3.idtable1=table1.id AND table3.idtable2=table2.id)

Dostaniemy blad: Unknown column 'table2.id' in 'on clause'

Patowa sytuacja :/
Jest na to jakiś sprytny myk?
teutates
Jasne:) Sprobuj tak:

  1. SELECT * FROM (table2, table1) LEFT JOIN table3 ON table3.idtable1=table1.id AND table3.idtable2=table2.id


http://bugs.mysql.com/bug.php?id=13551

Pozdrawiam
nospor
dzięki wielkie smile.gif

zachciało im sie do standardów gonic... winksmiley.jpg
teutates
Przyjaciel przyjaciela, tez przyjaciel:)

Pozdrawiam
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.