sql >> Database >  >> RDS >> Oracle

Oracle SQL maakt verschillende gegevensniveaus uit een enkele tabel

U kunt een recursieve CTE gebruiken:

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. Hoe werkt bevat() in PL-SQL?

  2. Vind alle niet-numerieke waarden in een kolom in Oracle

  3. SQL Server 2008 - HashBytes berekende kolom

  4. Hoe kan ik een zoekopdracht detecteren die de vergrendeling in Postgres bevat?