MySql 查询符合条件的最新数据行

 更新时间:2022年07月05日 11:31:48   作者:小目标青年  
这篇文章主要介绍了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查询最新数据行内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PHP函数使用说明(补充)

    PHP函数使用说明(补充)

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助。
    2010-07-07
  • MySQL 搭建MHA架构部署的步骤

    MySQL 搭建MHA架构部署的步骤

    这篇文章主要介绍了MySQL 搭建MHA架构部署的步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • 导致sql执行速度慢的几种情况盘点(生产环境踩过的坑)

    导致sql执行速度慢的几种情况盘点(生产环境踩过的坑)

    盘点分析MySQL执行速度慢可以帮助我们进行优化MySQL数据库的效率,这篇文章主要给大家盘点介绍了关于导致sql执行速度慢的几种情况,文中介绍的这些主要是生产环境踩过的坑,需要的朋友可以参考下
    2023-03-03
  • mysql 5.7.18 免安装版window配置方法

    mysql 5.7.18 免安装版window配置方法

    这篇文章主要为大家详细介绍了mysql 5.7.18 免安装版window配置方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • MySQL索引使用说明(单列索引和多列索引)

    MySQL索引使用说明(单列索引和多列索引)

    这篇文章主要讨论MySQL选择索引时单列单列索引和多列索引使用,以及多列索引的最左前缀原则,需要的朋友可以参考下
    2018-01-01
  • mysql的左右内连接用法实例

    mysql的左右内连接用法实例

    这篇文章主要介绍了mysql的左右内连接用法,以一个完整实例较为详细的分析了mysql的左右内连接使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • MySQL中replace into与replace区别详解

    MySQL中replace into与replace区别详解

    本文主要介绍了MySQL中replace into与replace区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • 关于case when语句的报错问题详解

    关于case when语句的报错问题详解

    SQL CASE 表达式是一种通用的条件表达式,类似于其它语言中的 if/else 语句,下面这篇文章主要给大家介绍了关于case when语句的报错问题的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-08-08
  • 网上提供的最简便的MySql数据库备份的方法

    网上提供的最简便的MySql数据库备份的方法

    网上提供的最简便的MySql数据库备份的方法...
    2007-02-02
  • MySQL 中常见的几种高可用架构部署方案解析

    MySQL 中常见的几种高可用架构部署方案解析

    MySQL Replication 是官方提供的主从同步方案,用于将一个 MySQL 的实例同步到另一个实例中,这篇文章主要介绍了MySQL 中常见的几种高可用架构部署方案,需要的朋友可以参考下
    2023-04-04

最新评论