我先把功能场景简要阐述下:

数据行字段如下:

name
started_at
type

在这张表里,name有重复值

现在需要在type确定的情况下,筛选出一个列表,满足,name不重复,找出的记录为同name下started_at为最小的记录

举个例子:

活动1 2019-06-01 type1
活动1 2019-06-02 type1
活动1 2019-06-03 type1

活动2 2019-06-03 type1
活动2 2019-06-05 type1
活动2 2019-06-07 type1

那筛的列表应为:

活动1 2019-06-01 type1
活动2 2019-06-03 type1

还需要满足started_at 大于 当前时间

请问这样的sql应该如何写?

解决思路为:

就是利用left join 自己

比如s1 left join s2 on s1.name=s2.name and s2.started_at<s1.started_at and s2.started_at > now()

最后where s2.id is null

SELECT s1.NAME, s1.started_at, FROM tbl s1 LEFT JOIN tbl s2 ON s1.`name` = s2.`name`   AND s1.started_at > s2.started_at   AND s2.started_at > now( ) WHERE  s2.id IS NULL   AND s1.started_at > now( )  AND s1.type = 'online_lecture'ORDER BY s1.NAME, s1.started_at;

总结

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  3. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  4. android 零星调试笔记
  5. 2011年Android(安卓)Camera学习笔记之一
  6. [APP] Android(安卓)开发笔记 006-使用短信验证SDK进行短信验证
  7. 【安卓笔记】android客户端与服务端交互的三种方式
  8. [RK3399][Android7.1] 调试笔记 --- 设置搜狗为开机默认输入法
  9. 整理:Android自带、第三方需要添加依赖的控件

随机推荐

  1. Android常用控件总结
  2. Android EditText 共用TextWatcher,在Text
  3. android 桌面快捷方式
  4. android各种分辨率和屏幕密度
  5. Android中Binder类代码(android-5.0.2)
  6. 史上最懒的android开发环境配置教程
  7. android service完全解析。
  8. android Vibrator 使用
  9. android broadcast intent
  10. android webview ERR_UNKNOWN_URL_SCHEME