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