如何将NVARCHAR逗号分隔列表转换为INT? [英] How to convert NVARCHAR comma-delimited list to INT?

查看:65
本文介绍了如何将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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆