Oracle
 sql >> база данни >  >> RDS >> Oracle

Как да извлека всички рекурсивни деца на родителския ред в Oracle SQL?

Вие сте близо:

select connect_by_root parent_id base, parent_id, child_id, qty
from md_boms
connect by prior child_id = parent_id
order by base, parent_id, child_id;

          BASE  PARENT_ID   CHILD_ID        QTY
    ---------- ---------- ---------- ----------
            25         25         26          1 
            25         25         27          2 
            25         26         28          1 
            25         26         29          1 
            25         26         30          2 
            25         27         31          1 
            25         27         32          1 
            25         27         33          2 
            26         26         28          1 
            26         26         29          1 
            26         26         30          2 
            27         27         31          1 
            27         27         32          1 
            27         27         33          2 

     14 rows selected 

connect_by_root оператор ви дава основния parent_id .

SQL Fiddle .

Не съм сигурен как изчислявате вашето qty . Предполагам, че искате общата сума за пътя до детето, но това не отговаря на това, което сте показали. Като отправна точка, тогава, заемете много силно от този отговор , можете да опитате нещо като:

with hierarchy as (
  select connect_by_root parent_id base, parent_id, child_id, qty,
    sys_connect_by_path(child_id, '/') as path
  from md_boms
  connect by prior child_id = parent_id
)
select h.base, h.parent_id, h.child_id, sum(e.qty)
from hierarchy h
join hierarchy e on h.path like e.path ||'%'
group by h.base, h.parent_id, h.child_id
order by h.base, h.parent_id, h.child_id;

     BASE  PARENT_ID   CHILD_ID SUM(E.QTY)
---------- ---------- ---------- ----------
        25         25         26          1 
        25         25         27          2 
        25         26         28          2 
        25         26         29          2 
        25         26         30          3 
        25         27         31          3 
        25         27         32          3 
        25         27         33          4 
        26         26         28          1 
        26         26         29          1 
        26         26         30          2 
        27         27         31          1 
        27         27         32          1 
        27         27         33          2 

 14 rows selected 


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Проблем с фокуса на Vista при извикване на проверка на правописа на Microsoft Word от Oracle Forms

  2. Как да използвам променлива от курсор в оператора select на друг курсор в pl/sql

  3. SQL заявка, Средно изкачване и двойка, която е изкачила най-много върхове

  4. Пример за израз на Oracle FOR LOOP SELECT

  5. Защо индексът NLSSORT не се използва за тази заявка?