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行
万分感谢。

解决方案 »

  1.   

    SELECT a.*, b.*
      FROM tab a, tab b
     WHERE a.name = b.name AND
           b.start < a.start AND
           a.end < b.end
      

  2.   

    如果要按原表字段显示,可以
    --表名为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;
      

  3.   

    列名建议不要取名为start,start为保留字