温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2022-09-20 15:34:44 来源:亿速云 阅读:144 作者:iii 栏目:开发技术

这篇“MySql怎么查询符合条件的最新数据行”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySql怎么查询符合条件的最新数据行”文章吧。

    平时做业务,经常是需要查什么什么什么的最新的一条数据。

    那至于最新这个概念, 对于产品来说,经常会说的是 时间顺序,最新也就是 最近的意思。

    结合示例:

    这是一张记录人员来访的记录表。
    数据表里的数据准确记录了每个人来访时带的帽子颜色、时间、人员编码(每个人唯一)。

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

    数据样例:

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

    需要做到的是 :

    拿出符合条件的最新的来访记录。

    你会最怎么做? 

    先实现一点的, 取出 A101 这个人员编码的 最新来访记录 。

    首先先展示错误的sql示例: 想当然地使用max() 函数。

    SELECT MAX(id) AS id ,user_code,cap_color,create_time FROM vist_record WHERE user_code='A101' ;

    查询结果(错误的结果):

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

    显然咋一看出来的数据有模有样,但是其实是错的。

    为什么是错的的,可以稍微讲一下,既然评论区有人感兴趣了(欢迎兄弟们说出自己的看法)。

    简单叙述, max是聚合函数, 我们的错误示例没配合group by 去使用, 这时候其实也就mysql这个家伙能让我们执行了,很多数据库都直接报错的。

    那么执行是执行的,其实这时候mysql相当于把整个表当作了一个内容块去进行一个压缩检索。

    我们加上了where 条件  user_code='A101',所以整个内容块确实过滤掉了其他不是user_code='A101' 的数据。
    也就是说这种松懈执行的情况下,mysql保证max 返回(相关列) 的最大值, 其他列字段它是不保证的。 

    正确的数据是 :

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

    那是不是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' )

    查询结果:

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

    但是看到上面使用子查询的这种方式, 大家心里面肯定也已经在暗暗地骂娘, 拿个最新数据这么麻烦?

    有没有简单一点的?
    有。

    比如说,我们已经确定了, id是自增的,id最大的数据(符合条件的数据) 就是最新的。

    那么我们就可以使用倒序 DESC 来取最新数据:

    DESC 也就是 倒序/降序 。

     使用倒序查找:

    SELECT *
    FROM vist_record
    WHERE user_code='A101'
    ORDER BY id DESC
    LIMIT 1;

    查询结果: 

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

     或者根据时间倒序:

    SELECT *
    FROM vist_record
    WHERE user_code='A101'
    ORDER BY create_time DESC
    LIMIT 1;

    查询结果: 

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

    就这么简单实现了吗? 

    那么我们如果需求要的不是指定A101 要的是涉及到的每一个人的最新数据呢?

    也就是存在多组的概念。 

    每一类的符合条件的最新数据

    橙色框就是 A101 、B202 、 C303 分别的最新记录 , 我们要取出来。

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

    错误示例:

    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怎么查询符合条件的最新数据行”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

    向AI问一下细节

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

    AI