SQL Server:从另一个CTE查询获取DISTINCT TOP列表

如何解决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

我追求的是

enter image description here

我会尽快(而不是以上)

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中使用ROW_NUMBER()我们可以为此使用TransactionId。然后,我们需要将DISTINCT更改为GROUP BY,以便我们可以对该TransactionId的MAX()进行排序(这样我们就可以获取最近访问的帐户)

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 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-