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 如果是英文+空格+汉字,或者汉字+空格+英文,就看你自己的需求了。
具体,可以参考,我回答的关于半个汉字的问题。
http://expert.csdn.net/Expert/topic/1901/1901102.xml?temp=.3438379
标签:
sql
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 趁着过年的时候手搓了一个低代码框架
· 推荐一个DeepSeek 大模型的免费 API 项目!兼容OpenAI接口!