求:交叉时间的sql

hbgzg3006 2010-04-09 02:11:21

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行
万分感谢。
...全文
80 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
hbgzg3006 2010-04-09
  • 打赏
  • 举报
回复
谢谢楼上,我的那个列明是自己编的。感激不尽。
tangren 2010-04-09
  • 打赏
  • 举报
回复
列名建议不要取名为start,start为保留字
tangren 2010-04-09
  • 打赏
  • 举报
回复
如果要按原表字段显示,可以
--表名为tab
SELECT 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;
tangren 2010-04-09
  • 打赏
  • 举报
回复
SELECT a.*, b.*
FROM tab a, tab b
WHERE a.name = b.name AND
b.start < a.start AND
a.end < b.end
hbgzg3006 2010-04-09
  • 打赏
  • 举报
回复
对了 忘了说了 同名的出现完全交叉的最多两行。谢谢。不存在多行。

17,086

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧