一条语句将字段中的多个空格变成一个空格

这里先产生一些测试数据,前后中间都有多个空格:

DECLARE @test TABLE(stringVARCHAR(8000))

INSERT INTO @test(string)

SELECT N' 测试'UNIONALL

SELECT N' OK '

--第一步是将左右的空格去掉

--第二不是将空格替换成空格加特殊字符,这里我是用char(11)(可以看到这个字符基本上数据是不会使用的,当然大家可以选择自己的特殊字符)

--第三步是将特殊字符去掉

---结果就是各个字符中间只有一个空格了

SELECT REPLACE(

REPLACE(

REPLACE(

LTRIM(RTRIM(string))

,' ',' '+CHAR(11))--Changes 2 spacesto the OX model

,CHAR(11)+' ','')--Changes the XO model to nothing

,CHAR(11),'')AS NewString--Changes the remaining X's to nothing

FROM @test

WHERE CHARINDEX('',string)> 0

结果:

(2 row(s) affected)
NewString
-------------------------------------------------------------
做 个 测试
OK

(2 row(s) affected)

这种方法值得借鉴。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值