日常开发当中,经常会遇到查询分组数据中最新的一条记录,比如统计当前系统每个人的最新登录记录、外卖系统统计所有买家最新的一次订单记录、图书管理系统借阅者最新借阅书籍的记录等等。今天给大家介绍一下如何实现以上场景的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分组取最新的一条记录相关推荐

  1. mysql 分组取最新的一条记录(整条记录)

    方法:mysql取分组后最新的一条记录,下面两种方法.一种是先筛选 出最大和最新的时间,在连表查询.一种是先排序,然后在次分组查询(默认第一条),就是最新的一条数据了 #select * from t ...

  2. 分组取最新的一条数据

    ##分组取最新的一条数据,错误 SELECTa.account_balance,a.deposit_amount,a.deposit_time,a.create_user,a.resident_id, ...

  3. MySQL分组查询最新的一条记录

    问题描述 使用关键字 group by,和order by,但是直接在查询语句后跟上group和order会失效 举例说明:table表中的每个code最新的一条数据 失效写法: SELECT t.` ...

  4. mysql左连接表要取最新的一条数据_MySQL的左连接查询,只取出最大的一条数据...

    今天有个需求,是通过两张表进行查询.一对多的关系.通过一个主键,取出其中的一条. 开始以为还好,直接用用了left join on进行查询.却发现了问题所在. 其他的好弄. 开始的写法借鉴这篇博客: ...

  5. MySQL之——GROUP BY分组取字段最大值

    转载自:http://blog.csdn.net/l1028386804/article/details/54657412 假设有一个业务场景,需要查询用户登录记录信息,其中表结构如下: [sql] ...

  6. group by分组取组内第一条

    正常情况下先将子查询进行排序,然后进行分组便可以取到组内的第一条数据 但是在mysql5.7之后需要在子查询排序的时候加一个limit 举个例子 student表 SELECT * FROM stud ...

  7. Sql group by 分组取时间最新的一条数据

    1.取时间最新的记录 不分组有重复(多条CreateTime一样的都是最新记录) select * from test t where pid in (select PId from Test twh ...

  8. SQL左连接副表取最新的一条记录的多中方式

    1.直接left join 取max,次sql在oracle中报错,a-column-may-not-be-outer-joined-to-a-subquery 原因分析:Oracle 不支持 在 j ...

  9. 分组查询最新的一条记录

    SELECT* FROMtable WHEREid IN (SELECTSUBSTRING_INDEX(GROUP_CONCAT(idORDER BYrecord_date DESC,id DESC) ...

最新文章

  1. Servlet入门 代码
  2. python爬取百度文库付费文档_亲测免费转换百度文库付费文件
  3. CentOS下crash分析内核kdump文件方法
  4. Module.h 网狐的“com”工具箱
  5. Node.js 开发者 2020 年度报告
  6. 不可上位!数据结构队列,老实排队,Java实现数组模拟队列及可复用环形队列
  7. MSSQL-字符串分离与列记录合并成一行混合使用
  8. python爬去朋友圈_python爬虫24 | 搞事情了,用 Appium 爬取你的微信朋友圈。
  9. 用newlisp管理windows下的nginx
  10. OpenJudge计算概论-字符串最大跨距
  11. 选项不属于HTML语言特点,Web前端开发初级模拟测试卷一(2)
  12. 累计独立访客(UV)不低于 1000是什么意思?如何查看自己小程序的UV数量?
  13. 第七章:Java基础数据类型-整数类型
  14. ERNIE-Gram: Pre-Training with Explicitly N-Gram Masked Language Modeling for Natural ...(2020-10-23)
  15. Android 摄像头拍照显示 相册显示 图片裁剪绘制显示
  16. 苹果电脑装 WIN7 黑屏问题解决办法
  17. 我们为什么生病:达尔文医学的新观念
  18. 原学而思培优、智联招聘CTO李京峰加盟T3出行
  19. 云数据中心安全设计要点
  20. 如何分享10亿月活红利?揭秘拥抱小程序电商的正确姿势

热门文章

  1. C++面向对象类的实例题目一
  2. SQL里的SWITCH分支语句
  3. 手机支付:电信运营商会被边缘化吗?!
  4. 网络摄象机常用传输协议
  5. AA级与AAA级台灯 重要指标对比
  6. Optical-Flow光流halcon算子,持续更新
  7. 【python数字信号处理】——Z变换
  8. mysql取得列类型_Mysql列类型
  9. python win+r时不成功_Win与R(不使用Anaconda的情况下)
  10. Nginx多种负载均衡策略搭建