大海话语 2022-01-30 19:41 采纳率: 87.9%
浏览 34
已结题

Mysql多条件查询,先满足前两个条件的情况 下,再判断其中最新的时间

我想查询 一条数据,在一个表中 ,有三个子条件,先满足前两个条件的情况 下,得到的多条数据中,再在这些得到的数据中,查询得到最新的更新时间的那一条数据(而不是全部表中最新的时间那一条数据)。我现在写的这条Mybatis 它会报 子查询 出现多条数据。不知道该 怎么做哈。。

select (select update_time from adverts where large_categories = #{largeCategories}
         and small_categories = #{smallCategories}) from adverts where 
         update_time = (select max(update_time) from adverts)
         
    </select>

下面这样写,会返回表中 ,全部数据的最新时间的那一条数据


select * from adverts where large_categories = #{largeCategories}
         and small_categories = #{smallCategories}
         and update_time = (select max(update_time) from adverts)
    
    </select>
  • 写回答

1条回答 默认 最新

  • 大鹏cool 优质创作者: Java技术领域 2022-01-30 19:56
    关注

    按照更新时间倒序取第一条即可,示例代码如下。

    select * from adverts where small_categories = #{smallCategories} and large_categories = #{largeCategories} order by update_time desc limit 1
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 2月7日
  • 已采纳回答 1月30日
  • 创建了问题 1月30日