Możesz użyć tabeli liczb, jeśli ją masz, użyj master.dbo.spt_values
jeśli chcesz taki, który ma wartości do 2048 r., lub stwórz własny. W takim przypadku możesz użyć master.dbo.spt_values
:
DECLARE @val AS INT=20, @val2 AS VARCHAR(50);
DECLARE @Date AS DATETIME = CONVERT(DATETIME,'02-05-2016');
SET @val2 = 'abc'
INSERT INTO dbo.YourTable
SELECT @val2, DATEADD(DAY,number,@Date)
FROM master.dbo.spt_values
WHERE type = 'P'
AND number <= @val;
Chociaż ponieważ zaczyna się od zera, w rezultacie otrzymasz 21 wierszy