数据库

 首页 > 数据库 > Oracle > oracle树形sql查询实例分析

oracle树形sql查询实例分析

分享到:
【字体:
导读:
         摘要:oracle树形sql查询实例分析通过此SQL语句[sql]select*fromtree查看原始数据如下:我们要想得到如下的一个树形查询结果如下图所示(包含ROOT,LEVEL,IS_LEAF,PATH四个字段):可执行如下SQL语... SyntaxHighlighter.al...

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树形sql查询实例分析
分享到:
认识Oracle数据库System Global Area(SG...
认识Oracle数据库System Global Area(SGA)(1) 认识Oracle数据库System Global Area (SGA)(1)   1 概述   Oracle SGA区的监控和管理,是数据库日常维护的重要内容。本文详细介绍SGA的基本概念,SGA运行情况检查,以及SGA的参数设置原则,希望对大家的有所帮助。   2 SGA的基本概念   当启动Oracle数据库时,...
Oracle统计邮件域的语句
Oracle统计邮件域的语句 Oracle统计邮件域的语句   select substr(lower(t1.email),instr(t1.email,'@',-1))    DOMAIN,COUNT(distinct t1.email) from FEG_ISU.LOYALTY_MEMBER T1     where  T1.EMAIL IS NOT NULL  www.2cto.com    AND T1.EMAIL LIKE '%@%'    AND LENGTH(t1.EMAIL)=LE...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……