2010-04-16 214 views
4

我有一個聲明爲包含所有數字的字段的varchar(1000)列,如下所示。 我想執行下面的腳本。我需要這個工作,請將varchar值轉換爲數據類型時轉換失敗int

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 

回答

6

它看起來像你想使用sp_executesql

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注入。

+0

感謝奧斯汀的快速回答。 郵政編碼從列表框中提取(多選真)。 – desi 2010-04-16 16:11:26

+0

嗨奧斯汀,對不起,我忘了投票。當我回來時,我看到你的答案不在我的列表中。 – desi 2010-04-16 17:01:06

相關問題