SQL Server 2017新增:Translate 函数(实现批量替换)

SQL Server 2017新增 Translate 函数,可以实现批量替换。

语法如下:

TRANSLATE ( 输入字符串, 要替换的字符, 替换成的字符) 

也就是把输入字符串中的 要进行替换的字符,替换为其他字符。


比如,现在有个字符串: 123#456*789!/0,要把其中的# * ! / 替换掉,如果用replace函数来做:

declare @v varchar(100)

set @v = '123#456*789!/0'

select replace(replace(replace(replace(@v,'#',''),'*',''),'!',''),'/','')
/*
1234567890
*/
replace函数要连用4次,才能完成替换,虽然能实现,但写完代码后,看着也头晕了。。。


用translate函数实现,就很简单了:

declare @v varchar(100)

set @v = '123#456*789!/0'

select replace(trim(translate(@v,'#*!/','    ')),' ','')
/*
1234567890
*/
translate函数有个限制,就是第2个参数、第3个参数,必须包含相同的字符,否则会报错。

就上面这个例子来说,要替换 #*!/ 这4个字符,那么第3个参数就要输入4个字符,这里是输入4个空格,最后需要在进行1次替换。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值