sql - Oracle SQL 中的 START WITH 和 CONNECT BY

标签 sql oracle

我有如下表

帐号

CUSTOMER_ID   PAYING_ACCOUNT_ID   PARENT_ACCOUNT_ID     ACCOUNT_ID   COMPANY_ID 
24669         24669               24669                 24669        0 
24671         24671               24669                 24671        0  
24670         24670               24669                 24670        0 
3385217       3385217             24670                 3385217      0 
158           158                 158                   158          0
159           159                 158                   159          0
160           160                 159                   160          0
161           161                 160                   161          0 
162           162                 160                   162          0
180           180                 180                   180          0 

这是 DDL
CREATE TABLE "SYSTEM"."ACCOUNT"
("CUSTOMER_ID"       NUMBER(20,0) NOT NULL ENABLE,
"PAYING_ACCOUNT_ID" NUMBER(20,0),
"PARENT_ACCOUNT_ID" NUMBER(20,0),
"ACCOUNT_ID"        NUMBER,
"COMPANY_ID"        NUMBER)

这是我的查询
   select  lpad(' ', 2*level) || A.ACCOUNT_ID AS LEVEL_LABEL, 
           LEVEL, 
          A.* 
      from ACCOUNT A 
start with PARENT_ACCOUNT_ID IN 
                       (select PARENT_ACCOUNT_ID 
                          from ACCOUNT 
                         where ACCOUNT_ID IN 
                                        (select PARENT_ACCOUNT_ID
                                           from ACCOUNT 
                                          where parent_account_id != account_id)
                                            and ACCOUNT_ID = PARENT_ACCOUNT_ID) 
   CONNECT BY NOCYCLE  PRIOR A.ACCOUNT_ID = A.PARENT_ACCOUNT_ID;

查询的主要目的是选择具有层次关系的数据,即PARENT_ACCOUNT_ID & ACCOUNT_ID,但是我得到了查询返回的重复数据

任何建议非常感谢。谢谢

最佳答案

为什么不简单:

 SELECT level, * FROM accounts
 START WITH parent_account_id = account_id
 CONNECT BY PRIOR account_id = parent_account_id
         AND account_id <> parent_account_id

?

关于sql - Oracle SQL 中的 START WITH 和 CONNECT BY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9257756/

相关文章:

mysql - mysql 和 oracle sql 方言之间的主要区别是什么?

.net - Managed Oracle ODP.NET 驱动程序是否使用网络加密?

SQL:在单个字段中包含多个值的嵌套 SELECT

sql - 使用 Google Cloud SQL 的 Maven GAE 插件

java - 多语言查询中的正则表达式不适用于应用程序,但适用于 SQL 开发人员和单元测试

mysql - 使用 JDBC 对数据进行分组

php - 如何从多个表中获取多个计数?

java - 如何为 Oracle CHAR 字段设置 JDBCPreparedStatement 参数?

oracle - PL/SQL 函数值的间隔精度

sql - 选择优先级最高的行