600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > mysql in 数字类型_关于sql where id in 转换成数据类型 int 时失败

mysql in 数字类型_关于sql where id in 转换成数据类型 int 时失败

时间:2022-08-06 18:55:22

相关推荐

mysql in 数字类型_关于sql where id in 转换成数据类型 int 时失败

有执行sql条件语句where id in(@参数)的时候,如果处理不当,就会出现问题:

有执行sql条件语句where id in(@参数)的时候,如果处理不当,就会出现问题:

如下面这个存储过程:

alter proc Web_gettwtwgoldgameserverGoldSell

@ID int

as

declare @twgoldsellID nvarchar(1000)

select @twgoldsellID=twgoldsellID from twgoldgameserver where ID=@ID

set @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 时失败。

发布php中文网,转载请注明出处,感谢您的尊重!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。