返回顶部
首页 > 资讯 > 数据库 >oracle 层次查询语句
  • 888
分享到

oracle 层次查询语句

2024-04-02 19:04:59 888人浏览 独家记忆
摘要

   oracle中层次查询语法:     select  ...     [level | connec

   oracle中层次查询语法:

     select  ...

     [level | connect_by_root |connect_by_isleaf |connect_by_iscycle ]

     from table_name

     [where] 

     connect by { prior col1=col2 | col1=prior col2 }

    [start with]

    [order [siblings] by];

connect by :说明每行数据将是按层次顺序检索,并规定将表中的数据连入树形结构的关系中。prior运算符必须放置在连接关系的两列中某一个的前面,对于子节点间的父子关系,prior运算符所在的一侧为父节点,另一侧的为子节点,从而确定查找树形结构的顺序是自顶向下还是自底向上。

start with:用于标识哪个节点作为查找树形结构的根节点,层次查询需要确定起始点,通过start with,后加条件。start with将确定将哪行作为root,如果不指定start with,则每行都当做root,然后查找其后代。start with后可以跟子查询,如果又where条件,则会截断层次中满足相关条件的节点,但不影响整个层次查询。

level:是一个伪列,代表当前这个节点所在的层级,对于根节点,level返回1,通过这个伪列结合其他oracle函数进行数据的格式化显示。

connect_by_root:connect_by_root必须和某个字段搭配使用,目的是获取根节点记录的字段信息。

connect_by_isleaf:判断当前结点是否为叶子节点,0表示非叶子节点,1表示是叶子节点。

connect_by_cycle:可以检查是否在树形查询的过程中构成循环,这个伪列只是在connect_by_cycle方式下有效。

order siblings by:定义返回时同意父节点下的各个兄弟节点之间的顺序。


例子:

--树形结构表emp;
select * from emp;
EMP_ID              EMP_NAME              UP_EMP_ID    
---------            ---------------         ---------------  
1              USER1              0         
2              USER2              1
3              USER3              1 
4              USER4              2
5              USER5              2
6              USER6              3
--从根节点emp_id=1开始,自顶向下查询出根节点的所有子节点
select  emp_id,emp_name,up_emp_id,level
from emp
start with emp_id=1
connect by prior emp_id=up_emp_id
order siblings by emp_id;
EMP_ID                EMP_NAME           UP_EMP_ID                        LEVEL
---------              ---------------      ---------------                    --------
1               USER1            0                       1
2               USER2            1                       2
4               USER4            2                       3
5               USER5            2                       3
3               USER3            1                       2
6               USER6            3                       3
--从emp_id=6,自底向上查询emp_id=6的所有父节点
select emp_id,emp_name,up_emp_id 
from  emp
start with emp_id=6
connect by emp_id = prior up_emp_id
order by  emp_id;
EMP_ID              EMP_NAME             UP_EMP_ID    
---------            ---------------        ---------------  
1              USER1             0
3              USER3             1
6              USER6             3


您可能感兴趣的文档:

--结束END--

本文标题: oracle 层次查询语句

本文链接: https://lsjlt.com/news/51995.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • oracle 层次查询语句
       Oracle中层次查询语法:     select  ...     [level | connec...
    99+
    2024-04-02
  • Oracle如何实现层次化查询
    小编给大家分享一下Oracle如何实现层次化查询,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Oracle层次化查询(1) 树状...
    99+
    2024-04-02
  • oracle常用查询语句
    杀会话,必须要时刻背上来:select 'alter system kill session ''' || sid|| ',' || serial# || ''' immediate;' fro...
    99+
    2024-04-02
  • oracle拼接查询语句
    拼接查询语句是一种将多个查询组合在一起形成一个复杂查询的语句。拼接查询可以通过 union 操作符(合并同结构数据)或连接操作符(合并相关数据)实现,例如: selec ...
    99+
    2024-05-11
    oracle
  • Oracle常用的查询语句
    SELECT * from user_views where view_name='v$session';SELECT * FROM ALL_USERS where us...
    99+
    2024-04-02
  • oracle查询实例名的语句
    要查询 oracle 实例名称,请执行以下步骤:使用 sql 语句:select instance_name from v$instance;instance_name 列存储...
    99+
    2024-05-11
    oracle
  • DQL查询语句
    排序查询 * 语法:order by 子句 * order by 排序字段1 排序方式1 , 排序字段2 排序方式2... * 排序方式: * ASC:升序,默认的。 * DESC:降序。 * 注意: * ...
    99+
    2019-10-15
    DQL查询语句
  • oracle with 语句实现递归查询
    Oracle with 语句可以实现如同connect by 语句一样的序列:connect by用法使用rownum实现1到10的序列。select rownum from&...
    99+
    2024-04-02
  • 条件语句与查询语句
    条件语句:到目前为止我们所使用的语句操作几乎都是对每一行都进行操作,那么能不能但对某一行,或者某几行进行操作呢?这个时候就需要使用到条件语句关键字WHERE,介绍一下关系运算符:>:大于<...
    99+
    2024-04-02
  • oracle查询、修改、删除、插入语句
    ( id int, xm varchar2(5), age varchar2(3) ) 内有数据格式 id xm age 1 ...
    99+
    2020-09-12
    oracle查询 修改 删除 插入语句
  • Sqlite—查询语句(Select)
    基本语法如下 sqlite> select * from tb_user; sqlite> select userid,username from tb_user; 格式化的查询输出 sqlite> .heade...
    99+
    2022-02-01
    Sqlite—查询语句(Select)
  • T-SQL查询语句
        SQL语言中最主要、最核心的部分是它的查询功能。查询语句用来对已经存在于数据库的数据按照特定的组合、条件表达式或次序进行检索,使用SELECT语句来完...
    99+
    2024-04-02
  • PHP查询语句怎么查询结果
    这篇“PHP查询语句怎么查询结果”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“PHP查询语句怎么查询结果”文章吧。一、连接数...
    99+
    2023-07-05
  • 怎么在Oracle中使用OVER查询语句
    本篇文章为大家展示了怎么在Oracle中使用OVER查询语句,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、rank()/dense_rank() over(pa...
    99+
    2024-04-02
  • oracle数据库查询语句怎么使用
    要使用Oracle数据库查询语句,您可以使用SQL语言编写查询语句,并在Oracle数据库管理系统中执行它们。以下是一个示例查询语句...
    99+
    2024-04-09
    oracle
  • SQLServer中怎么实现层次数据查询
    SQLServer中怎么实现层次数据查询,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。  SQLServer2000层次数据查询的实现方法...
    99+
    2024-04-02
  • 让MySQL中单句实现无限层次父子关系查询的方法
    这篇文章将为大家详细讲解有关让MySQL中单句实现无限层次父子关系查询的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在 SQL Server 中,使用 CTE 表达...
    99+
    2024-04-02
  • sql查询语句优化
    sql查询语句优化 1、对查询进行优化,应尽量避免全表扫描 a、 where 及 order by 涉及的列上建立索引 b、 尽量避免在 where 子句中对字段进行 null 值判断,可以将null值设置默认值0等,如...
    99+
    2016-05-19
    sql查询语句优化 数据库入门 数据库基础教程 数据库 mysql
  • 常用sql语句查询
    oracle常用经典SQL查询 常用SQL查询:   查看表空间的名称及大小   select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size from dba...
    99+
    2019-10-10
    常用sql语句查询 数据库入门 数据库基础教程 数据库 mysql
  • mysql查询语句优化
     这篇说下mysql查询语句优化 是否请求了不需要的数据 典型案例:查询不需要的记录,多表关联时返回全部列,总是取出全部列,重复查询相同的数据。 是否在扫描额外的记录 ...
    99+
    2022-05-11
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作