irpas技术客

MySql 怎么查出符合条件的最新的数据行?_小目标青年_mysql查询最新的数据

网络 628

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

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

结合示例:

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

数据样例:

需要做到的是 :

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

你会最怎么做??

先实现一点的, 取出 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? )

好了,该篇就先到这吧。


1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,会注明原创字样,如未注明都非原创,如有侵权请联系删除!;3.作者投稿可能会经我们编辑修改或补充;4.本站不提供任何储存功能只提供收集或者投稿人的网盘链接。

标签: #mysql查询最新的数据 #最新数据的查找