首页  >  文章  >  数据库  >  如何确保 MySQL 的“avail”表中的日期范围不重叠?

如何确保 MySQL 的“avail”表中的日期范围不重叠?

Patricia Arquette
Patricia Arquette原创
2024-10-28 10:00:04306浏览

How to Ensure Non-Overlapping Date Ranges in MySQL's `avail` Table?

MySQL:仅当不存在重叠时才将日期范围插入日期列

问题陈述

给定一个名为avail的表存储不同 acc_id 的可用性日期范围,目的是验证和插入新的日期范围,而不与同一 acc_id 的现有日期范围重叠。具体来说,必须避免任何类型的重叠,包括与现有日期匹配的开始日期和结束日期。

建议的解决方案

单语句方法:

遗憾的是,由于缺乏 SQL CHECK 约束,不可能在 MySQL 中使用单个插入语句来实现此验证。

替代方法:

SQL 触发器:

SQL 触发器可用于在执行插入或更新操作之前强制执行此约束。触发器将检查重叠行并使用 SIGNAL 语句抛出错误。但是,这种方法需要使用最新版本的 MySQL。

应用程序逻辑:

最实用的方法是在应用程序逻辑中执行验证。 SELECT COUNT(id) 语句可用于检索新范围违反的行数。如果计数大于 0,则应中止插入/更新操作。

检查插入失败:

可以检查受影响的行以确定是否插入是成功还是失败。值为 0 表示失败,可能是由于日期重叠或其他原因。

示例:

<code class="sql">SELECT COUNT(id)
FROM avail
WHERE
  acc_id = <new_acc_id>
  AND (
    (start_date <= <new_start_date> AND end_date >= <new_start_date>)
    OR (start_date <= <new_end_date> AND end_date >= <new_end_date>)
  );</code>

如果返回的计数大于 0 ,不应执行插入操作。

以上是如何确保 MySQL 的“avail”表中的日期范围不重叠?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn