Suppose you want for demonstration purposes TOP 3 schema_id FROM sys.objects ORDER BY object_id.
Declare @Var1 as int;
Declare @Var2 as int;
Declare @Var3 as int;
WITH T AS
(
SELECT *,
ROW_NUMBER() OVER (ORDER BY object_id) RN
FROM sys.objects
)
SELECT @Var1 = MAX(CASE WHEN RN = 1 THEN schema_id END),
@Var2 = MAX(CASE WHEN RN = 2 THEN schema_id END),
@Var3 = MAX(CASE WHEN RN = 3 THEN schema_id END)
FROM T
WHERE RN <= 3;
SELECT @Var1, @Var2, @Var3
It uses ROW_NUMBERfor line numbers, then combines them into a single line result, which is used when assigning to variables.
source
share