oracle sys_connect_by_path 函数 结果集连接

来源:asp之家 时间:2009-07-12 18:48:00 

以前看过有人转换过的,当时仅仅惊叹了一下,就过去了,没有记下来,直至于用到的时候呢,开始到处找,找来找去都没有找不到痕迹了,心里也就郁郁寡欢呀。

今天无意间,看connect by的使用,看到了sys_connect_by_path的用法,算是给我一个另类的惊喜了,sys_connect_by_path(columnname, seperator) 也可以拼出串来,不过这个函数本身不是用来给我们做这个结果集连接用的,而是用来构造树路径的,所以需要和connect by一起来用。

呵呵呵,在这里嚣张了一把,基于对oracle的一些函数的了解的基础上,看我是怎样硬生生的把一个没有树结构的普通表或者结果集做出我们想要的东西来。

magic is start.

道具,一个普通表,就一个字段 name, 姑且叫表名为test_sysconnectbypath吧,表名太长,嘻嘻,不怕,别名之。
以下为该表数据
NAME
------------------
深圳
武汉
上海
北京
天津
新加坡
别名之
SQL>with temp as (select name form test_sysconnectbypath);

这是别名的写法,我们下面的sql语句就可以用temp来代替这个结果集。当然这个()里面可以是你自己的复杂查询出来的结果集也行

第一变性开始,把这个变成有树形结构的

怎么才能变形成树结构了,大家马上想到,加一个pid,和id才行哟,这里没有,我们就给他们加上吧。不过,加了id,怎么来填他们的结构数据呢,这里需要另一个函数显圣了 lag() , lag() 是取前记录, 和lead相对, 如果是简单的拼的话,树结构不就是,上一条记录就是下一条记录的父节点了么

这样我们用rownum,不就.... OK了
action
select t.name, no, lag(no) over(order by no) pid from (select temp.*, rownum no from temp) t;
结果出来了
NAME NO PID
-------------------- ---------- ----------
深圳 1
武汉 2 1
上海 3 2
北京 4 3
天津 5 4
新加坡 6 5
现在就是个树形了吧。
再变树
action
select * from (select t.name, no, lag(no) over(order by no) pid from (select temp.*, rownum no from temp)) t start with pid is null connect by prior no=pid;
看看结果吧
结果出来了
NAME NO PID
-------------------- ---------- ----------
深圳 1
武汉 2 1
上海 3 2
北京 4 3
天津 5 4
新加坡 6 5
奇怪结果没有变哟,是的,这里只是把树给选出来了,你如果加个lpad(' ', 4*level, '*')||name就可以看出端倪了
最后一变,拼成串
select sys_connect_by_path(name. ',') text from (select t.name, no, lag(no) over(order by no) pid from (select temp.*, rownum no from temp)) t start with pid is null connect by prior no=pid;
你们自己看结果吧。
Text
--------------------------------------------------
深圳,武汉,上海,北京,天津,新加坡
......
呵呵呵,虽然是做出来来,但是就像上面说讲的,这里只是另类的喜悦,因为这个不是我以前看到的那个解决方案,不过是通过这个方法,有用到了强大的connect by已经分析函数over,仅是窃喜,
找寻工作还要继续,什么时候才很然给我拨开云雾找到你哟。

标签:oracle,sys_connect_by_path
0
投稿

猜你喜欢

  • 多级联动下拉选择框,动态获取下一级

    2008-09-04 10:34:00
  • 通过事务日志解决SQL Server常见四大故障(一)

    2009-03-25 13:46:00
  • 15个网页排版例子赏析

    2008-01-06 16:38:00
  • Oracle中查询本月星期5的所有日期列表的语句

    2012-07-11 16:13:21
  • CSS控制字体效果的思考

    2011-06-14 09:44:02
  • 防止表格或或div层被撑开的几种方法

    2008-01-01 15:33:00
  • ASPJPEG组件简要攻略之水印、缩略图和描边代码

    2008-12-17 12:08:00
  • javascript中css的float特殊写法

    2007-12-24 20:24:00
  • sqlserver中在指定数据库的所有表的所有列中搜索给定的值

    2011-09-30 11:27:38
  • 另外一种斜体的导航条

    2008-11-05 12:24:00
  • ajax xmlhttp getResponseHeader实例教程

    2009-02-04 10:46:00
  • javascript的正则表达式

    2010-07-27 12:29:00
  • FrontPage2002简明教程一:安装与界面

    2008-08-17 11:04:00
  • SQL Server数据库动态交叉表的参考示例

    2009-01-04 14:44:00
  • 求任意自然数内的素数

    2009-10-15 12:21:00
  • ASP显示当前在线人数统计代码

    2010-04-24 15:47:00
  • P3P 和 跨域 (cross-domain) cookie 访问(读取和设置)

    2011-04-02 10:42:00
  • sql存储过程获取汉字拼音头字母函数

    2011-11-03 16:58:05
  • IE6 iframe 横向滚动条问题

    2009-01-18 13:31:00
  • 阿里巴巴中秋节logo设计的艰辛曲折过程

    2008-09-11 17:15:00
  • asp之家 网络编程 m.aspxhome.com