您好,欢迎来到意榕旅游网。
搜索
您的当前位置:首页关于sqlwhereidin转换成数据类型int时失败(转)

关于sqlwhereidin转换成数据类型int时失败(转)

来源:意榕旅游网
关于sqlwhereidin转换成数据类型int时失败(转)

有执⾏sql条件语句where id in(@参数)的时候,如果处理不当,就会出现问题:如下⾯这个存储过程:

alter proc Web_gettwtwgoldgameserverGoldSell@ID int as

declare @twgoldsellID nvarchar(1000)

select @twgoldsellID=twgoldsellID from twgoldgameserver where ID=@IDset @twgoldsellID=replace(@twgoldsellID,'|',',')

set @twgoldsellID=left(@twgoldsellID,len(@twgoldsellID)-1) select * from twgoldsell where ID in (@twgoldsellID)我们看上去好像没有什么问题,却在执⾏的时候报错:

消息 245,级别 16,状态 1,第 1 ⾏

在将 varchar 值 '813,1160,1219,1227,1232' 转换成数据类型 int 时失败。

其实此条语句在执⾏时,

select * from twgoldsell where ID in (@twgoldsellID)

执⾏的语句是:select * from twgoldsell where ID in ('813,1160,1219,1227,1232')这样执⾏当然出错,因为@twgoldsellID是⼀个字符串,现在是以参数的形式传递。解决办法:

select * from twgoldsell where ID in (@twgoldsellID)改为:

exec('select * from twgoldsell where ID in ('+@twgoldsellID+')')

记住:⼀定要加exec执⾏函数,不然会报如下错误:

消息 245,级别 16,状态 1,过程 Web_gettwtwgoldgameserverGoldSell,第 8 ⾏在将 varchar 值 '+@twgoldsellID+' 转换成数据类型 int 时失败。

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- yrrf.cn 版权所有

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务