[MSSQL] Funkcja jako parametr procedury

0

Cześć, mam jak dla mnie dziwny problem(MSSQL 2005 Express)

Jest wywołanie procedury:

execute procName @param1, dateadd(hh, 10, @dateTimeParam), @param3 output

Dostaję syntax error:
"Incorrect syntax near 'hh'."

O co mu chodzi?

0

Takie rzeczy tylko w Erze. Parametr przekazany do procedury musi być zmienną lub stałą zatem musisz zrobić w ten sposób:

DECLARE @data datetime;
SET @data = dateadd(hh, 10, @dateTimeParam);
EXECUTE procName @param1, @data, @param3 OUTPUT;
0

DECLARE
@date datetime,
@param3 varchar(32)

SET @date = dateadd(hh, 10, '2009-01-01')

EXECUTE procName
@param1 = 1,
@param2 = @date,
@param3 = @param3 OUTPUT

// łups nie zdążyłem :(

1 użytkowników online, w tym zalogowanych: 0, gości: 1