这篇文章主要讲解了“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
)
感谢各位的阅读,以上就是“MySql如何查出符合条件的最新数据行”的内容了,经过本文的学习后,相信大家对MySql如何查出符合条件的最新数据行这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是开发云,小编将为大家推送更多相关知识点的文章,欢迎关注!
这篇文章主要介绍“mysql有存储过程吗”,在日常操作中,相信很多人在mysql有存储过程吗问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql有存储过程吗”的疑惑有所帮助!接下来,请跟着小编一起来学习吧! mysql有存储…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。