>  기사  >  데이터 베이스  >  Oracle中的树查询与CASE查询

Oracle中的树查询与CASE查询

WBOY
WBOY원래의
2016-06-07 17:03:281037검색

当表具有层次结构数据时,通过使用层次查询可以更直观的显示数据结果,并显示其数据之间的层次关系。如下查询例子:

当表具有层次结构数据时,通过使用层次查询可以更直观的显示数据结果,并显示其数据之间的层次关系。如下查询例子:

select lpad(' ',3*(t2.grl_grouplevel-1))||t1.cif_namecn from cb_cst_inf t1,cs_group_rel t2 where t1.cif_cstno=t2.grl_cstid 
 start with t2.grl_cstid ='CB10001810' and t2.grl_groupid='10002135'
 connect by prior t2.grl_cstid = t2.grl_uplevelid;
--cs_group_rel表中grl_uplevelid字段体现层次关系,,最上级grl_uplevelid为空
--START WITH :用于指定层次查询的跟行
--CONNECT BY :用于指定父行和子行之间的关系,在这个条件中必须使用PRIOR引用父行,语法如下:...PRIOR expr=expr 或 ...expr=PRIOR expr

 

CASE查询:
select lpad(' ',5*(t2.grl_grouplevel-1))||t1.cif_namecn name,
 case when t2.grl_grouplevel='1' then '总公司'
      when t2.grl_grouplevel='2' then '一级分公司'
 else '一级以下分公司' end level_name  from cb_cst_inf t1,cs_group_rel t2 where t1.cif_cstno=t2.grl_cstid  --and t1.cif_cstno='CB10001810'
 start with t2.grl_uplevelid is null and t2.grl_groupid='10002024'
 connect by prior t2.grl_cstid = t2.grl_uplevelid;

linux

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.