SQL存储过程 必须声明标量变量问题 数据库中执行成功,但是当我用程序调用存储过程时提示“必须声明标量”

ALTER procedure [dbo].[InsertIntoff]
(
@tablename nvarchar(50) ,
@caname nvarchar(200) ,
@firsturl nvarchar(200) ,
@num int ,
@secondurl nvarchar(200) ,
@fromurl nvarchar(200) ,
@flg nvarchar(50)
)
as
exec('insert into ' +@tablename+ ' values(@caname,@firsturl,@num,@secondurl,@fromurl,@flg)')

第1个回答  2011-09-24
exec('insert into ' +@tablename+ ' values(@caname,@firsturl,@num,@secondurl,@fromurl,@flg)')
修改一下:
exec('insert into ' +@tablename+ ' values('+@caname+ ','+@firsturl+ ','+@num+ ','+@secondurl+ ','+@fromurl+ ','+@flg+ ')')追问

我像你这么写了,但是还是异常。异常 内容:过程或函数 'InsertIntoff' 需要参数 '@caname',但未提供该参数。

本回答被网友采纳
第2个回答  2011-09-25

因为exec() 相当于调用另一个存储过程,
在另一个存储过程中,你没有声明变量 @totalCount
第3个回答  2011-09-28
sp_executesql [ @statement = ] statement
[
{ , [ @params = ] N'@parameter_name data_type [ OUT | OUTPUT ][ ,...n ]' }
{ , [ @param1 = ] 'value1' [ ,...n ] }
]

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网