首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > oracle >

求:交织时间的sql

2011-12-19 
求:交叉时间的sql表idstartendname1 2009-08-082009-09-09 beijing2 2009-10-082010-09-09 shanghai3 2008

求:交叉时间的sql

id start end name
1 2009-08-08 2009-09-09 beijing
2 2009-10-08 2010-09-09 shanghai
3 2008-10-08 2009-09-09 tianjin
4 2007-10-08 2009-09-09 chongqing
5 2009-09-01 2009-09-05 beijing
6 2009-09-10 2009-11-05 beijing
……
start 和end 都是Date类型
还有很多行
我想找出 name相同的 某一行的Start end 完全包含另一行的Start和end的行 都是哪两行
比如上面 北京name=‘beijing’的第1行 就完全包括第5行
万分感谢。

[解决办法]

SQL code
SELECT a.*, b.*  FROM tab a, tab b WHERE a.name = b.name AND       b.start < a.start AND       a.end < b.end
[解决办法]
如果要按原表字段显示,可以
SQL code
--表名为tabSELECT t.*  FROM tab t,       (SELECT a.id aid, b.id bid          FROM tab a, tab b         WHERE a.name = b.name AND               b.start < a.start AND               a.end < b.end) c WHERE t.id = c.aid OR       t.id = c.bid; 

热点排行