mysql自联去重的一些笔记记录

 更新时间:2019年06月07日 09:52:30   作者:小白菜  
这篇文章主要给大家介绍了关于mysql自联去重的一些笔记记录,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

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

数据行字段如下:

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;

大家有什么更好的解决思路吗?

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • python 连接数据库mysql解压版安装配置及遇到问题

    python 连接数据库mysql解压版安装配置及遇到问题

    今天学习python连接数据库,就想安装一下mysql数据库,没想到小小的数据库也遇到了不少挫折,所以我就把自己的安装过程以及问题写出来分享给大家,需要的朋友可以参考下
    2019-06-06
  • ARM64架构下安装mysql5.7.22的全过程

    ARM64架构下安装mysql5.7.22的全过程

    这篇文章主要介绍了ARM64架构下安装mysql5.7.22的全过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-07-07
  • Mysql使用函数json_extract处理Json类型数据的方法实例

    Mysql使用函数json_extract处理Json类型数据的方法实例

    在日常业务开发中通常mysql数据库中某个字段会需要存储json格式字符串,下面这篇文章主要给大家介绍了关于Mysql使用函数json_extract处理Json类型数据的相关资料,需要的朋友可以参考下
    2022-09-09
  • MySQL数据库备份方法说明

    MySQL数据库备份方法说明

    MySQL数据库备份方法说明...
    2007-07-07
  • 解析MySQL索引的作用

    解析MySQL索引的作用

    这篇文章主要为大家详细介绍了MySQL索引的作用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • MySQL建表设置默认值的取值范围

    MySQL建表设置默认值的取值范围

    这篇文章主要介绍了MySQL建表设置默认值的取值范围,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • mac下重置mysl8.0.11密码的方法

    mac下重置mysl8.0.11密码的方法

    mac下安装mysql8.0.11时要求输入密码之后想修改密码。接下来通过本文给大家介绍mac下重置mysl8.0.11密码的方法,需要的朋友可以参考下
    2018-06-06
  • mysql仿asp的数据库操作类

    mysql仿asp的数据库操作类

    使用说明: 该类完全按照ADO的习惯书写的,用过ASP的人都觉得ASP连接数据库比PHP好用(这是我的感觉), 但PHP得一个一个API地写,挺累,该类做了完全的封装 创建类的实例时可以指定一个数据库表和选择的数据库,如:new MySQLDB("table","database");
    2008-04-04
  • 详解Mysql两表 join 查询方式

    详解Mysql两表 join 查询方式

    这篇文章主要介绍了Mysql两表 join 查询方式,主要包括SQL基本语法格式ji3种join方式,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • MAC下MYSQL数据库密码忘记的解决办法

    MAC下MYSQL数据库密码忘记的解决办法

    这篇文章主要介绍了Mac操作系统下MYSQL数据库密码忘记的快速解决办法,教大家重置MYSQ密码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11

最新评论