ITPub博客

首页 > Linux操作系统 > Linux操作系统 > (转)查找连续段(SQL技巧)

(转)查找连续段(SQL技巧)

原创 Linux操作系统 作者:fjmingyang 时间:2019-04-07 21:45:05 0 删除 编辑

在ITPUB上有一则非常巧妙的SQL技巧,学习一下,记录在这里。

最初的问题是这样的:

我有一个表结构,
fphm,kshm
2014,00000001
2014,00000002
2014,00000003
2014,00000004
2014,00000005
2014,00000007
2014,00000008
2014,00000009
2013,00000120
2013,00000121
2013,00000122
2013,00000124
2013,00000125

(第二个字段内可能是连续的数据,可能存在断点。)

怎样能查询出来这样的结果,查询出连续的记录来。
就像下面的这样?
2014,00000001,00000005
2014,00000009,00000007
2013,00000120,00000122
2013,00000124,00000125

ITPUB上的朋友给出了一个非常巧妙的答案:

SELECT b.fphm, MIN (b.kshm) Start_HM, MAX (b.kshm) End_HM
FROM (SELECT a.*, TO_NUMBER (a.kshm - ROWNUM) cc
FROM (SELECT *
FROM t
ORDER BY fphm, kshm) a
) b
GROUP BY b.fphm, b.cc

from : http://blog.csdn.net/annicybc/archive/2007/02/25/1514147.aspx


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/1698901/viewspace-103265/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 使用oracle发送mail
请登录后发表评论 登录
全部评论

注册时间:2006-04-03

  • 博文量
    66
  • 访问量
    51665