Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Suppression de données hiérarchiques dans la table SQL

Sur SQL Server :utilisez une requête récursive. Étant donné CREATE TABLE tmp(Id int, Parent int), utilisez

WITH x(Id) AS (
    SELECT @Id
    UNION ALL
    SELECT tmp.Id
      FROM tmp
      JOIN x ON tmp.Parent = x.Id
)
DELETE tmp
  FROM x
  JOIN tmp ON tmp.Id = x.Id