设为首页 加入收藏

TOP

oracle树形sql查询实例分析
2014-11-24 02:25:01 来源: 作者: 【 】 浏览:0
Tags:oracle 树形 sql 查询 实例分析
oracle树形sql查询实例分析
通过此SQL语句
[sql]
select * from tree
查看原始数据如下:

我们要想得到如下的一个树形查询结果如下图所示
(包含 ROOT, LEVEL, IS_LEAF, PATH 四个字段):

可执行如下SQL语句:
[sql]
select connect_by_root(child_col) root, level ,
decode(connect_by_isleaf,0,'No',1,'Yes') is_leaf, sys_connect_by_path(child_col,'/') path
from tree www.2cto.com
start with parent_col is null connect by prior child_col=parent_col;
[sql]
树形查询的重点在于 start with ... connect by prior .... 语句
[sql]
以及 connect_by_root ,connect_by_isleaf,sys_connect_by_path这三个函数,
decode是一般常用的函数。
其他参考:http://www.2cto.com/database/201205/131485. html
动态查询语句例子:
[sql]
declare
n_rows number;
v_sql_stmt varchar2(50);
v_table_name varchar2(20);
v_name varchar2(20);
begin www.2cto.com
v_table_name := 'tree';
v_sql_stmt := 'select count(*) from ' || v_table_name || ' where parent_col = :1';
v_name := 'asia';
dbms_output.put_line(v_sql_stmt);
execute immediate v_sql_stmt into n_rows using v_name;
dbms_output.put_line('The number of rows of' || v_table_name || 'is ' || n_rows);
end;

摘自 蓝色诱惑的专栏
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇oracle树形结构相关查询 下一篇oracle取树形结构的数据,一条sql

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: