sql 存储过程 出现 需要声明标量变量@r

BEGINDECLARE@sqlCommandNVARCHAR(1000)DECLARE@ResultINT/******变量:返回结果******/SET@sqlCom... BEGIN

DECLARE @sqlCommand NVARCHAR(1000)
DECLARE @Result INT /****** 变量:返回结果 ******/

SET @sqlCommand = 'SELECT @r = ' + @ApproverDepartment +' From WorkFlow_OA_Rights WHERE 所属公司 = ' + CONVERT(NVARCHAR(10),@ApproverBranchKey)
select @sqlCommand

EXEC sp_executesql @sqlCommand, N'@r int output ' ,@Result output

/****** 判断是否找到审批人 ******/
IF @Result > 0
BEGIN
SET @ApproverKey = @Result
END
ELSE
BEGIN
RAISERROR('获取审批人失败!',16,1)
RETURN -1
END
END
展开
 我来答
WHITE_WIN
2013-03-19 · TA获得超过6111个赞
知道大有可为答主
回答量:3759
采纳率:50%
帮助的人:1877万
展开全部
如果@ApproverDepartment是字符型,而且值为数字(如'9'),则该语句没有任何错误

你可以把select @sqlCommand的输出结果拷贝上来,一起看一下。
szm341
2013-03-19 · TA获得超过6726个赞
知道大有可为答主
回答量:5005
采纳率:100%
帮助的人:5108万
展开全部
两个问题,1、@ApproverDepartment这个参数值是列名吗
2、@ApproverBranchKey这个参数最好用传参的形式而不要拼接,你要拼接的话还要单独拼接单引号
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式