加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySql如何找出符合条件的最新数据行

发布时间:2023-06-09 13:59:12 所属栏目:MySql教程 来源:
导读:这篇文章主要讲解了“MySql如何查出符合条件的最新数据行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySql如何查出符合条件的最新数据行&rd
这篇文章主要讲解了“MySql如何查出符合条件的最新数据行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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
 
)
 
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!