zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    类的无参方法笔记
    类的无参预习内容
    类和对象
    洛谷 题解 P2010 【回文日期】
    洛谷 题解 CF711A 【Bus to Udayland】
    洛谷 题解 P2676 【超级书架】
    洛谷 题解 CF903B 【The Modcrab】
    洛谷 题解 P1585【魔法阵】
    HDU 2553【N皇后问题】
    一些函数
  • 原文地址:https://www.cnblogs.com/3Tai/p/3607956.html
Copyright © 2011-2022 走看看