将列拆分为行,而不是经典的枢轴

时间:2012-12-07 16:10:25

标签: mysql

编辑:询问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

2 个答案:

答案 0 :(得分:1)

这是sql中的标准功能,叫做“union” 请查看您正在使用的数据库系统的文档。

答案 1 :(得分:1)

不确定这是否有效,但请尝试:

SELECT t1.id1
... snip ...
WHERE t1.id1 != t2.id1;

这只是明确地排除了自我重叠,并且允许&#39; 7&#39;记录显示为&#39; 6&#39; (根据您的样本结果)。