• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL批量去掉某个字段中的空格
    POST TIME:2021-10-18 21:05

    Mysql有什么办法批量去掉某个字段字符中的空格?不仅是字符串前后的空格,还包含字符串中间的空格,答案是 replace,使用mysql自带的 replace 函数,另外还有个 trim 函数。

    (1)mysql replace 函数

    语法:replace(object,search,replace)

    意思:把object中出现search的全部替换为replace

    案例:清除news表中content字段中的空格 
    update `news` set `content`=replace(`content`,' ','');
    

    (2)mysql trim 函数

    语法:trim([{BOTH | LEADING | TRAILING} [remstr] FROM] str)

    以下举例说明:

    mysql> SELECT TRIM(' phpernote '); 
    -> 'phpernote' 
    mysql> SELECT TRIM(LEADING 'x' FROM 'xxxphpernotexxx'); 
    -> 'phpernotexxx' 
    mysql> SELECT TRIM(BOTH 'x' FROM 'xxxphpernotexxx'); 
    -> 'phpernote' 
    mysql> SELECT TRIM(TRAILING 'xyz' FROM 'phpernotexxyz'); 
    -> 'phpernotex' 
    

    MySQL数据库中插入数据的时候,由于疏忽,有一列文字有些行前面多了一个空格,出于强迫症以及避免以后可能出现问题,我决定把这个空格给干掉,在网上搜到的方法大多数是直接使用replace:

    UPDATE example
    SET col = replace(col, ' ', '')
    WHERE col replace '^ ';
    

    使用这种方法固然可以把行首的空格去掉,但是列中文字间用于分割词语的空格也会被去掉,一大片文字会连起来,故不可行。

    后来我想使用replace的时候能不能使用正则来匹配呢,几番搜索的结果是不可行。

    最后我想了一个我认为较为简单可行的方法:

    首先使用CONCAT()在有空格的行前面加一个字符‘x':

    UPDATE example
    SET col = CONCAT('x', col)
    WHERE col REGEXP '^ ';
    

    这样下来行前面多了两个字符 ‘x ‘。

    然后使用REPLACE来把多的两个字符一起去掉:

    UPDATE example
    SET col = REPLACE(col, 'x ', '')
    WHERE col REGEXP '^x ';

    总结

    以上就是本文关于MySQL批量去掉某个字段中的空格的全部内容,希望对大家有所帮助,感兴趣的朋友可以参阅:MySQL 声明变量及存储过程分析、几个比较重要的MySQL变量、mysql数据库开发规范【推荐】等。有什么问题可以随时留言,大家一起交流讨论。

    您可能感兴趣的文章:
    • mysql中使用replace替换某字段的部分内容
    • MySQL中replace into语句的用法详解
    • MYSQL的REPLACE和ON DUPLICATE KEY UPDATE语句介绍解决问题实例
    • MySQL的Replace into 与Insert into on duplicate key update真正的不同之处
    • MYSQL 批量替换之replace语法的使用详解
    上一篇:mysql数据库开发规范【推荐】
    下一篇:浅谈mysql的子查询联合与in的效率
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信