资源描述:
《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