mysql-利润set变量模拟分组查询每组中的第N条数据

本文探讨了在MySQL中如何高效地对数据进行分组并选取每个分组的第N条记录,对比了传统方法与使用set变量的性能差异,通过实例展示了10万数据量下的优化效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

查询思路:

很多时候想在使用group by时想查询group by的每一组中的第N条数据,而取这些数据时往往按如下方式去执行则很慢

SELECT  *  FROM  test main  WHERE  (SELECT COUNT(1)   FROM test sub   WHERE      main.uid = sub.uid     AND main.gid > sub.gid  ) < 3;

按如上方式,对于数据10000左右的表就已经很吃不消。

或已拼接结构的方式

SELECT t.a,t.b
,substring_index( group_concat( IFNULL(t.c,
0)ORDER BY t.itime DESC ), ",", 3 ) c
,substring_index( group_concat( t.itime
ORDER BY t.itime DESC ),",", 3) time  
FROM t t GROUP BY t.a ,t.b;

等等这些单存对sql来说并不是想要的方案,效率太慢,

如下,是借用mysql的set变量来处理,10w的数据效率还不错,就贴出来了。

在如下结果集中

 标记好的结果

sql语句(为取其中的某一类型)

set @rowNO = 0;-- 定义序列变量
set @codeTemp = '';-- 定义每组区别变量
select * from (
select 
i.* ,-- 字段值
if(@codeTemp=stockCode,@rowNO := @rowNo+1,@rowNO := 0) AS rowno,-- 赋值序列
@codeTemp:=stockCode as stockCode1 -- 赋值区别
from (
select i.stockCode,i.endDate,i.JingLiRun  from income_statements i WHERE i.endDate like '%-12-31' order by stockCode,i.endDate desc -- 可自定义的临时表数据
) i 
) i where i.rowno = 1 -- 取每组第N条

如有更好的欢迎分享

 

转载于:https://www.cnblogs.com/hwaggLee/p/5395201.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值