我需要对结果进行排序,以便首先出现状态列为特定值的所有项目,然后按日期出现。
我试过这个:
SELECT Id, Status, CreatedAt FROM Table
ORDER BY (Status=1) DESC, CreatedAt
我想我会在 (Status=1) 上得到一个布尔值,所以按 DESC 排序以将真 (1) 值放在顶部。
但我收到语法错误。这可能吗?如果可以,正确的语法是什么?
谢谢!
我需要对结果进行排序,以便首先出现状态列为特定值的所有项目,然后按日期出现。
我试过这个:
SELECT Id, Status, CreatedAt FROM Table
ORDER BY (Status=1) DESC, CreatedAt
我想我会在 (Status=1) 上得到一个布尔值,所以按 DESC 排序以将真 (1) 值放在顶部。
但我收到语法错误。这可能吗?如果可以,正确的语法是什么?
谢谢!
您也可以CASE
在ORDER BY
:
SELECT Id, Status, CreatedAt
FROM Table
ORDER BY
CASE WHEN Status = 1 THEN 0 ELSE 1 END ASC,
CreatedAt ASC
尝试这个
SELECT Id, Status, CreatedAt FROM Table
ORDER BY (case when Status=1 then 1 else 2 end), CreatedAt