Oracle、postgresql递归语法

目录

简介

测试数据

ORACLE

postgresql

关键字解析

Oracle递归查询中的关键字

PostgreSQL递归查询中的关键字

简介

        现在很多业务场景都禁止使用游标,游标对于性能的影响较大。但是特殊场景仍然需要,对于向java,python等编程语言,游标更是普遍,学习了解一下游标,便于能看懂屎山代码。

测试数据

CREATE TABLE employees (
  employee_id INT PRIMARY KEY,
  last_name VARCHAR(100),
  manager_id INT
);

INSERT INTO employees VALUES (1, 'CEO', NULL);
INSERT INTO employees VALUES (2, 'Manager A', 1);
INSERT INTO employees VALUES (3, 'Manager B', 1);
INSERT INTO employees VALUES (4, 'Employee A', 2);
INSERT INTO employees VALUES (5, 'Employee B', 2);
INSERT INTO employees VALUES (6, 'Employee C', 3);

ORACLE

在数据库中,递归查询是一种特殊的查询,它可以用来查询具有层次结构的数据,例如员工和他们的经理之间的关系,或者目录和子目录之间的关系。在Oracle和PostgreSQL中,我们可以使用WITH RECURSIVE语句来执行递归查询。

SELECT employee_id, last_name, manager_id 
FROM employees where 
START WITH manager_id IS NULL
CONNECT BY PRIOR employee_id = manager_id;

postgresql

WITH RECURSIVE employee_recursive AS (
  SELECT employee_id, last_name, manager_id
  FROM employees
  WHERE manager_id IS NULL
  UNION ALL
  SELECT e.employee_id, e.last_name, e.manager_id
  FROM employees e
  INNER JOIN employee_recursive er ON er.employee_id = e.manager_id
)
SELECT * FROM employee_recursive;

        在这个查询中,WITH RECURSIVE子句定义了一个递归查询。这个查询由两部分组成,第一部分是基础查询,它定义了递归查询的起点。第二部分是递归查询,它定义了父记录和子记录之间的关系。两部分通过UNION ALL操作符连接起来。


        递归查询是一种强大的工具,它可以用来查询具有层次结构的数据。在Oracle和PostgreSQL中,我们可以使用CONNECT BY语句和WITH RECURSIVE语句来执行递归查询。虽然这两种方法的语法有所不同,但它们的基本思想是相同的:定义一个起点,然后定义一个递归关系来遍历数据。

为了避免在递归过程中发生死循环,可以增加level关键字,对下转层级进行约束

oracle 

SELECT employee_id, last_name, manager_id,level 
FROM employees where level<=2
START WITH manager_id IS NULL
CONNECT BY PRIOR employee_id = manager_id;

postgresql 

WITH RECURSIVE employee_recursive AS (
  SELECT employee_id, last_name, manager_id, 1 AS level
  FROM employees
  WHERE manager_id IS NULL
  UNION ALL
  SELECT e.employee_id, e.last_name, e.manager_id, er.level + 1
  FROM employees e
  INNER JOIN employee_recursive er ON er.employee_id = e.manager_id
)
SELECT employee_id, last_name, manager_id, level
FROM employee_recursive where level<=2;

关键字解析

Oracle递归查询中的关键字

- LEVEL: 在Oracle中,LEVEL是一个伪列,它表示在层次查询中的深度级别。在CONNECT BY查询中,可以使用LEVEL来确定行在层次结构中的级别。例如,可以使用LEVEL来缩进层次结构的输出。

- PRIOR: PRIOR关键字用于在CONNECT BY子句中定义父记录和子记录之间的关系。PRIOR关键字可以让你引用上一级的行。

- CONNECT BY: CONNECT BY子句用于定义父记录和子记录之间的关系。

- START WITH: START WITH子句用于定义递归查询的起点。


PostgreSQL递归查询中的关键字

- WITH RECURSIVE: WITH RECURSIVE子句用于定义一个递归查询。这个查询由两部分组成,第一部分是基础查询,它定义了递归查询的起点。第二部分是递归查询,它定义了父记录和子记录之间的关系。

- UNION ALL: UNION ALL操作符用于连接基础查询和递归查询的结果。

在使用这些关键字时,需要注意的是,递归查询可能会导致无限循环,特别是当数据中存在循环引用时。因此,当编写递归查询时,需要确保有一个明确的退出条件。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值