oracle 查询当前节点对应的根节点的id

在 Oracle 数据库中,如果你有一个层次结构的数据(例如,树形结构),你可以使用递归查询(也称为层次查询)来找到某个节点对应的根节点。Oracle 提供了一个名为 CONNECT BY 的子句来处理这种递归查询。

假设你有一个表 your_table,其中有一个列 id 表示节点的唯一标识符,另一个列 parent_id 表示父节点的标识符。根节点的 parent_id 通常是 NULL

以下是一个示例查询,它查找给定节点 current_node_id 对应的根节点的 id

sql 复制代码
WITH RECURSIVE_TREE AS (
    SELECT 
        id,
        parent_id,
        LEVEL,
        CONNECT_BY_ISLEAF AS is_leaf,
        CONNECT_BY_ROOT id AS root_id
    FROM 
        your_table
    START WITH 
        id = :current_node_id
    CONNECT BY 
        PRIOR id = parent_id
)
SELECT 
    root_id
FROM 
    RECURSIVE_TREE
WHERE 
    LEVEL = 1;

在这个查询中:

  • WITH RECURSIVE_TREE AS (...) 定义了一个递归的公用表表达式(CTE)。
  • SELECT ... FROM your_table START WITH id = :current_node_id 指定了递归查询的起点,即 current_node_id
  • CONNECT BY PRIOR id = parent_id 指定了递归关系,即当前行的 parent_id 等于上一行的 id
  • LEVEL 是 Oracle 提供的一个伪列,表示从根节点到当前节点的层级。
  • CONNECT_BY_ROOT id AS root_id 用于获取根节点的 id
  • 最后的 SELECT 语句从 CTE 中选择根节点的 id,条件是 LEVEL = 1,实际上在这个特定查询中,由于我们从 current_node_id 开始并向上递归,LEVEL = 1 的行就是根节点。

注意:

  • :current_node_id 是一个绑定变量,你需要将其替换为实际的节点 ID。
  • 如果你的 Oracle 版本较旧,不支持 CONNECT_BY_ROOTLEVEL 这样的伪列,你可能需要使用其他方式标记和检索根节点。

此外,如果你只需要找到根节点的 id 而不关心其他信息,可以简化查询:

sql 复制代码
SELECT 
    CONNECT_BY_ROOT id AS root_id
FROM 
    your_table
START WITH 
    id = :current_node_id
CONNECT BY 
    PRIOR id = parent_id
FETCH FIRST ROW ONLY;

这个简化的查询使用 FETCH FIRST ROW ONLY 来只获取根节点的 id

相关推荐
焱焱枫32 分钟前
自适应SQL计划管理(Adaptive SQL Plan Management)在Oracle 12c中的应用
数据库·sql·oracle
2301_7930698235 分钟前
Spring Boot +SQL项目优化策略,GraphQL和SQL 区别,Spring JDBC 等原理辨析(万字长文+代码)
java·数据库·spring boot·sql·jdbc·orm
hhw19911244 分钟前
spring boot知识点5
java·数据库·spring boot
ITPUB-微风1 小时前
功能开关聚合对象实践:提升金融领域的高可用性
网络·数据库·金融
去看日出1 小时前
Linux(centos)系统安装部署MySQL8.0数据库(GLIBC版本)
linux·数据库·centos
Hanyaoo2 小时前
为什么mvcc中?m_ids 列表并不等同于 min_trx_id 和 max_trx_id 之间的所有事务 ID
数据库
偏右右2 小时前
PL/SQL 异常处理
数据库·sql·oracle
利瑞华3 小时前
Redis 存在线程安全问题吗?为什么?
数据库·redis·安全
小金的学习笔记3 小时前
如何在本地和服务器新建Redis用户和密码
服务器·数据库·redis
听封3 小时前
Redis存在线程安全的问题吗?
数据库·redis·安全