sql 分页查询 order by和group by一起使用导致排序失效问题解决

背景:在查询数据库数据的时候,很多时候我们需要用到group by来进行分组,同时使用order by进行排序,但是当两个同时使用时稍不注意就会出现问题。我在进行公司项目开发时就出现了问题:通过分页查询对查询的数据进行分组,通过聚合函数对分组数据处理,然后排序返回到前端显示,后面发现前端分页的数据会出现重复或丢失。分析判断应该是sql排序失效导致分页查询数据异常,后面查资料证实了这一点。

1. GROUP BY 和 ORDER BY 的作用:

GROUP BY:group by用于借助诸如 COUNT()、AVG()、MIN() 和 MAX() 之类的聚合函数将数据分组。它的工作方式是,如果特定的列在不同的行中具有相同的值,它会将这些行合并为一组。

ORDER BY:order by从英文里理解就是行的排序方式,默认的为升序。 order by 后面必须列出排序的字段名,可以是多个字段名。asc升序、desc降序

2.注意事项:

1. 在使用group by的语句中,select字段只能用于分类的列(表达式),或聚合函数。where条件用于group by之前,having用于group by 之后对结果进行筛选。

2. order by 的字段,必须包含group by 子句里的全部字段,否则排序失效(重要)

3. 结果演示 

1. 这是我之前出问题的sql,直接使用group by和order by分页查询数据

SELECT
	sd.detail_id,
	sd.detail_no,
	sd.buyer,
	sd.create_by,
	sd.create_time,
	dp.product_name,
	dp.unit 
FROM
	t_daily_subscribe sd
	LEFT JOIN t_daily_product dp ON sd.product_id = dp.product_id 
WHERE
	sd.del_flag = 0 
	AND state IN ( 600 ) 
	AND sd.active = TRUE 
GROUP BY
	sd.detail_id 
ORDER BY
	sd.create_time DESC
	LIMIT 0,10

limit分页(0,10)查询结果如下:

 limit分页(10,10)查询结果如下:

 发现查出数据会有重复数据甚至数据丢失,说明sql的排序没有生效,导致每次查出来的数据不一致,自然再分页肯定会出问题

2. 将sql修改为下面就没问题了,order by字段必须包含group by的字段,排序就能正常工作

SELECT
	sd.detail_id,
	sd.detail_no,
	sd.buyer,
	sd.create_by,
	sd.create_time,
	dp.product_name,
	dp.unit 
FROM
	t_daily_subscribe sd
	LEFT JOIN t_daily_product dp ON sd.product_id = dp.product_id 
WHERE
	sd.del_flag = 0 
	AND state IN ( 600 ) 
	AND sd.active = TRUE 
GROUP BY
	sd.detail_id 
ORDER BY
	sd.create_time DESC, sd.detail_id
	LIMIT 0,10

sql语句为项目代码不便展示就做了一些删除,能明白文章的大致意思就行

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
SQL分页指令中包含了ORDER BY排序指令,可以按照指定的排序方式对数据进行排序。但是在某些情况下,我们会发现很奇怪的事情:ORDER BY排序指令失效了。下面详细介绍一些可能导致SQL分页ORDER BY失效的原因和解决方案。 原因一:使用关联查询 一些情况下,我们需要使用关联查询,这种情况下,如果没有正确指定ORDER BY排序方式,分页查询结果可能会不正确。这是由于关联查询时,可能会发生复杂的排序,使得原本按照单个字段排序的结果失效解决方案一:在分页指令中正确指定排序方式 在使用分页查询指令时,需要指定排序方式,以确保结果正确。通常情况下,我们可以按照某个字段进行排序,再进行分页查询。 原因二:查询条件过多 有些情况下,我们在查询时可能会指定过多的查询条件,这可能会导致SQL查询优化器无法正确地优化查询,进而导致ORDER BY排序失效解决方案二:优化查询条件 优化查询条件是解决此类问题的关键。我们需要明确具体的查询需求,在查询时尽量使用简洁的条件和正确的指令,以减少SQL优化器的工作量。 原因三:服务器负载过高 在某些情况下,服务器负载过高可能会导致SQL分页ORDER BY排序失效。当服务器负载较高时,可能会影响SQL查询引擎的响应速度,使得查询的返回结果不正确,包括ORDER BY排序失效解决方案三:优化服务器负载 为了避免服务器负载过高导致ORDER BY排序失效问题,我们需要优化服务器的性能。可以使用多台服务器进行负载均衡,调节服务器计算资源的使用,以提高服务器的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值