首頁 > 資料庫 > mysql教程 > PostgreSQL 的 EXCLUDE 約束如何防止重疊和相鄰的日期/時間範圍條目?

PostgreSQL 的 EXCLUDE 約束如何防止重疊和相鄰的日期/時間範圍條目?

Barbara Streisand
發布: 2025-01-04 00:30:38
原創
915 人瀏覽過

How Can PostgreSQL's EXCLUDE Constraint Prevent Overlapping and Adjacent Date/Time Range Entries?

在PostgreSQL 中使用EXCLUDE 防止相鄰/重疊條目

建立問題:

建立問題:

。資料庫儲存任意日期/時間範圍,目標是防止重疊和相鄰條目。採用了使用 EXCLUDE 子句和 GiST 索引的約束,但是對第二個解析度的假設產生了擔憂。

解 1:假設第二個分辨率

如果應用程式只需要第二個分辨率,假設這在約束中可能就足夠了。然而,更高解析度的資料類型可能需要更穩健的解決方案。

解 2:包含邊界

下限和上限的包含邊界 ([]) 都允許使用範圍函數透過 CHECK 約束進行重疊檢測。帶有 && 的 EXCLUDE 約束確保不重疊,而另一個 CHECK 約束強制執行包含邊界。

解 3:規範邊界

規範邊界 ([)] 促進非-透過 EXCLUDE 約束與 && 重疊。此外,在單獨的 EXCLUDE 約束中使用相鄰運算子 (-|-) 來禁止相鄰條目。 CHECK 約束確保適當的邊界值。

實作細節:
-- Solution 2: Inclusive Bounds
CREATE TABLE tbl (
  tbl_id serial PRIMARY KEY,
  tsr tsrange,
  CONSTRAINT tsr_no_overlap  EXCLUDE USING gist (tsr WITH &&),
  CONSTRAINT tsr_enforce_incl_bounds CHECK (lower_inc(tsr) AND upper_inc(tsr))
);

-- Solution 3: Canonical Bounds
CREATE TABLE tbl (
  tbl_id serial PRIMARY KEY,
  tsr tsrange,
  CONSTRAINT tsr_no_overlap  EXCLUDE USING gist (tsr WITH &&),
  CONSTRAINT tsr_no_adjacent EXCLUDE USING gist (tsr WITH -|-),
  CONSTRAINT tsr_enforce_bounds CHECK (lower_inc(tsr) AND NOT upper_inc(tsr))
);
登入後複製

建議:

解決方案3 提供了無論分辨率要求如何,都可以處理重疊和相鄰條目的強大解決方案。

以上是PostgreSQL 的 EXCLUDE 約束如何防止重疊和相鄰的日期/時間範圍條目?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板