SQL 删除表字段中所有的空格

源地址:http://bbs.csdn.net/topics/30322040


Sample表中有一个Name字段,目前当中有很多记录含有空格,如:“ 张 学 友 ”,如何用SQL语句将这些空格删掉,而变成“张学友”?

我想SQL语句应该有如下分解动作:
(1)将表中含有空格的记录找出来;
(2)去掉空格。不管空格在哪个位置,也不管空格有多少,全部去掉;
(3)将去掉空格后的记录更新会原表。

请给出详细语句及步骤。


select * from yourtable where charindex(' ',name)>0 and ascii(ltrim(name))>127
update yourtable set name=replace(name,' ','') where charindex(' ',name)>0 and ascii(ltrim(name))>127

解决方案,做一个函数(SQL Server 2K才支持,7.0以前,只能用存储过程),算法描述如下:
1 一个一个截取出来,汉字和英文字符的ascii码不一样。汉字有两个字节组成,并且都是>127。这是判断同英文字符的差别
2 如果是汉字,中间的空格就丢弃掉
3 如果是英文+空格+汉字,或者汉字+空格+英文,就看你自己的需求了。
具体,可以参考,我回答的关于半个汉字的问题。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值