如何解决SQL Server:从另一个CTE查询获取DISTINCT TOP列表
我有以下查询
WITH Recent_BankAccountNumber_CTE (BankAccountNumber,TransactionId) AS
(
SELECT TOP 25 BankAccountNumber,TransactionId
FROM [Transaction]
WHERE CustomerId = 1234
ORDER BY TransactionId DESC
)
SELECT
BankAccountNumber,TransactionId
FROM
Recent_BankAccountNumber_CTE
ORDER BY
OutboundTransactionId DESC
我得到以下输出:
BankAccountNumber OutboundTransactionId
------------------------------------------
8002950781 32078
8002950781 32077
8002950781 32076
016200270000486 32075
121054658698 32074
035200146349621 32073
200300019256 32072
200300019256 32071
200300019256 32070
200300019256 31088
018021030517 31087
102957612131 31086
100336018793 31085
100336018793 31084
042033430297001 31083
042033430297001 31082
100336018793 31081
8004062604 31080
102957612131 31079
042033430297001 31078
121054658698 31077
111353490614 31076
121054658698 31075
82455039 31074
110854031395 31073
我追求的是
我会尽快(而不是以上)
SELECT DISTINCT TOP 10 (BankAccountNumber)
FROM Recent_BankAccountNumber_CTE
我进入下面,这是不正确的
BankAccountNumber
-----------------
016200270000486
018021030517
035200146349621
042033430297001
100336018793
102957612131
110854031395
111353490614
121054658698
200300019256
有人可以让我知道DISTINCT TOP 10
怎么了吗?
解决方法
“前10名”组件通常需要排序。在您的情况下,它没有它们,因此(显然)正在按字母顺序排序(因此先是0,然后是1,然后是2)。
因此,您需要一个值才能从CTE中进行排序。 一种方法是在CTE中使用我们可以为此使用TransactionId。然后,我们需要将DISTINCT更改为GROUP BY,以便我们可以对该TransactionId的MAX()进行排序(这样我们就可以获取最近访问的帐户)ROW_NUMBER()
。
WITH Recent_BankAccountNumber_CTE (BankAccountNumber,TransactionId) AS (
SELECT TOP 25 BankAccountNumber,TransactionId
FROM [Transaction]
WHERE CustomerId = 1234
ORDER BY TransactionId desc)
SELECT TOP 10 BankAccountNumber
FROM Recent_BankAccountNumber_CTE
GROUP BY BankAccountNumber
ORDER BY MAX(TransactionId) DESC;
这是db<>fiddle的原始版本和答案的更新-请注意,我必须做一些调整才能将数据用作CTE。
tl; dr版本:您需要对其中进行排序以获得最新的事务-在这种情况下为MAX(TransactionID) DESC
。但是,您需要将DISTINCT
的方法更改为GROUP BY
,因为MAX()部分不适用于DISTINCT。
更新:没有CTE的版本
请注意,可以简化上述操作,而无需CTE。不过,我假设CTE可能比此问题中的最低版本宽,并且CTE相对清楚地说明了正在发生的事情,并且只要您在transaction.CustomerId
上有一个索引,性能就可能很好(实际上,其性能可能会优于以下版本。
但是,如果需要的话,您应该可以使用类似的方法
SELECT TOP 10 BankAccountNumber
FROM [Transaction]
WHERE CustomerId = 1234
GROUP BY BankAccountNumber
ORDER BY MAX(TransactionId) DESC;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。