在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中文網其他相關文章!