SQL在将 varchar/nvarchar 值 ‘8480,8481‘ 转换成数据类型 int 时失败。

在一次存储过程编写过程中,因为需要一次性查询多个Id值,则声明变量为varchar,但在执行过程中却出现转换int失败提示。

错误写法:

DECLARE @BalanceId nvarchar(200)
set @BalanceId = '8480,8481'
select * from tLawyerBalance where Id in (@BalanceId)

结果就发生了报错,错误提示如下:

通过多方查找,找到方法,可以使用charindex结合ltrim解决该问题,如下:


DECLARE @BalanceId nvarchar(200)
set @BalanceId = '8480,8481'
select * from tLawyerBalance where charindex(','+ltrim(Id)+',',','+@BalanceId+',')>0

将原来的SQL中where条件改为:
charindex(','+ltrim(Id)+',',','+@BalanceId+',')>0

希望能帮到各位小伙伴。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值