Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [mysql] sortowanie po dwóch kolumnach jednocześnie
Forum PHP.pl > Forum > Bazy danych > MySQL
zdzichu
Witajcie.
Borykam się z takim problemem - mam dwie kolumny w tabeli - created_at i updated_at - obie zawierają datetime odpowiednio stworzenia i edytowania rekordu. Początkowo updated_at ma wartość null - dopiero po edycji przyjmuje aktualną wartość. Chciałbym posortować dane od najnowszego do najstarszego jednocześnie po tych dwóch kolumnach - tylko nie bardzo wiem jak - jedyne co mi przychodzi do głowy, to instrukcja warunkowa wybierająca "starszą" kolumnę,przypisywanie do nowej, tymczasowej i sortowanie po tej kolumnie - ale myślę, że jest jakiś inny, prostszy sposób.
Z góry dzięki za podpowiedzi
JoShiMa
Może napisz jak próbowałeś.
zdzichu
tak naprawdę jeszcze nie próbowałem - jedyne rozwiązanie, które wydaje mi się, że powinno działać wydaje mi się rozwiązaniem strasznie na około, a ja lubię eleganckie rozwiązania.
W każdym razie, jak nikt nic nie poradzi, zrobię coś takiego(nie testowałem do końca czy to działa, piszę na oko)
[code=sql]
SELECT *,CASE updated_at
WHEN updated_at IS NULL THEN 'created_at'
ELSE 'updated_at'
END AS ord
FROM table ORDER BY ord [/code]
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.