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

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日

悬赏问题

  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?