在 PostgreSQL 中查找重叠的日期范围
当前的任务是检索指定时间内与特定球队相关的球员列表框架。虽然提供的查询试图实现这一目标,但由于逻辑不正确以及对如何识别重叠范围的根本误解,它还不够。
要创建一个在所需时间范围内准确识别玩家的查询,需要遵循几个关键原则必须考虑:
-
正确的日期范围比较: 原始查询中使用的 BETWEEN 运算符包括上限。在处理重叠范围时这是不正确的,重叠范围应该是排他的。相反,适当的比较是 <或 = 介于下限和上限之间,确保仅捕获指定范围内的日期。
-
NULL 值的考虑:对于尚未离开团队的玩家, date_leave 列可能为 NULL。查询必须通过允许重叠范围比较中包含 NULL 值来考虑这种可能性。
-
处理潜在的重复:当同一玩家存在多个合同时,必须进行合并结果消除重复。可以使用 DISTINCT 关键字来确保只返回唯一的玩家名称。
-
SQL OVERLAPS 运算符: PostgreSQL 提供了一个内置的 OVERLAPS 运算符,该运算符专门用于确定是否两次时期相交。该运算符可以通过消除显式日期比较的需要来简化查询。
-
范围类型:在 PostgreSQL 9.2 及更高版本中,可以使用专门的范围类型来表示日期范围。这些类型允许有效的重叠范围比较,并可用于优化查询。
通过合并这些原则,提供的修订后的查询解决了原始查询的缺点,并准确识别给定团队的球员指定时间内:
SELECT DISTINCT name_player
FROM contract
WHERE name_team = ?
AND (date_join, COALESCE(date_leave, CURRENT_DATE)) OVERLAPS
(date '2009-01-01', date '2010-01-01');
登录后复制
以上是如何在 PostgreSQL 中高效查找特定日期范围内球队的球员?的详细内容。更多信息请关注PHP中文网其他相关文章!