MYSQL学习:GROUP BY分组取最新的一条记录
日常开发当中,经常会遇到查询分组数据中最新的一条记录,比如统计当前系统每个人的最新登录记录、外卖系统统计所有买家最新的一次订单记录、图书管理系统借阅者最新借阅书籍的记录等等。今天给大家介绍一下如何实现以上场景的SQL写法,希望对大家能有所帮助!
1、初始化数据表
-- 借阅者表
CREATE TABLE `userinfo` (`uid` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`uname` varchar(20) NOT NULL COMMENT '姓名',`uage` int(11) NOT NULL COMMENT '年龄',PRIMARY KEY (`uid`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT;
INSERT INTO `userinfo` VALUES (1, '小明', 20);
INSERT INTO `userinfo` VALUES (2, '小张', 30);
INSERT INTO `userinfo` VALUES (3, '小李', 28);
-- 书籍表
CREATE TABLE `bookinfo` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`book_no` varchar(20) NOT NULL COMMENT '书籍编号',`book_name` varchar(20) NOT NULL COMMENT '书籍名称',PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT;
INSERT INTO `bookinfo` VALUES (1, 'ISBN001', '计算机基础');
INSERT INTO `bookinfo` VALUES (2, 'ISBN002', '计算机网络');
INSERT INTO `bookinfo` VALUES (3, 'ISBN003', '高等数学');
INSERT INTO `bookinfo` VALUES (4, 'ISBN004', '明朝那些事');
INSERT INTO `bookinfo` VALUES (5, 'ISBN005', '物理');
INSERT INTO `bookinfo` VALUES (13, 'ISBN006', '读者');
-- 借阅记录表
CREATE TABLE `borrow_record` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',`user_id` int(11) NOT NULL COMMENT '用户id',`book_id` int(11) NOT NULL COMMENT '书籍id',`borrowtime` datetime NOT NULL COMMENT '书籍id',PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT;
INSERT INTO `borrow_record` VALUES (8, 1, 2, '2021-05-01 10:52:00');
INSERT INTO `borrow_record` VALUES (9, 2, 4, '2021-07-12 23:32:00');
INSERT INTO `borrow_record` VALUES (10, 2, 1, '2021-03-21 09:00:00');
INSERT INTO `borrow_record` VALUES (11, 1, 3, '2021-08-11 17:39:00');
INSERT INTO `borrow_record` VALUES (12, 1, 5, '2021-09-02 18:12:00');
INSERT INTO `borrow_record` VALUES (13, 3, 1, '2021-07-06 12:32:00');
INSERT INTO `borrow_record` VALUES (14, 2, 1, '2021-08-09 10:10:00');
INSERT INTO `borrow_record` VALUES (15, 4, 3, '2021-04-15 19:45:00'
);
写法1 直接group by 根据userid ,使用聚合函数max取得最近的浏览时间
select a.user_id ,max(c.uname) uname
,max(a.borrowtime) borrowtime,max(b.book_name) book_name
from borrow_record a
INNER JOIN bookinfo b on b.id=a.book_id
INNER JOIN userinfo c on c.uid=a.user_id
GROUP BY a.user_id
-- 说明: 这样会存在获取书籍名称错乱的情况,
-- 因为使用聚合函数获取的书籍名称,不一定是对应用户
-- 最新浏览记录对应的书籍名称
写法2 采用子查询的方式,获取借阅记录表最近的浏览时间作为查询条件
select a.user_id ,c.uname,a.borrowtime
,b.book_name book_namefrom borrow_record a
INNER JOIN bookinfo b on b.id=a.book_id
INNER JOIN userinfo c on c.uid=a.user_id
where a.borrowtime=(select max(borrowtime)
from borrow_record t where t.user_id=a.user_id)
-- 说明:可以满足查询效果,不过性能不是最优解
写法3 采用group by + join 性能最高,推荐采用
select a.user_id ,c.uname,a.borrowtime
,b.book_name book_namefrom (
select t.user_id,max(borrowtime) borrowtime
from borrow_record t GROUP BY t.user_id) as e INNER JOIN borrow_record a on e.user_id=a.user_id
and e.borrowtime=a.borrowtimeINNER
JOIN bookinfo b on b.id=a.book_id
INNER JOIN userinfo c on c.uid=a.user_id
运行效果如下:
IT技术分享社区
个人博客网站:https://programmerblog.xyz
文章推荐程序员效率:画流程图常用的工具程序员效率:整理常用的在线笔记软件远程办公:常用的远程协助软件,你都知道吗?51单片机程序下载、ISP及串口基础知识硬件:断路器、接触器、继电器基础知识
MYSQL学习:GROUP BY分组取最新的一条记录相关推荐
- mysql 分组取最新的一条记录(整条记录)
方法:mysql取分组后最新的一条记录,下面两种方法.一种是先筛选 出最大和最新的时间,在连表查询.一种是先排序,然后在次分组查询(默认第一条),就是最新的一条数据了 #select * from t ...
- 分组取最新的一条数据
##分组取最新的一条数据,错误 SELECTa.account_balance,a.deposit_amount,a.deposit_time,a.create_user,a.resident_id, ...
- MySQL分组查询最新的一条记录
问题描述 使用关键字 group by,和order by,但是直接在查询语句后跟上group和order会失效 举例说明:table表中的每个code最新的一条数据 失效写法: SELECT t.` ...
- mysql左连接表要取最新的一条数据_MySQL的左连接查询,只取出最大的一条数据...
今天有个需求,是通过两张表进行查询.一对多的关系.通过一个主键,取出其中的一条. 开始以为还好,直接用用了left join on进行查询.却发现了问题所在. 其他的好弄. 开始的写法借鉴这篇博客: ...
- MySQL之——GROUP BY分组取字段最大值
转载自:http://blog.csdn.net/l1028386804/article/details/54657412 假设有一个业务场景,需要查询用户登录记录信息,其中表结构如下: [sql] ...
- group by分组取组内第一条
正常情况下先将子查询进行排序,然后进行分组便可以取到组内的第一条数据 但是在mysql5.7之后需要在子查询排序的时候加一个limit 举个例子 student表 SELECT * FROM stud ...
- Sql group by 分组取时间最新的一条数据
1.取时间最新的记录 不分组有重复(多条CreateTime一样的都是最新记录) select * from test t where pid in (select PId from Test twh ...
- SQL左连接副表取最新的一条记录的多中方式
1.直接left join 取max,次sql在oracle中报错,a-column-may-not-be-outer-joined-to-a-subquery 原因分析:Oracle 不支持 在 j ...
- 分组查询最新的一条记录
SELECT* FROMtable WHEREid IN (SELECTSUBSTRING_INDEX(GROUP_CONCAT(idORDER BYrecord_date DESC,id DESC) ...
最新文章
- Servlet入门 代码
- python爬取百度文库付费文档_亲测免费转换百度文库付费文件
- CentOS下crash分析内核kdump文件方法
- Module.h 网狐的“com”工具箱
- Node.js 开发者 2020 年度报告
- 不可上位!数据结构队列,老实排队,Java实现数组模拟队列及可复用环形队列
- MSSQL-字符串分离与列记录合并成一行混合使用
- python爬去朋友圈_python爬虫24 | 搞事情了,用 Appium 爬取你的微信朋友圈。
- 用newlisp管理windows下的nginx
- OpenJudge计算概论-字符串最大跨距
- 选项不属于HTML语言特点,Web前端开发初级模拟测试卷一(2)
- 累计独立访客(UV)不低于 1000是什么意思?如何查看自己小程序的UV数量?
- 第七章:Java基础数据类型-整数类型
- ERNIE-Gram: Pre-Training with Explicitly N-Gram Masked Language Modeling for Natural ...(2020-10-23)
- Android 摄像头拍照显示 相册显示 图片裁剪绘制显示
- 苹果电脑装 WIN7 黑屏问题解决办法
- 我们为什么生病:达尔文医学的新观念
- 原学而思培优、智联招聘CTO李京峰加盟T3出行
- 云数据中心安全设计要点
- 如何分享10亿月活红利?揭秘拥抱小程序电商的正确姿势