Oracle中SYS_CONNECT_BY_PATH函数的妙用

数据库 Oracle
在Oracle中,SYS_CONNECT_BY_PATH函数主要作用是可以把一个父节点下的所有子节点通过某个字符进行区分,然后连接在一个列中显示。

Oracle中SYS_CONNECT_BY_PATH函数是非常重要的函数,下面就为您介绍一个使用SYS_CONNECT_BY_PATH函数的例子,实例如下:

  1. create table test (a varchar2(10),b varchar2(10));  
  2.  
  3. INSERT INTO TEST (A, B) VALUES ('1', '我');  
  4. INSERT INTO TEST (A, B) VALUES ('1', '们');  
  5. INSERT INTO TEST (A, B) VALUES ('2', '一');  
  6. INSERT INTO TEST (A, B) VALUES ('2', '起');  
  7. COMMIT;  
  8.  
  9. SELECT A, B FROM TEST  
  10.  
  11. A          B  
  12. ---------- ----------  
  13. 1          我  
  14. 1          们  
  15. 2          一  
  16. 2          起  
  17.  
  18. 现在需要达到如下的效果,  
  19. A          B  
  20. ---------- ----------  
  21. 1          我,们  
  22. 2          一,起  
  23.  

只想用一句sql来返回结果。

  1. SELECT A, LTRIM(MAX(SYS_CONNECT_BY_PATH(B, ',')), ',') B  
  2. FROM (SELECT B, A, ROW_NUMBER() OVER(PARTITION BY A ORDER BY B DESC) RN  
  3.           FROM TEST)  
  4. START WITH RN = 1 
  5. CONNECT BY RN - 1 = PRIOR RN  
  6.        AND A = PRIOR A  
  7. GROUP BY A; 

其中,SYS_CONNECT_BY_PATH函数主要作用是可以把一个父节点下的所有子节点通过某个字符进行区分,然后连接在一个列中显示。

row_number函数的用途是非常广泛,这个函数的功能是为查询出来的每一行记录生成一个序号。生产序号的方法通过over()函数里面的语句来控制。
 

 

 

【编辑推荐】

Oracle to_char函数的使用

oracle函数返回表的实现

带您了解Oracle FBI索引

详解Oracle多种表连接方式

oracle中使用SQL递归语句的例子

责任编辑:段燃 来源: 互联网
相关推荐

2017-08-07 15:52:33

Oracleonnect by优化

2011-07-20 17:54:02

C++

2010-10-28 14:02:00

oracle conn

2017-05-03 09:40:43

HIVEcollectexplode

2010-04-01 09:34:06

Oracle函数

2010-09-10 15:16:51

CSSdisplay

2020-10-27 07:37:07

Python

2011-04-08 15:50:54

Oracleover函数

2010-09-08 15:16:46

clearCSS

2010-09-09 16:54:05

CSSclear

2009-06-03 09:01:41

微软Windows 7操作系统

2022-08-03 08:11:58

数据测试同类型

2022-02-17 20:34:12

Python短路机制开发

2015-09-07 17:06:40

Swapfile.sy虚拟内存Windows

2019-08-29 07:13:50

oracle数据库主键

2013-07-01 15:06:04

2024-02-23 18:04:37

C++const关键字

2009-09-03 13:50:22

ToString(st

2021-10-20 07:36:03

Python构造方法

2010-08-30 16:02:06

CSSclear
点赞
收藏

51CTO技术栈公众号