Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [SQL][PgSQL] Wyrażenie warunkowe w zapytaniu
Forum PHP.pl > Forum > Bazy danych > PostgreSQL
Shavei
Czesc,

Chcialbym dodac w zapytaniu warunek dla LEFT JOIN lecz nie bardzo mi to wychodzi. Chciałbym joinować jakas tabele, w zaleznosci od wartosci jakiegos pola.
Skomplikowalem chyba troche, ale pokaze na przykladzie (oczywiscie [niestety] on nie dziala) o co mi chodzi.

  1. SELECT
  2. *
  3. FROM t_table1 AS t1
  4. LEFT JOIN t_table2 AS t2 ON t2.id = t1.id
  5. CASE WHEN t1.id > 300 THEN
  6. LEFT JOIN t_table3 AS t3 ON t3.id = t1.id
  7. ELSE END
  8. ORDER BY t1.id DESC



Jak to powinno poprawnie wygladac?
Dzieki za pomoc smile.gif
Zbłąkany
Jestem na 90% pewien, że taka konstrukcja nie jest dozwolona. A możesz mi wytłumaczyć, dlaczego akurat tak potrzebujesz skonstruować zapytanie?
Ja bym spróbował czegoś takiego:
  1. SELECT
  2. *
  3. FROM table1 AS t1
  4. LEFT JOIN table2 AS t2 ON t2.id = t1.id
  5. LEFT JOIN table3 AS t3 ON t3.id = t1.id AND t1.id > 300;
Shavei
Ja na 100% jestem pewien, że ta konstrukcja jest zabroniona ;-)
Potrzebuję skonstruować takie zapytanie, ponieważ chcę dołączyć tylko tą tabelę w zapytaniu, która jest mi potrzebna.
A jaką tabelę chciałbym dołączyć, to zależy od wartości w jednym z pól tabeli głównej :-)
wlamywacz
A może:
  1. SELECT
  2. *
  3. FROM t_table1 AS t1
  4. LEFT JOIN t_table2 AS t2 ON t2.id = t1.id
  5. LEFT JOIN t_table3 AS t3 ON (t3.id = t1.id AND t1.id > 300)
  6. ORDER BY t1.id DESC
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.