gpt4 book ai didi

sql - 如何根据特殊情况选择数据?

转载 作者:行者123 更新时间:2023-12-02 08:48:24 25 4
gpt4 key购买 nike

说我有TABLE Audit,其中包含COLUMN ID、STATUS、TIME和示例数据,如下所示:

1. {ID = 1, STATUS = 'APPROVE', TIME = '2015-02-01'}
2. {ID = 1, STATUS = 'DECLINE', TIME = '2014-12-01'}
3. {ID = 1, STATUS = 'CLOSED', TIME = '2015-11-01'}
4. {ID = 2, STATUS = 'APPROVE', TIME = '2015-02-01'}
5. {ID = 3, STATUS = 'DECLINE', TIME = '2015-10-01'}
6. {ID = 4, STATUS = 'CLOSED', TIME = '2015-02-01'}

有一个条件:如果status='approve',则忽略status='decline',否则选择所有内容。

我可以知道如何构造一个查询以便只获取记录:1,3,4,5,6吗?

我当前的方法是首先检索带有 status='approve' 和 'lined' 的所有数据并将它们存储到 temptable 中,然后存储 status 的数据=“拒绝”且 ID 不在 @temptable 中,变为 @temptable。然后最终select * from @temptable

我想知道是否还有其他方法可以处理这种情况?

最佳答案

您可以使用窗口函数:

WITH cte AS
(
SELECT *
,[dec] = COUNT(CASE WHEN STATUS = 'DECLINE' THEN 1 END) OVER (PARTITION BY ID)
,[app] = COUNT(CASE WHEN STATUS = 'APPROVE' THEN 1 END) OVER (PARTITION BY ID)
FROM #Audit
)
SELECT ID, STATUS, [TIME]
FROM cte
WHERE NOT ([dec] >= 1 AND [app] >= 1 AND [STATUS] = 'DECLINE');

LiveDemo

您的列 TIME 可能会产生误导,尤其是当它仅包含日期时:)

关于sql - 如何根据特殊情况选择数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34064071/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com