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 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 &&) 语法详细信息与 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |