oracle connect by 和 分析函数总结

oracle connect by 和 分析函数总结

ID:40489658

大小:107.48 KB

页数:15页

时间:2019-08-03

oracle connect by 和 分析函数总结_第1页
oracle connect by 和 分析函数总结_第2页
oracle connect by 和 分析函数总结_第3页
oracle connect by 和 分析函数总结_第4页
oracle connect by 和 分析函数总结_第5页
资源描述:

《oracle connect by 和 分析函数总结》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、1.connectby用法总结2一、树查询(递归查询)2二、列转行sys_connect_by_path()42.分析函数总结61.分析函数(OVER)72.分析函数2(Rank,Dense_rank,row_number)93.分析函数3(Top/BottomN、First/Last、NTile)94.窗口函数115.报表函数141.151.connectby用法总结一、树查询(递归查询)1.作用对于oracle进行简单树查询(递归查询)列转行2.基本语法select...from wh

2、ere:过滤条件,用于对返回的所有记录进行过滤。startwith:查询结果重起始根结点的限定条件。connectby;:连接条件1)例子:selectnum1,num2 fromtablestartwithnum2=1008 connectby num2=priornum1 ;2)解释:startwith:用来标识哪个节点作为查找树

3、型结构的根节点。若该子句被省略,则表示所有满足查询条件的行作为根节点。prior:位置很重要(自我总结,和父在一起则自底向上,即查父和子在一起则自顶向下查子)例子原始数据num1为父num2为子15看下面的图1.CONNECT_BY_ROOT返回当前节点的最顶端节点。2.CONNECT_BY_ISLEAF判断是否为叶子节点,是1,不是0。3.LEVEL伪列表示节点深度。4.SYS_CONNECT_BY_PATH函数显示详细路径,并用“/”分隔。15二、列转行sys_connect_by_path()这个函数使用

4、之前必须先建立一个树,否则无用sys_connect_by_path(字段名,2个字段之间的连接符号)with tmp_aas(select'1'a,'0'pfromdualunionall select'2','1'fromdualunionall select'3','1'fromdualunionall select'4','3'fromdualunionall select'5','2'fromdualunionall select'6','5'fromdual)--子全部显示根-->子  level代

5、表级别selecta,p,sys_connect_by_path(a,'--'),levelfromtmp_astartwitha=1connectbyp=priora15--2和2的所有下级去掉根-->子(开始就要去掉)selecta,p,sys_connect_by_path(a,'--')fromtmp_astartwithp=1anda<>'2'connectbyp=priora--2的所有下级都去掉根-->子(connect时去掉)selecta,p,sys_connect_by_path(a,'--

6、')fromtmp_astartwitha=1connectbyp=prioraandp<>'2'--去掉2的分枝--2的下一级去掉根-->子(where中去掉)selecta,p,sys_connect_by_path(a,'--')fromtmp_awherep<>'2'startwitha=1connectbyp=priora--显示最长的根-->子with tmp_tabas(select'中国's,nullbfromdual unionall select'广东's,'中国'bfromdual uni

7、onall select'湖南's,'中国'bfromdual unionall select'衡阳's,'湖南'bfromdual unionall select'广州's,'广东'bfromdual unionall select'衡东's,'衡阳'bfromdual )selectmax(sys_connect_by_path(s,'/'))fromtmp_tabstartwiths='湖南'connectbypriors=b152.分析函数总结一、统计方面:Sum() Over ([Partition 

8、by ] [Order by ])Sum() Over ([Partition by ] [Order by ]       Rows Between  Preceding And  Following)       Sum() Over ([Partition by ] [Order by ]     Rows Between  Preceding And Current Row)S

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。