Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mysql row_number函数

mysql数据库row_number函数举例介绍

作者:是个粽子

在MySQL中ROW_NUMBER()是一种用来生成行号的功能函数,通常情况下它用于对查询结果进行编号,以便方便地查看每行的位置,下面这篇文章主要给大家介绍了关于mysql数据库row_number函数举例介绍的相关资料,需要的朋友可以参考下

1.语法

#将字段按照COLUMN1分组COLUMN2排序后分配一个从1开始升序的编号

SELECT *, ROW_NUMBER() OVER(PARTITION BY COLUMN1 ORDER BY COLUMN2 ) AS NUM FROM TABLE;

2.举例

1.将商品表中的价格按升序排序并编号

SELECT goods_price,goods_user_id,ROW_NUMBER() over(ORDER BY goods_price) as num  FROM  goods

运行结果:

结果新增了一列来标记行号

2.将商品按用户分组后价格降序并编号

SELECT goods_price,goods_user_id,ROW_NUMBER() over(PARTITION BY goods_user_id ORDER BY goods_price desc) as num FROM goods

运行结果:

结果会按每一个用户进行分区,按价格降序排序后,按顺序编号。

3.将商品按用户分组后价格降序并编号且只查询编号为1的记录

SELECT * FROM 
(SELECT goods_price,goods_user_id,ROW_NUMBER() over(PARTITION By goods_user_id ORDER BY goods_price desc) as num FROM  goods) as a  
WHERE a.num=1

运行结果:

可以看到在上述基础上过滤出了编号为1的记录。

3.更复杂的示例:

下面是一个稍微复杂一些的示例,我们可以使用ROW_NUMBER()函数为每个部门的员工按工资进行排名。我们需要将salary结果分组到每个department_id中,然后根据salary降序排序。以下是我们的示例代码:

SELECT row_no, department_id, first_name, last_name, salary
FROM (
   SELECT department_id, first_name, last_name, salary,
ROW_NUMBER() OVER (PARTITION BY department_id ORDER BY salary DESC) as row_no
FROM employee) t
WHERE row_no <= 5;

该查询使用了子查询,首先它将需要的列投射到ROW_NUMBER() OVER(PARTITION BY department_id ORDER BY salary DESC)中,其中PARTITION BY department_id的作用是将结果按部门分组,而ORDER BY salary DESC则按工资降序排列。最后,我们只取每个部门及其前5名员工。

我们可以看到,ROW_NUMBER()函数对于数据分析非常有用,可以帮助我们完成许多复杂的任务。

总结

到此这篇关于mysql数据库row_number函数的文章就介绍到这了,更多相关mysql row_number函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文