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

58次阅读
没有评论

共计 1556 个字符,预计需要花费 4 分钟才能阅读完成。

这篇文章主要讲解了“MySql 如何查出符合条件的最新数据行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“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

错误的筛选结果:

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

正确编码:

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
)

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

感谢各位的阅读,以上就是“MySql 如何查出符合条件的最新数据行”的内容了,经过本文的学习后,相信大家对 MySql 如何查出符合条件的最新数据行这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计1556字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)