mysql父子关系递归_oracle一条语句递归查询父子关系

1  建表:

CREATE TABLE test_tree (

test_id   INT  NOT NULL,

pid       INT,

test_val  VARCHAR(10),

PRIMARY KEY (test_id)

);

INSERT INTO test_tree VALUES(1, 0,   '.NET');

INSERT INTO test_tree VALUES(2, 1,      'C#');

INSERT INTO test_tree VALUES(3, 1,      'J#');

INSERT INTO test_tree VALUES(4, 1,      'ASP.NET');

INSERT INTO test_tree VALUES(5, 1,      'VB.NET');

INSERT INTO test_tree VALUES(6, 0,   'J2EE');

INSERT INTO test_tree VALUES(7, 6,      'EJB');

INSERT INTO test_tree VALUES(8, 6,      'Servlet');

INSERT INTO test_tree VALUES(9, 6,      'JSP');

INSERT INTO test_tree VALUES(10, 0,  'Database');

INSERT INTO test_tree VALUES(11, 10,    'DB2');

INSERT INTO test_tree VALUES(12, 10,    'MySQL');

INSERT INTO test_tree VALUES(13, 10,    'Oracle');

INSERT INTO test_tree VALUES(14, 10,    'SQL Server');

INSERT INTO test_tree VALUES(15, 13,    'PL/SQL');

INSERT INTO test_tree VALUES(16, 15,    'Function');

INSERT INTO test_tree VALUES(17, 15,    'Procedure');

INSERT INTO test_tree VALUES(18, 15,    'Package');

INSERT INTO test_tree VALUES(19, 15,    'Cursor');

INSERT INTO test_tree VALUES(20, 14,    'T-SQL');

使用 STARTWITH  CONNECT BY 语句实现树状查询

使用 SYS_CONNECT_BY_PATH  函数,获取节点的全路径.

COLUMN "FullPath"

2:查询语句

SELECT

LEVEL,

test_id,

test_val,

SYS_CONNECT_BY_PATH(test_val, '\') AS "FullPath"

FROM

test_tree

START WITH

pid =0

CONNECT BY PRIOR test_id = pid

ORDER SIBLINGS BY test_val;

结果:

LEVEL    TEST_ID TEST_VAL             FullPath

---------- ---------- -------------------- -----------------------------------

1          1 .NET                 \.NET

2          4 ASP.NET              \.NET\ASP.NET

2          2 C#                   \.NET\C#

2          3 J#                   \.NET\J#

2          5 VB.NET               \.NET\VB.NET

1         10 Database             \Database

2         11 DB2                  \Database\DB2

2         12 MySQL                \Database\MySQL

2         13 Oracle               \Database\Oracle

3         15 PL/SQL               \Database\Oracle\PL/SQL

4         19 Cursor               \Database\Oracle\PL/SQL\Cursor

LEVEL    TEST_ID TEST_VAL             FullPath

---------- ---------- -------------------- -----------------------------------

4         16 Function             \Database\Oracle\PL/SQL\Function

4         18 Package              \Database\Oracle\PL/SQL\Package

4         17 Procedure            \Database\Oracle\PL/SQL\Procedure

2         14 SQL Server           \Database\SQL Server

3         20 T-SQL                \Database\SQL Server\T-SQL

1          6 J2EE                 \J2EE

2          7 EJB                  \J2EE\EJB

2          9 JSP                  \J2EE\JSP

2          8 Servlet              \J2EE\Servlet

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值