加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 唯一日期时间范围的Postgres约束

发布时间:2020-12-12 08:32:56 所属栏目:MsSql教程 来源:网络整理
导读:我的表有两列: startsAt 结束 两者都保持日期和时间. 我想制定以下约束: 如果两列都不是NULL,则startsAt和endsAt之间的范围不得与其他范围(来自其他行)重叠. 解决方法 您可以保留单独的时间戳列,并在表达式上仍然使用 exclusion constraint : CREATE TABLE
我的表有两列:

> startsAt
>结束

两者都保持日期和时间.
我想制定以下约束:

如果两列都不是NULL,则startsAt和endsAt之间的范围不得与其他范围(来自其他行)重叠.

解决方法

您可以保留单独的时间戳列,并在表达式上仍然使用 exclusion constraint
CREATE TABLE tbl (
   tbl_id    serial PRIMARY KEY,starts_at timestamp,ends_at   timestamp,EXCLUDE USING gist (tsrange(starts_at,ends_at) WITH &&) -- no overlapping
);

Constructing a tsrange value没有显式边界,因为tsrange(starts_at,ends_at)自动采用默认边界:包括下限和排除上限 – ‘[)’,这通常是最好的.

SQL Fiddle.

有关:

> Preventing adjacent/overlapping entries with EXCLUDE in PostgreSQL

向现有表添加约束

ALTER TABLE tbl ADD CONSTRAINT tbl_no_overlapping_time_ranges
EXCLUDE USING gist (tsrange(starts_at,ends_at) WITH &&)

语法详细信息与CREATE TABLE相同.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读