标签:
于是我採用cast()函数将DLSJB这个整型变量转换成字符串,这样问题就攻克了。
正确代码例如以下所看到的:
ALTER PROCEDURE [dbo].[Proc_SH_WXJDList] @DH varchar(50), --单号 @DLSJB int, --代理商级别ID @DLSName varchar(100) --代理商姓名 AS BEGIN Declare @sqlStr varchar(800) --存储sql语句 Set @sqlStr = 'SELECT * FROM View_DLS_WXJD_Customer WHERE 1=1' --合成sql语句,不输入条件则选择所有 if(@DH!='') --推断是写单号 set @sqlStr = @sqlStr + ' and DH like ''%' + @DH + '%''' if(@DLSJB!= -1 ) --推断是否选择代理商级别 set @sqlStr = @sqlStr + ' and JBID ='+''''+cast(@DLSJB as varchar(5))+'''' if(@DLSName!='') --推断是否选择代理商名 set @sqlStr = @sqlStr + ' and DLSName like ''%' + @DLSName + '%''' EXEC (@sqlStr + 'ORDER BY DH DESC') END
佩特来项目经验小集合(2)___组合查询存储过程,报错 "varchar JBID='' 转换成数据类型 int 时失败"
标签:
原文地址:http://www.cnblogs.com/mengfanrong/p/5215173.html