sql 学习记录之:查询最早提交的记录信息

2023-10-25 01:59

本文主要是介绍sql 学习记录之:查询最早提交的记录信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义:表 tbl_a 有字段 col_id 主键、col_order_id 订单号、col_creator 创建人、col_created_time 创建时间(表结构与数据附文尾)
现有一需求,查询同一个订单号,最早提交的人员
首先,我们要的结果是 d1001 张三,d1002 赵云
在这里插入图片描述
可能这这个时候有小伙伴就会想到了:

select col_order_id,col_creatorfrom ( select * from  tbl_a  order by col_order_id,col_created_time ) m
group by col_order_id

这个咋一看好像没有什么问题,但是实际上有问题的
在这里插入图片描述
原因是:group by 的结果并不是取第一条数据而是随机的
这个时候,有的小伙伴又有想法了:我们可以先找出每个订单号最早的时间,再根据时间和订单号确定具体的人员,sql 如下:

select t.col_order_id,t.col_creator from tbl_a t 
inner join (select col_order_id,min(col_created_time) as col_created_time from tbl_a group by col_order_id) m
on m.col_order_id = t.col_order_id and m.col_created_time  = t.col_created_time

在这里插入图片描述
这个想法思路是对的,结果也是没问题的,但是呢但记录表数据很大的时候,性能上就会相对差一点,因为这条 sql 需要遍历两次 tbl_a 表,那有没有遍历一次就可以取得我们想要的数据的sql呢

当然也是有的,思路呢和本文第一个sql一样,也是先排序,再取值,不过呢,不是将全部排序,而是将某个字段排序,具体sql如下:

select col_order_id,SUBSTRING_INDEX(GROUP_CONCAT(col_creator order by col_created_time),',',1) 
from tbl_a group by col_order_id

在这里插入图片描述

这边用到了两个函数:
1、GROUP_CONCAT,聚合函数,与group by 合用,用于拼接字段值或者文本
2、SUBSTRING_INDEX,字符串函数,用于截取字符串

表结构与数据:

CREATE TABLE `tbl_a`  (`col_id` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL,`col_order_id` varchar(64) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL,`col_creator` varchar(64) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL,`col_created_time` datetime(0) NULL DEFAULT NULL,PRIMARY KEY (`col_id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_bin ROW_FORMAT = Dynamic;INSERT INTO `tbl_a`(`col_id`, `col_order_id`, `col_creator`, `col_created_time`) VALUES ('1001', 'd1001', '张三', '2022-07-15 16:43:54');
INSERT INTO `tbl_a`(`col_id`, `col_order_id`, `col_creator`, `col_created_time`) VALUES ('1002', 'd1001', '李四', '2022-07-16 16:44:51');
INSERT INTO `tbl_a`(`col_id`, `col_order_id`, `col_creator`, `col_created_time`) VALUES ('1003', 'd1001', '王五', '2022-07-17 16:45:42');
INSERT INTO `tbl_a`(`col_id`, `col_order_id`, `col_creator`, `col_created_time`) VALUES ('1004', 'd1002', '诸葛', '2022-07-18 16:43:54');
INSERT INTO `tbl_a`(`col_id`, `col_order_id`, `col_creator`, `col_created_time`) VALUES ('1005', 'd1002', '赵云', '2022-07-16 16:44:51');
INSERT INTO `tbl_a`(`col_id`, `col_order_id`, `col_creator`, `col_created_time`) VALUES ('1006', 'd1002', '曹操', '2022-07-17 16:45:42');

这篇关于sql 学习记录之:查询最早提交的记录信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/279280

相关文章

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt