关于sql where id in 转换成数据类型 int 时失败
2010-05-21 15:54
465 查看
有执行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 时失败。
关于sql条件语句where id in (@参数)执行报错问题(转换成数据类型 int 时失败)解决完成,有什么问题,可以一起在技术社区(http://bbs.25yi.com)讨论。
作者: 网站设计@ 企业网站管理系统
原载: 25亿企业网站管理系统
如下面这个存储过程:
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 时失败。
关于sql条件语句where id in (@参数)执行报错问题(转换成数据类型 int 时失败)解决完成,有什么问题,可以一起在技术社区(http://bbs.25yi.com)讨论。
作者: 网站设计@ 企业网站管理系统
原载: 25亿企业网站管理系统
相关文章推荐
- 关于sql where id in 转换成数据类型 int 时失败
- 关于sql where id in 转换成数据类型 int 时失败
- 关于sql where id in 转换成数据类型 int 时失败(转)
- 关于sql条件语句where id in (@参数)执行报错问题(转换成数据类型 int 时失败)(
- 在将 varchar 值 'select * from soft where id=' 转换成数据类型 int 时失败
- 10月14日遇到的问题 在将 nvarchar 值 转换成数据类型 int 时失败。
- sqlserver 在将 nvarchar 值 'XXX' 转换成数据类型 int 时失败
- sql 在将 nvarchar 值 转换成数据类型 int 时失败。
- 在将varchar值转换成数据类型int时失败
- 在将 varchar 值 '' 转换成数据类型 int 时失败
- java关于float类型和int类型数据转换为字符串(吃软不吃硬)
- 在将 varchar 值 'System.Web.UI.WebControls.DataKey' 转换成数据类型 int 时失败。
- 在将 varchar 值 'xinpian' 转换成数据类型 int 时失败?
- 编写存储过程时,出现“转换成数据类型 int 时失败”错误的解决方法
- Sql 在将varchar值 '21,123,.. ' 转换成数据类型 int 时失败 的问题
- MSSQL 错误:在将 varchar 值 '1,2,3,5,6' 转换成数据类型 int 时失败。
- 佩特来项目经验小集合(2)___组合查询存储过程,报错 "varchar JBID='' 转换成数据类型 int 时失败"
- System.Data.SqlClient.SqlException 在将 varchar 值 'xxx' 转换成数据类型 int 时失败。
- varchar 值 '2123,2385,4516' 转换成数据类型 int 时失败
- 在将 varchar 值 '1,2,3,4,5,6,7,8' 转换成数据类型 int 时失败。