sql >> Databasteknik >  >> RDS >> Sqlserver

Ändra en CTE SELECT till en tabellvärde användardefinierad funktion

Ta bort den första ; och order by klausul.

Alter FUNCTION GetDescendentSteps 
(   
@StepId INT 
)
RETURNS TABLE 
AS
RETURN
    WITH cteRecursion
         AS (SELECT
                 StepId
                 ,1 AS Level
             FROM
                 Step
             WHERE
                 StepId = @StepId
             UNION ALL
             SELECT
                 t.StepId
                 ,c.Level + 1
             FROM
                 Step t
                 INNER JOIN cteRecursion c
                     ON t.ParentStepId = c.StepId
            )
    SELECT
        StepId,Level
    FROM
        cteRecursion



  1. SQLite-kommandon

  2. PostgreSQL:skrivskyddad tabell

  3. JDBC MySql-anslutningspoolning görs för att undvika uttömd anslutningspool

  4. mysqli multipla queries - set variabel ger booleskt fel/hur hoppar man över detta?