2010-04-16 7 views
4

J'ai une colonne varchar (1000) déclarée comme champ qui contient tous les nombres, comme indiqué ci-dessous. Et je veux exécuter le script suivant. J'ai besoin que cela fonctionne s'il vous plaîtLa conversion a échoué lors de la conversion de la valeur varchar en type de données 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 

Répondre

6

On dirait que vous voulez utiliser 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 

Vous devez être très prudent sur l'injection SQL lors du codage de cette façon.

+0

Merci Austin pour la réponse rapide. Les codes postaux sont extraits d'une liste (multisélect vrai). – desi

+0

Salut Austin, désolé j'ai oublié de donner vote. Quand je reviens et je vois que votre réponse n'était pas dans ma liste. – desi

Questions connexes