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次替换。