Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: ORDER BY z warunkiem
Forum PHP.pl > Forum > Bazy danych > MySQL
Stef@n
Witam, próbuje posortować dane z tabeli, ale trochę inaczej niż zawsze gdyż potrzebny jest warunek między dwiema kolumnami danych te kolumny to "wynik" i "dodatkowy_wynik". Teraz chce aby sortowała sie kolumna "wynik" >ORDER BY wynik ASC< ale jeśli dodatkowy_wynik jest większy od 0 a mniejszy od wynik to do sortowania ma pobierać dodatkowy_wynik. Próbowałem coś takiego, ale zero efektu:
  1. SELECT *, IF(dodatkowy_wynik > 0 AND dodatkowy_wynik < wynik) AS wynik FROM tabela ORDER BY wynik ASC


Proszę o pomoc
piotrex41
Takie coś to chyba z użyciem JOINa się robi. Poczytaj o LEFT JOIN, RIGHT JOIN i INNER JOIN. Wtedy możesz łączyć dwie tabele (bo o to Ci chodzi jeśli dobrze zrozumiałem). A jeśli nie dwie tabele a po prostu dwie wartości kolumn to chyba tak powinno działać:

Kod
SELECT `*` FROM `tabela` WHERE `dodatkowy_wynik` > '0' AND `dodatkowy_wynik` < `wynik` AS `wynik` ORDER BY `wynik` ASC
Stef@n
Chodzi o sortowanie 2 kolumn jednej tabeli z zastosowaniem tego warunku co opisałem wyżej. To co pokazałeś nie działa
redeemer
Może tak:
  1. SELECT *, IF(dodatkowy_wynik > 0 AND dodatkowy_wynik < wynik, dodatkowy_wynik, wynik) AS wynik FROM tabela ORDER BY wynik ASC
Stef@n
Dzięki działa smile.gif
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.