首頁 >資料庫 >mysql教程 >如何在 PostgreSQL 中有效率地找到重疊的日期範圍?

如何在 PostgreSQL 中有效率地找到重疊的日期範圍?

Susan Sarandon
Susan Sarandon原創
2025-01-05 10:41:40690瀏覽

How Can I Efficiently Find Overlapping Date Ranges in PostgreSQL?

在 PostgreSQL 中尋找重疊的日期範圍

在 PostgreSQL 中處理日期範圍時,識別重疊是一項關鍵任務。提供的查詢嘗試尋找特定年份期間在球隊中的球員,但包含錯誤。

提供的查詢有問題

查詢包含BETWEEN 條件( DATE_PART('YEAR',date_join) >= ? AND DATE_PART('YEAR',date_leave) = 和

更正的查詢

正確找出重疊範圍,我們需要調整條件以排除上限:

SELECT * 
FROM   contract 
JOIN   team USING (name_team) 
JOIN   player USING(name_player) 
WHERE  name_team = ? 
AND    DATE_PART('YEAR',date_join) >= ? 
AND    DATE_PART('YEAR',date_leave) < ?

使用範圍的替代解決方案類型

PostgreSQL 版本9.2及更高版本提供範圍類型的支援。這是一個利用範圍類型和&&& 運算子來尋找重疊範圍的查詢:

SELECT DISTINCT name_player 
FROM   contract
WHERE  name_team = ? 
AND    daterange(date_join, date_leave) &&&
       daterange '[2009-01-01,2010-01-01)'

此查詢利用重疊運算子&&& 和專門定義的範圍類型來找出重疊的日期範圍,而不需要顯式邊界檢查。

以上是如何在 PostgreSQL 中有效率地找到重疊的日期範圍?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn