mysql分组排序并取每组的前1条记录

实际开发中会遇到使用mysql分组统计,并且要求取每组数据的前1条数据

如下:需要根据模块分组,取每组中的前1条优质供应商数据,取前几条数据,其实会用到上篇文章中的排名函数**row_number() 函数**来实现,其含义可以点击此函数跳转查看上篇文章

sql 复制代码
select supplier_company_name,Logo,ModuleType, row_num 
FROM(
select sr.supplier_company_name,bc.Logo,ss.ModuleType,
ROW_NUMBER() OVER (PARTITION BY ss.ModuleType ORDER BY sr.recommendation_order DESC) row_num 
from supd_supply_recommend sr
INNER JOIN base_companyinfo bc ON sr.user_id=bc.UserId 
INNER JOIN supd_supply_info ss on sr.user_id=ss.CreatorId AND ss.IsDeleted=0
-- WHERE ss.ModuleType='22'
WHERE sr.`Status`='Show' 
GROUP BY ss.ModuleType,ss.CreatorId
) as t

WHERE row_num <2

注意:逻辑就是先使用PARTITION BY根据模块类型ss.ModuleType分区(即分组,把相同的内容分成一组)、

根据推荐序号sr.recommendation_order排名(把PARTITION BY分区的一组数据根据某个字段进行排名),

最后根据模块类型和供应商用户id分组查询(GROUP BY ss.ModuleType,ss.CreatorId)--这个理在使用GROUP BY是为了过滤一些重复的内容,比如:上面语句去掉GROUP BY ss.ModuleType,ss.CreatorId

sql 复制代码
select sr.supplier_company_name,bc.Logo,ss.ModuleType,
ROW_NUMBER() OVER (PARTITION BY ss.ModuleType ORDER BY sr.recommendation_order DESC) row_num 
from supd_supply_recommend sr
INNER JOIN base_companyinfo bc ON sr.user_id=bc.UserId 
INNER JOIN supd_supply_info ss on sr.user_id=ss.CreatorId AND ss.IsDeleted=0
-- WHERE ss.ModuleType='22'
WHERE sr.`Status`='Show' 

其结果如下:

同意模块ModuleType=00000000-0000-0000-0000-000000000000的同一分区下 出现了10条重复的中船海为高科技有限公司供应商,这里我的逻辑其实是要同一分区下,不同供应商进行排名,

即只显示分区ModuleType=00000000-0000-0000-0000-000000000000下的艾克斯有限公司和中船海为高科技有限公司的排名,所以加上GROUP BY ss.ModuleType,ss.CreatorId来过滤重复数据。

row_num<2 就是取排名中小于第二名的数据,也就是前1条数据,如果你的实际需求也是取前一条最好写成row_num=1;我这里需求是前10条,只不过为了演示给大家,所以写成取前1条了

结果如下:未取前1条数据前的查询结果

取前一条记录的查询结果

如上取出每个模块分区(ModuleType)下的第一条数据

相关推荐
CryptoRzz26 分钟前
欧美(美股、加拿大股票、墨西哥股票)股票数据接口文档
java·服务器·开发语言·数据库·区块链
APItesterCris1 小时前
构建弹性数据管道:利用淘宝商品 API 进行流式数据采集与处理
linux·数据库·windows
九河云1 小时前
TOS + 数字孪生:集装箱码头的智能进化密码
大数据·服务器·网络·数据库·数字化转型
手握风云-2 小时前
MySQL数据库精研之旅第十九期:存储过程,数据处理的全能工具箱(二)
数据库·mysql
孟意昶2 小时前
Doris专题17- 数据导入-文件格式
大数据·数据库·分布式·sql·doris
你可以永远相信功夫熊猫2 小时前
金蝶云·星瀚 | 生产制造成本核算终极实操手册(从0到1,含两套完整案例)
数据库·erp
Thepatterraining2 小时前
MySQL零基础教程:DDL/DCL/DML详解,从建库到存储过程一篇搞定!
数据库·sql·mysql
想ai抽2 小时前
深入starrocks-怎样实现多列联合统计信息
java·数据库·数据仓库
jackletter2 小时前
待补充 五大关系数据库(sqlserver、mysql、oracle、pgsql、sqlite)的列类型:目录
mysql·oracle·sqlserver·sqlite·pgsql·列类型
Y4090013 小时前
MySQL中的“事务”
数据库·mysql