SQL中的自定义排序

时间:2014-08-28 15:37:02

标签: sql sql-server tsql sql-order-by ssms

我正在尝试使用ORDER BY语句在我的SQL查询中的CASE子句中实现“自定义”排序,但它给了我一些时髦的排序

到目前为止,这是我的ORDER BY条款:

编辑反映更新:

ORDER BY 
    CASE WHEN 
        CheckInStatus <> 'Cancelled' AND ArrivalTime is null AND GETDATE() > DATEADD(mi,30, CAST(StartDateTime AS DATETIME))THEN 1
    WHEN 
        CheckInStatus <> 'Cancelled' AND ArrivalTime is null AND GETDATE() <= DATEADD(mi,30, CAST(StartDateTime AS DATETIME)) THEN 2
    WHEN ArrivalTime is not null THEN 3
    WHEN CheckInStatus='Cancelled' THEN 4 
    ELSE 5
    END,
    StartDateTime, ScanTechName

我想要做的是按如下方式订购查询:

没有到达的人(以及谁的约会未被取消)和当前时间超过StartTime超过30分钟 - 这些人应该是第一个

未到达的人(以及谁的约会未被取消)和当前时间小于或等于StartTime之后的30分钟 - 这些人出现在第二位

接下来是签到的所有人

随后取消约会

最后是其他一切

所有内容都将按StartTime和Name

排序

问题似乎发生在2和3。这些家伙似乎混在一起,我认为这可能与我的AND有关,但我不知道如何解决它。

以下是我在搜索结果中遇到的错误 - 我已在CASE中加入了ORDER BY,以便直观地看到问题

编辑以包含结果:

Arrival Time            | CheckIn Status | StartDateTime           | OrderStatus
----------------------------------------------------------------------------------
2014-08-15 08:00:07.123 | Arrived        | 2014-08-15 07:15:00.000 | 3 
----------------------------------------------------------------------------------
2014-08-15 07:47:48.643 | Arrived        | 2014-08-15 07:30:00.000 | 2

所以发生了一些事情

  1. 由于我目前的GETDATE()是2014年8月28日 - 上面不应该有2个状态。因为它不小于或等于StartDate之后的30分钟
  2. 由于这本身就错了,所以可能导致第二个问题 - 因为它被标记为2,它应该出现在3之前而不是之后。

2 个答案:

答案 0 :(得分:3)

这部分情况似乎是导致问题的原因:

CAST(StartDateTime AS DATETIME) > DATEADD(mi,30, CAST(StartDateTime AS DATETIME))

[StartDateTime]永远不会比同一天加上30分钟更好!对你的第二个条件也是如此。

如果您没有解决问题,是否可以提供有关此查询结果的更多信息?

答案 1 :(得分:0)

这是一个简单的逻辑错误。您正在将“StartDateTime”与(“StartDateTime”+ 30分钟)进行比较,它将始终返回true。我猜你想要比较当前时间,这会使它看起来像这样:

ORDER BY 
CASE WHEN 
    CheckInStatus <> 'Cancelled' AND ArrivalTime is null AND getdate() > DATEADD(mi,30, CAST(StartDateTime AS DATETIME))THEN 1
WHEN 
    CheckInStatus <> 'Cancelled' AND ArrivalTime is null AND getdate() <= DATEADD(mi,30, CAST(StartDateTime AS DATETIME)) THEN 2
WHEN ArrivalTime is not null THEN 3
WHEN CheckInStatus='Cancelled' THEN 4 
ELSE 5
END,
StartDateTime, ScanTechName