MPP库使用row_number()取值错误问题

问题

MPP库使用row_number() 进行排序后,取指定序号值时,是随机取值了,并没有取指定序号的数据

with t1 as(
	select 
        row_number() over(partition by pid order by create_time desc) as num, * 
    from t3
)
select * from t1 where num = 1

原因

暂时还没了解,如果有哪位好心的大佬知道可以评论一下。

解决办法

使用group by 的方式把需要的字段全部取出,之后再取指定序号的数据,如下示例:

with t1 as(
	select 
        row_number() over(partition by pid order by create_time desc) as num, id, pid, create_time, update_time 
    from t3
    group by id, pid, create_time, update_time
)
select * from t1 where num = 1

如果有哪位好心的大佬知道还有其它方法可以评论一下,让更多人知道。

作者:假装空白
欢迎任何形式的转载,但请务必注明出处。
限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。

posted @   假装空白  阅读(18)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
历史上的今天:
2022-08-15 HTML 引用 tracking.js 调取摄像头取人脸 Demo
点击右上角即可分享
微信分享提示