sql >> Databáze >  >> RDS >> Sqlserver

Změňte CTE SELECT na uživatelem definovanou funkci s hodnotou tabulky

Odstraňte první ; a order by klauzule.

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. Jaký je nejlepší způsob předání parametrů SQLCommand?

  2. MySQL implementace tabulek do databáze

  3. Proč jsou skalární funkce SQL Serveru pomalejší?

  4. SQL Injection Prevention