的,这是我的存储过程:过程预计参数 '@params' 类型 '的ntext/NCHAR/nvarchar的'
ALTER PROCEDURE [dbo].[sp_Update_Projecttijden]
@tabelnaam NVARCHAR(30) ,
@starttijd DATETIME,
@eindtijd DATETIME,
@tijd FLOAT,
@startid INT,
@eindid INT
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for procedure here
-- DECLARE @DATEVARCHAR NVARCHAR(4000);
DECLARE @SQLCommand NVARCHAR(MAX) = N'
UPDATE ' + QUOTENAME(@tabelnaam) + N'
SET Start = @starttijd
, Einde = @eindtijd
, Tijd = @tijd
, StartID = @startid
, EindID = @eindid
WHERE StartID = @startid AND [email protected]';
EXECUTE dbo.sp_executesql @sqlCommand,
' N @starttijd DATETIME, @eindtijd DATETIME, @tijd FLOAT, @startid INT, @eindid INT'
, @starttijd
, @eindtijd
, @tijd
, @startid
, @eindid;
END
引发的错误是这样的:
消息214,级别16,状态3,过程sp_executesql,第3行过程 需要类型为'ntext/nchar/nvarchar'的参数'@params'。
我一直在寻找类似的问题/答案,但不能真正解决我的问题。 所有帮助非常感谢。
应考虑不使用以sp_前缀(甚至更好没有前缀的所有)。它可能会导致问题。 http://sqlperformance.com/2012/10/t-sql-queries/sp_prefix –