日期:2014-05-16  浏览次数:20702 次

求出时间包含的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 * from tablename a where exists(select 1 from tablename where start>a.start and start<a.end and end>a.start and end<a.end and name=a.name) or exists
(select 1 from tablename where start<a.start and end>a.end and name=a.name);

------解决方案--------------------
SQL code
select *
from 表 a ,表 b
where a.start<=b.start and a.end>=b.end and a.id!=b.id