将 varchar 值转换为数据类型 int 时转换失败

2024-03-29

我有一个 varchar(1000) 列声明为包含所有数字的字段,如下所示。 我想执行以下脚本。我需要这个才能工作

Declare @PostalCode varchar(1000)=0
    set @PostalCode ='7005036,7004168,7002314,7001188,6998955'

Select hl.* From CountryLocation cl
INNER JOIN refPostalCodes pc ON pc.PostalCode = hl.PostalCode
where pc.Postalcode in (@PostalCode) and pc.notDeleted = 1

看起来你想使用sp_executesql http://msdn.microsoft.com/en-us/library/aa933299(SQL.80).aspx:

Declare @PostalCode varchar(1000)=0
    set @PostalCode ='7005036,7004168,7002314,7001188,6998955'

declare @sql nvarchar(4000)  //didn't count the chars...

select @sql = N'Select hl.* From CountryLocation cl
INNER JOIN refPostalCodes pc ON pc.PostalCode = hl.PostalCode
where pc.Postalcode in (' + @PostalCode + ') and pc.notDeleted = 1'

exec sp_executesql @sql

你需要成为非常小心关于以这种方式编码时的 SQL 注入。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

将 varchar 值转换为数据类型 int 时转换失败 的相关文章

随机推荐