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

2024-12-23 06:33:41
推荐回答(3个)
回答1:

exec('insert into ' +@tablename+ ' values(@caname,@firsturl,@num,@secondurl,@fromurl,@flg)')
修改一下:
exec('insert into ' +@tablename+ ' values('+@caname+ ','+@firsturl+ ','+@num+ ','+@secondurl+ ','+@fromurl+ ','+@flg+ ')')

回答2:


因为exec() 相当于调用另一个存储过程,
在另一个存储过程中,你没有声明变量 @totalCount

回答3:

sp_executesql [ @statement = ] statement
[
{ , [ @params = ] N'@parameter_name data_type [ OUT | OUTPUT ][ ,...n ]' }
{ , [ @param1 = ] 'value1' [ ,...n ] }
]