4

我需要对结果进行排序,以便首先出现状态列为特定值的所有项目,然后按日期出现。

我试过这个:

SELECT Id, Status, CreatedAt FROM Table
ORDER BY (Status=1) DESC, CreatedAt

我想我会在 (Status=1) 上得到一个布尔值,所以按 DESC 排序以将真 (1) 值放在顶部。

但我收到语法错误。这可能吗?如果可以,正确的语法是什么?

谢谢!

4

2 回答 2

13

您也可以CASEORDER BY

SELECT Id, Status, CreatedAt 
FROM Table
ORDER BY 
   CASE WHEN Status = 1 THEN 0 ELSE 1 END ASC, 
   CreatedAt ASC
于 2013-03-26T13:55:04.150 回答
5

尝试这个

SELECT Id, Status, CreatedAt FROM Table
ORDER BY (case when Status=1 then 1 else 2 end), CreatedAt
于 2013-03-26T13:54:27.483 回答