当前位置:网站首页> MySql 查询符合条件的最新数据行
MySql 查询符合条件的最新数据行
2022-07-05 16:42:00 【1024问】
平时做业务,经常是需要查什么什么什么的最新的一条数据。
那至于最新这个概念, 对于产品来说,经常会说的是 时间顺序,最新也就是 最近的意思。
结合示例:
这是一张记录人员来访的记录表。
数据表里的数据准确记录了每个人来访时带的帽子颜色、时间、人员编码(每个人唯一)。

数据样例:

需要做到的是 :
拿出符合条件的最新的来访记录。
你会最怎么做?
先实现一点的, 取出 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_timeFROM vist_recordWHERE id IN (SELECT MAX(id) AS id FROM vist_record WHERE user_code='A101' )查询结果:

但是看到上面使用子查询的这种方式, 大家心里面肯定也已经在暗暗地骂娘, 拿个最新数据这么麻烦?
有没有简单一点的?
有。
比如说,我们已经确定了, id是自增的,id最大的数据(符合条件的数据) 就是最新的。
那么我们就可以使用倒序 DESC 来取最新数据:
DESC 也就是 倒序/降序 。
PS:

使用倒序查找:
SELECT *FROM vist_recordWHERE user_code='A101'ORDER BY id DESCLIMIT 1;查询结果:

或者根据时间倒序:
SELECT *FROM vist_recordWHERE user_code='A101'ORDER BY create_time DESCLIMIT 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查询最新数据行内容请搜索软件开发网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件开发网!
边栏推荐
- The second day of learning C language for Asian people
- 网站页面禁止复制内容 JS代码
- stirring! 2022 open atom global open source summit registration is hot!
- Embedded-c Language-1
- First day of learning C language
- 浏览器渲染原理以及重排与重绘
- thinkphp3.2.3
- Read the basic grammar of C language in one article
- 一文了解MySQL事务隔离级别
- How does the outer disk futures platform distinguish formal security?
猜你喜欢

dried food! Semi supervised pre training dialogue model space

调查显示传统数据安全工具面对勒索软件攻击的失败率高达 60%

Error in composer installation: no composer lock file present.

国内首家 EMQ 加入亚马逊云科技「初创加速-全球合作伙伴网络计划」
![[Web attack and Defense] WAF detection technology map](/img/7c/60a25764950668ae454b2bc08fe57e.png)
[Web attack and Defense] WAF detection technology map

Three traversal methods of binary tree
一文了解MySQL事务隔离级别

ECU简介

Etcd 构建高可用Etcd集群

Etcd build a highly available etcd cluster
随机推荐
Embedded -arm (bare board development) -1
【机器人坐标系第一讲】
CMake教程Step6(添加自定义命令和生成文件)
thinkphp3.2.3
Jarvis OJ Flag
[Jianzhi offer] 66 Build product array
EasyX second lesson
composer安装报错:No composer.lock file present.
【729. 我的日程安排錶 I】
编译libssh2报错找不到openssl
Rider 设置选中单词侧边高亮,去除警告建议高亮
兰空图床苹果快捷指令
Embedded-c Language-3
IDC报告:腾讯云数据库稳居关系型数据库市场TOP 2!
【二叉树】根到叶路径上的不足节点
Embedded UC (UNIX System Advanced Programming) -1
URP下Alpha从Gamma空间到Linner空间转换(二)——多Alpha贴图叠加
[Web attack and Defense] WAF detection technology map
Copy mode DMA
dried food! Semi supervised pre training dialogue model space