当前位置: 首页 > news >正文

MySql 怎么查出符合条件的最新的数据行?

平时做业务,经常是需要查什么什么什么的最新的一条数据。

那至于最新这个概念, 对于产品来说,经常会说的是 时间顺序,最新也就是 最近的意思。
 

结合示例:


这是一张记录人员来访的记录表。
数据表里的数据准确记录了每个人来访时带的帽子颜色、时间、人员编码(每个人唯一)。

数据样例:


需要做到的是 :

拿出符合条件的最新的来访记录。

你会最怎么做? 

先实现一点的, 取出 A101 这个人员编码的 最新来访记录 。


首先先展示错误的sql示例: 想当然地使用max() 函数。


SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record WHERE user_code='A101' ; 

查询结果(错误的结果):



 

显然咋一看出来的数据有模有样,但是其实是错的。

为什么是错的的,可以稍微讲一下,既然评论区有人感兴趣了(欢迎兄弟们说出自己的看法)。

简单叙述, max是聚合函数, 我们的错误示例没配合group by 去使用, 这时候其实也就mysql这个家伙能让我们执行了,很多数据库都直接报错的。

那么执行是执行的,其实这时候mysql相当于把整个表当作了一个内容块去进行一个压缩检索。

我们加上了where 条件  user_code='A101',所以整个内容块确实过滤掉了其他不是user_code='A101' 的数据。

也就是说这种松懈执行的情况下,mysql保证max 返回(相关列) 的最大值, 其他列字段它是不保证的。 


 

正确的数据是 :


那是不是max(id) 用不了了?


正确用法(将符合条件的最大id值作为条件):


SELECT
 id,user_code,cap_color,create_time
FROM vist_record
WHERE id IN (SELECT MAX(id) AS id FROM vist_record WHERE user_code='A101' )
 

查询结果:

但是看到上面使用子查询的这种方式,

大家心里面肯定也已经在暗暗地骂娘, 拿个最新数据这么麻烦?

有没有简单一点的?


有。


比如说,我们已经确定了, id是自增的,id最大的数据(符合条件的数据) 就是最新的。


那么我们就可以使用倒序 DESC 来取最新数据:

DESC 也就是 倒序/降序 。

PS:

 使用倒序查找:

SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY id DESC
LIMIT 1;

查询结果: 

 或者根据时间倒序:

SELECT *
FROM vist_record
WHERE user_code='A101'
ORDER BY create_time DESC
LIMIT 1;

查询结果: 

就这么简单实现了吗? 

那么我们如果需求要的不是指定A101 要的是涉及到的每一个人的最新数据呢?

也就是存在多组的概念。 

每一类的符合条件的最新数据

橙色框就是 A101 、B202 、 C303 分别的最新记录 , 我们要取出来。

错误示例:
 

SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record   GROUP BY user_code

错误的筛选结果:


正确编码:
 

SELECT  id ,user_code,cap_color,create_time FROM vist_record  WHERE id in
(
SELECT MAX(id) AS id  FROM vist_record  GROUP BY user_code 
)

好了,该篇就先到这吧。

相关文章:

  • Springboot 手动分页查询,分批批量插入数据
  • SpringBoot (走读源码)静态方法中调用spring注入的对象,注入对象为null?
  • HashMap 使用的时候指定容量?你真的用明白了吗?(值得一阅)
  • 用这个免费CDN,治愈WordPress网站加载缓慢的大难题
  • 搞什么啊? URI 和 URL 到现在还不清楚?
  • Springboot 根据数据库表自动生成实体类和Mapper,只需三步
  • SpringBoot 导出多个Excel文件,压缩成.zip格式下载
  • Springboot 指定自定义模板导出Excel文件
  • Mysql 我随手造200W条数据,给你们讲讲分页优化。
  • 【云原生】风云暗涌的时代,DBA们的利刃出鞘了
  • 以后面试官问你 为啥不建议使用Select *,请你大声回答他!
  • Springboot 导入导出Excel ,一对多关系,复合表格、合并单元格数据
  • 怎么清晰地理解、表达 IaaS 、 PaaS 、 SaaS ?
  • UML类图的六大关系,最佳学习理解方式
  • Springboot 整合 Socket 实战案例 ,实现 单点发送、广播群发,1对1,1对多
  • [Vue CLI 3] 配置解析之 css.extract
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • CentOS7简单部署NFS
  • exif信息对照
  • HTTP那些事
  • java8-模拟hadoop
  • JavaScript 基础知识 - 入门篇(一)
  • JavaScript设计模式之工厂模式
  • Java多态
  • Odoo domain写法及运用
  • underscore源码剖析之整体架构
  • Webpack入门之遇到的那些坑,系列示例Demo
  • 笨办法学C 练习34:动态数组
  • 闭包--闭包作用之保存(一)
  • 从0搭建SpringBoot的HelloWorld -- Java版本
  • 今年的LC3大会没了?
  • 少走弯路,给Java 1~5 年程序员的建议
  • 提醒我喝水chrome插件开发指南
  • 微信支付JSAPI,实测!终极方案
  • 项目管理碎碎念系列之一:干系人管理
  • 一份游戏开发学习路线
  • 用jQuery怎么做到前后端分离
  • hi-nginx-1.3.4编译安装
  • 格斗健身潮牌24KiCK获近千万Pre-A轮融资,用户留存高达9个月 ...
  • ​ 无限可能性的探索:Amazon Lightsail轻量应用服务器引领数字化时代创新发展
  • #我与Java虚拟机的故事#连载19:等我技术变强了,我会去看你的 ​
  • #中的引用型是什么意识_Java中四种引用有什么区别以及应用场景
  • (4)logging(日志模块)
  • (C)一些题4
  • (C语言)球球大作战
  • (Forward) Music Player: From UI Proposal to Code
  • (附源码)php投票系统 毕业设计 121500
  • (南京观海微电子)——I3C协议介绍
  • (区间dp) (经典例题) 石子合并
  • (提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战
  • (转)shell调试方法
  • (转)创业的注意事项
  • .NET “底层”异步编程模式——异步编程模型(Asynchronous Programming Model,APM)...
  • .Net 中Partitioner static与dynamic的性能对比
  • .NET 中的轻量级线程安全