当前位置:网站首页>MySql 怎么查出符合条件的最新的数据行?
MySql 怎么查出符合条件的最新的数据行?
2022-07-30 04:15:00 【m0_67403013】
平时做业务,经常是需要查什么什么什么的最新的一条数据。
那至于最新这个概念, 对于产品来说,经常会说的是 时间顺序,最新也就是 最近的意思。
结合示例:
这是一张记录人员来访的记录表。
数据表里的数据准确记录了每个人来访时带的帽子颜色、时间、人员编码(每个人唯一)。
数据样例:

需要做到的是 :
拿出符合条件的最新的来访记录。
你会最怎么做?
先实现一点的, 取出 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
)
好了,该篇就先到这吧。
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- Wechat second-hand transaction small program graduation design finished product (1) Development overview
- 弘玑再度入围Gartner 2022 RPA魔力象限并实现位置大幅跃升
- Redis【超详解!!!】
- JQ源码分析(环境处理)
- 第51篇-知乎请求头参数分析【2022-07-28】
- 骁龙7系芯片表现如何?Reno8 Pro佐证新一代神U
- How does the AI intelligent security video platform EasyCVR configure the simultaneous transmission of audio and video?
- Pytorch框架学习记录1——Dataset类代码实战
- error: The following untracked working tree files would be overwritten by
- Redis "super explanation!!!!!!"
猜你喜欢
随机推荐
sqlmap use tutorial Daquan command Daquan (graphics)
How does the Snapdragon 7 series chip perform?Reno8 Pro proves a new generation of God U
Data Lake: Data Integration Tool DataX
【转】Swift 中的面向协议编程:引言
Pytorch framework learning record 3 - the use of Transform
spicy(二)unit hooks
Redis "super explanation!!!!!!"
【驱动】udev为USB转4串口的每个串口起别名
Pytorch框架学习记录3——Transform的使用
STM32 SPI+WM8978 voice loopback
mysql 结构、索引详解
Pytorch framework learning record 1 - Dataset class code combat
Boutique: Taobao/Tmall Get Order Details API for Purchased Products
数组和结构体
The implementation and basic operation of sub-database sub-table, ER table, global table, fragmentation rules, global sequence, etc. in MyCat
golang中如何比较struct,slice,map是否相等以及几种对比方法的区别
error: The following untracked working tree files would be overwritten by
机器学习:知道通过低方差过滤实现降维过程
Reverse Analysis Practice 2
SQL Server data type conversion function cast () and convert () explanation










