愿所有的美好和期待都能如约而至

与 Oracle 的 CONNECT BY ... START WITH 等效的 PostgreSQL 语法是什么?

发布时间:  来源:互联网  作者:匿名  标签:connect-by error What is the equivalent PostgreSQL syntax to Oracle's C  热度:37.5℃

本文介绍了与 Oracle 的 CONNECT BY … START WITH 等效的 PostgreSQL 语法是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Oracle中,如果我有一个表定义为……

In Oracle, if I have a table defined as …

CREATE TABLE taxonomy
    (
    key NUMBER(11) NOT NULL CONSTRAINT taxPkey PRIMARY KEY,
    value VARCHAR2(255),
    taxHier NUMBER(11)
    );
ALTER TABLE
    taxonomy
ADD CONSTRAINT
    taxTaxFkey
FOREIGN KEY
    (taxHier)
REFERENCES
    tax(key);

有了这些值……

With these values …

key value   taxHier
0   zero    null
1   one     0
2   two     0
3   three   0
4   four    1
5   five    2
6   six     2

这个查询语法……

SELECT
     value
FROM
    taxonomy
CONNECT BY
    PRIOR key = taxHier
START WITH
    key = 0;

会产生……

zero
one
four
two
five
six
three

这在 PostgreSQL 中是如何完成的?

How is this done in PostgreSQL?

推荐答案

在 Postgres 中使用 RECURSIVE CTE:

Use a RECURSIVE CTE in Postgres:

WITH RECURSIVE cte AS (
   SELECT key, value, 1 AS level
   FROM   taxonomy
   WHERE  key = 0

   UNION  ALL
   SELECT t.key, t.value, c.level + 1
   FROM   cte      c
   JOIN   taxonomy t ON t.taxHier = c.key
   )
SELECT value
FROM   cte
ORDER  BY level;

我之前回答中的详细信息和文档链接:

Details and links to documentation in my previous answer:

  • PostgreSQL 是否有像LEVEL”这样的伪列?在 Oracle 中?

这篇关于与 Oracle 的 CONNECT BY … START WITH 等效的 PostgreSQL 语法是什么?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,

勇敢去编程!

勇敢的热爱编程,未来的你一定会大放异彩,未来的生活一定会因编程更好!

TOP