登录
首页 >  数据库 >  MySQL

groupBy和orderBy的替代方案

来源:SegmentFault

时间:2023-02-24 19:58:10 147浏览 收藏

你在学习数据库相关的知识吗?本文《groupBy和orderBy的替代方案》,主要介绍的内容就涉及到MySQL、PHP、laravel,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

一、背景

相关的设备状态数据

在开发的时候遇到一个需求,需要根据device_code将数据分组,同时获得每组数据中最新的一条数据。

二、遇到的问题

2.1 最初的思路:先对数据进行orderBy 再进行groupBy

 sql语句:
 sql: SELECT * from y_device_events ORDER BY created_at DESC GROUP BY device_code

结果: 这种写法会报错,当groupBy和orderBy组合使用的时候,必须要先进性groupBy在进行orderBy。

2.2 进阶思路:对数据进行orderBy的结果作为临时表,再对临时表分组

 sql语:
 sql:SELECT * from (SELECT * from y_device_events ORDER BY created_at DESC) as new_table GROUP BY new_table.device_code 

结果:这条语句执行了,但是结果并没有按照预期的将最新的一条筛选出来

三、最终的解决方案

3.1 初级方案

通过之前两种方案发现直接使用orderBy和groupBy并不能达到目的,最后觉得可以和自身作关联查询,通过关联查询进行筛选。

SELECT
`y_device_events`.*
FROM
`y_device_events`
LEFT JOIN `y_device_events` AS `new_table` ON `y_device_events`.`device_code` = 
`new_table`.`device_code`
AND `y_device_events`.`created_at` 

这种方法通过左关联查询,对笛卡尔积进行了筛选,就可以达到我们的目的。

3.2 缺点:对于数据量特别大的情况,如果没有限制条件,得到的笛卡尔积会很大,所以查询速度较慢。
3.3 最终的写法

我的需求中可以加上对type及sub_type的限制,因此稍微可以加快一下数据的筛选,而且如果有数据筛选条件,可以将条件放入JOIN语句里面,而不是join完成的where里

 SELECT
  `y_device_events`.*
FROM
  `y_device_events`
LEFT JOIN `y_device_events` AS `new_table` ON `y_device_events`.`device_code` = 
`new_table`.`device_code`
AND `y_device_events`.`created_at`  '2018 - 07 - 05 10 : 07 : 27'
AND `y_device_events`.`created_at` 

加入筛选条件后,可以大大加快查询的效率。

理论要掌握,实操不能落!以上关于《groupBy和orderBy的替代方案》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>