栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Oracle-将行中的值转换为范围

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Oracle-将行中的值转换为范围

我觉得可能可以对此进行改进,但是它可以起作用:

WITH base AS  (    SELECt  1 N FROM DUAL UNIOn ALL    SELECt  2 N FROM DUAL UNIOn ALL    SELECt  3 N FROM DUAL UNIOn ALL    SELECt  6 N FROM DUAL UNIOn ALL    SELECt  7 N FROM DUAL UNIOn ALL    SELECt 17 N FROM DUAL UNIOn ALL    SELECt 18 N FROM DUAL UNIOn ALL    SELECt 19 N FROM DUAL UNIOn ALL    SELECt 21 N FROM DUAL), lagged AS(    SELECt n, LAG(n) OVER (ORDER BY n) lag_n FROM base), groups AS(    SELECt n, row_number() OVER (ORDER BY n) groupnum      FROM lagged      WHERe lag_n IS NULL OR lag_n < n-1), grouped AS(    SELECt n, (SELECT MAX(groupnum) FROM groups      WHERe groups.n <= base.n   ) groupnum      FROM base)SELECt groupnum, MIN(n), MAX(n)  FROM grouped  GROUP BY groupnum  ORDER BY groupnum


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/647581.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号