如何将NVARCHAR逗号分隔列表转换为INT? [英] How to convert NVARCHAR comma-delimited list to INT?
本文介绍了如何将NVARCHAR逗号分隔列表转换为INT?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
选择 id,名称来自 MyCylenderMaster 其中 id ( @ ids )
以上查询我收到错误输入字符串格式不正确因为id的数据类型为int而@ids的数据类型为nvarchar(max),我的@ids值为喜欢
@ ids = 1,2,3,4,5 .......
有什么方法可以解决这个问题。
解决方案
见这里:在SQL IN子句中使用逗号分隔值参数字符串 [ ^ ]
根据您的要求,您无需将逗号分隔的列表转换为但是你可以动态地将你的列 id 转换为nvarchar。
和你的问题一样,你可以使用EXEC()函数:
EXEC('选择ID,来自MyCylenderMaster的名称,其中id为('+ @ ids +')')
OR CHARINDEX()函数如:
CHARINDEX(CONVERT(nvarchar,id),@ ids,0)> 0
select id,name from MyCylenderMaster where id in (@ids)
in above query i got error Input string was not in correct format because the id has datatype int and @ids has datatype nvarchar(max), my @ids values are like
@ids=1,2,3,4,5.......
is there any way to sove that problem.
解决方案
See here: Using comma separated value parameter strings in SQL IN clauses[^]
As your requirement, you don't need to convert your comma-delimited list to int but convert your column id to nvarchar on the fly.
And as your problem, you can use EXEC() function:
EXEC('select id,name from MyCylenderMaster where id in ('+@ids+')')
OR CHARINDEX() function like:
CHARINDEX(CONVERT(nvarchar,id),@ids,0) > 0
这篇关于如何将NVARCHAR逗号分隔列表转换为INT?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文