sql >> Database teknologi >  >> RDS >> Oracle

Oracle SQL skaber forskellige niveauer af data fra en enkelt tabel

Du kan bruge en rekursiv CTE:

WITH CTE(ITEM_VALUE, ITEM_ABOVE, DESCRIPTION, ITEM_GROUP) AS 
(
   SELECT ITEM_VALUE, ITEM_ABOVE, DESCRIPTION, DESCRIPTION AS ITEM_GROUP
   FROM mytable
   WHERE ITEM_ABOVE = 'CAR'

   UNION ALL

   SELECT t1.ITEM_VALUE, t1.ITEM_ABOVE, t1.DESCRIPTION, t2.ITEM_GROUP
   FROM mytable t1
   JOIN CTE t2 ON t1.ITEM_ABOVE = t2.ITEM_VALUE
)
SELECT ITEM_VALUE, ITEM_ABOVE, DESCRIPTION, ITEM_GROUP
FROM CTE 



  1. Forespørgsel for at hente alle rækker fra forrige måned

  2. MySQL Fjerner duplikerede kolonner på Left Join, 3 tabeller

  3. Flere INSERTS i en tabel og mange til mange tabeller

  4. MySQL vs MongoDB 1000 læser