MySQL判断时间段是否重合的两种方法

 更新时间:2022年07月08日 09:56:55   作者:小旭2021  
这篇文章介绍了MySQL判断时间段是否重合的两种方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

两种写法。如图,4种重合情况和2种不重合情况。

第一种写法:

-- 时间段 a,b  
SELECT * FROM table WHERE
       (start_time >= a and end_time <= b) -- 被包含了
    or (end_time >= a and end_time <=b)
    or (start_time >= a and start_time <=b)
    or (start_time <= a and end_time >=b)

解析:where后的4个条件分别代表了图中4种重合的情况。
但是第一种情况被2和3包含了,所以简化一下写法:

SELECT * FROM table WHERE
    (end_time >= a and end_time <=b)
    or (start_time >= a and start_time <=b)
    or (start_time <= a and end_time >=b);

第二种写法:

SELECT * FROM table WHERE not (start_time > b or end_time < a);

到此这篇关于MySQL判断时间段是否重合的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • MySQL9.1.0实现GTID模式的项目实践

    MySQL9.1.0实现GTID模式的项目实践

    本文主要介绍了在MySQL 9.1.0中实现GTID模式的主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-02-02
  • 一步步教你如何使用mysql binlog恢复数据

    一步步教你如何使用mysql binlog恢复数据

    Binlog日志即binary log,是二进制日志文件,有两个作用,一个是增量备份,另一个是主从复制,下面这篇文章主要给大家介绍了关于如何使用mysql binlog 恢复数据的相关资料,需要的朋友可以参考下
    2023-04-04
  • MySql5.7.21安装要点记录笔记

    MySql5.7.21安装要点记录笔记

    这篇文章主要介绍了mysql5.7.21安装要点记录笔记,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-02-02
  • MySQL 使用 Performance Schema 定位和解决慢 SQL 问题

    MySQL 使用 Performance Schema 定位和解决慢 

    本文介绍了如何使用MySQL的PerformanceSchema来定位和解决慢SQL查询问题,通过启用PerformanceSchema并分析相关的系统表,可以收集到详细的性能数据,从而识别出影响性能的SQL语句,优化策略包括优化查询语句、调整数据库配置等
    2025-02-02
  • MySQL提示The InnoDB feature is disabled需要开启InnoDB的解决方法

    MySQL提示The InnoDB feature is disabled需要开启InnoDB的解决方法

    这篇文章主要介绍了MySQL提示The InnoDB feature is disabled需要开启InnoDB的解决方法,简单分析了MySQL数据库开启InnoDB引擎的实现技巧,需要的朋友可以参考下
    2016-01-01
  • MySQL数据库之约束简析

    MySQL数据库之约束简析

    这篇文章主要介绍了MySQL数据库之约束简析,约束是作用于表中字段上的规则,用于限制存储在表中的数据,保证数据库中数据的正确、有效性和完整性,需要的朋友可以参考下
    2023-09-09
  • MySQL分区表的详细介绍

    MySQL分区表的详细介绍

    当设计MySQL分区表时,需要考虑以下几个方面,分区策略、分区字段、分区数量和分区函数,本文就来介绍一下MySQL分区表,感兴趣的可以了解一下
    2023-10-10
  • MySQL中lower_case_table_names作用及使用小结

    MySQL中lower_case_table_names作用及使用小结

    在使用DataEase连接外部数据库时,可能会遇到启动报错的问题,官方文档指出,修改数据库配置文件中的lower_case_table_names=1参数可以解决此问题,此参数控制表名大小写敏感性,感兴趣的可以了解一下
    2024-09-09
  • Mysql DDL常见操作汇总

    Mysql DDL常见操作汇总

    这篇文章主要介绍了Mysql DDL常见操作汇总,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • MySQL 的启动选项和系统变量实例详解

    MySQL 的启动选项和系统变量实例详解

    这篇文章主要介绍了MySQL 的启动选项和系统变量,结合实例形式详细分析了MySQL 启动选项和系统变量具体原理、功能、用法及操作注意事项,需要的朋友可以参考下
    2020-05-05

最新评论