您现在的位置是:群英 > 数据库 > MySQL数据库
MySQL查询最新数据数据行的方法是什么
Admin发表于 2022-10-25 18:10:17739 次浏览
这篇文章分享给大家的内容是关于MySQL查询最新数据数据行的方法是什么,本文介绍得很详细,内容有一定的参考价值,能帮助大家进一步学习和理解“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查询最新数据数据行的方法是什么的知识,欢迎关注群英网络,群英网络将为大家推送更多相关知识的文章。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2022-08-03 17:48:08 
摘要:oracle中的12154错误是无法解析指定连接的意思。解决方法:1、因为环境变量没有配对,可以通过修改“TNS_ADMIN”和“NLS_LANG”参数解决;2、若环境变量无误,则更改“Oracle_Home/network\admin”文件夹下的“listener.ora”、“tnsnames.ora”或者“sqlnet.ora”文件配置即可。
2022-04-27 16:44:02 
摘要:给大家带来一篇关于MySql5.7.11编译安装及修改root密码的技巧的相关教程文章,内容涉及到mysql修改root密码、mysql5.7.11修改root密码、MySql5.7.11编译安装及修改root密码的方法小结等相关内容,更多关于MySql5.7.11编译安装及修改root密码的方法小结的内容希望能够帮助到大家。
2022-10-24 09:43:03 
摘要:MySQL 因其速度和整体易用性而成为开发人员和管理员最受欢迎和喜爱的数据库。不幸的是,这种易用性是以牺牲安全为代价的。即使 MySQL 可以配置有严格的安全控制,你的普通默认 MySQL 配置可能不会使用它们。在本文中,我将介绍强化 MySQL 数据库应采取的五个重要步骤。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部