如何在我的查询中添加组内的行号 [英] How to add a row number within a group in my query

查看:33
本文介绍了如何在我的查询中添加组内的行号的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我试过这个查询:

SELECT X,Y,Z,COUNT(*) 
FROM TABLE1 
GROUP BY X,Y,Z

我的结果是:

但我需要以下结果:

推荐答案

这应该可以解决问题:

SELECT X,Y,Z,ROW_NUMBER() OVER (PARTITION BY X,Y,Z ORDER BY X,Y,Z)
FROM TABLE1 

ROW_NUMBER() 将为组 X、Y、Z 中的每个值打勾,并在下一组重置.ORDER BY 子句用于定义它应该按什么顺序打勾,并且可以更改为您希望的任何方式.这是 Oracle 提供的分析功能之一,非常有用.

The ROW_NUMBER() will tick up for every value in the group X,Y,Z, and reset at a next group. The ORDER BY clause is used to define in what order it should tick up, and can be changed to however you wish. This is one of the analytical functions Oracle provides, and can be very useful.

这篇关于如何在我的查询中添加组内的行号的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆