IT猫扑网:您身边最放心的安全下载站! 最新更新|软件分类|软件专题|手机版|论坛转贴|软件发布

您当前所在位置: 首页数据库Oracle → oracle中使用SQL递归语句

oracle中使用SQL递归语句

时间:2015-06-28 00:00:00 来源:IT猫扑网 作者:网管联盟 我要评论(1)

  例子:

  pid  id

  a   b

  a   c

  a   e

  b   b1

  b   b2

  c   c1

  e   e1

  e   e3

  d   d1

  指定pid=a,选出

  a   b

  a   c

  a   e

  b   b1

  b   b2

  c   c1

  e   e1

  e   e3

  SQL语句:select   parent,child   from   test   start   with   pid='a'

  connect   by   prior   id=pid

  Oracle  SQL的递归查询:

  1、表机构

  SQL> desc comm_org_subjection

  Name  Null?    Type

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

  ORG_SUBJECTION_ID NOT NULL VARCHAR2(32)    子键

  ORG_ID      NOT NULL VARCHAR2(32)

  FATHER_ORG_ID     NOT NULL VARCHAR2(32)   父键

  LOCKED_IF   NOT NULL VARCHAR2(1)

  START_DATE  NOT NULL DATE

  END_DATE DATE

  EDITION_NAMEPLATE    NUMBER(8)

  CODE_AFFORD_IF VARCHAR2(1)

  CODE_AFFORD_ORG_ID      NOT NULL VARCHAR2(32)

  CODING_SHOW_ID NUMBER(8)

  BSFLAG   VARCHAR2(1)

  MODIFI_DATE    DATE

  CREATOR_ID     VARCHAR2(32)

  CREATE_DATE    DATE

  CREATOR  VARCHAR2(35)

  2、递归查找父结点 org_id为C6000000000001下的所有子结点:

  select * from comm_org_subjection a

  start with a.org_id='C6000000000001'

  connect by prior a.org_subjection_id=a.father_org_id

  3、递归查找子结点 org_id为C6000000000001下的所有父结点:

  select org_id from comm_org_subjection a

  start with a.org_id='C6000000000001'

  connect by prior a.father_org_id=a.org_subjection_id

关键词标签:oracle,SQL递归语句

相关阅读

文章评论
发表评论

热门文章 Oracle中使用alter table来增加,删除,修改列的语法 Oracle中使用alter table来增加,删除,修改列的语法 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 误删Oracle数据库实例的控制文件 误删Oracle数据库实例的控制文件 为UNIX服务器设置Oracle全文检索 为UNIX服务器设置Oracle全文检索

相关下载

    人气排行 oracle中使用SQL语句修改字段类型-oracle修改SQL语句案例 Oracle中使用alter table来增加,删除,修改列的语法 ORACLE SQL 判断字符串是否为数字的语句 ORACLE和SQL语法区别归纳(1) oracle grant 授权语句 ORACLE修改IP地址后如何能够使用 如何加速Oracle大批量数据处理 Oracle删除表的几种方法