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

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/yupeigu/article/details/79194946

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

展开阅读全文

没有更多推荐了,返回首页