编辑:询问meta并决定修改我的问题,粗体添加新内容。
我有以下查询,查找重叠的时间段:
SELECT t1.id1, t2.id1
FROM `mytable` AS t1
JOIN `mytable` AS t2
ON (
((t1.start_date BETWEEN t2.start_date AND t2.end_date))
OR ((t1.end_date BETWEEN t2.start_date AND t2.end_date))
)
WHERE t1.id1 < t2.id1;
结果集是:
id1 id1
6 7
8 9
5 11
10 12
我需要以下结果,只需在单个列上添加所有值,并添加一列以显示哪些行是对,以便稍后我可以使用该结果here 。应该很简单,但我无法让它发挥作用。
col pair_id
6 1
8 2
5 3
10 4
7 1
9 2
11 3
12 4
答案 0 :(得分:1)
这是sql中的标准功能,叫做“union” 请查看您正在使用的数据库系统的文档。
答案 1 :(得分:1)
不确定这是否有效,但请尝试:
SELECT t1.id1
... snip ...
WHERE t1.id1 != t2.id1;
这只是明确地排除了自我重叠,并且允许&#39; 7&#39;记录显示为&#39; 6&#39; (根据您的样本结果)。