熟练使用mysql的replace替换函数

因为一个网站后台要写一个数据库替换的插件,所以去温习mysql函数。

如果是基于wordpress就好办了,因为有大量类似插件,但是由于是独立开发,所以只好自己写一个了。

从昨晚开始在runoob开始从头看mysql教程手册,今早三点醒来又开始看,到六点看完了。

函数比较简单,毋庸置疑,php中有str_replace与preg_replace等强大替换函数!

语法:replace(onject,search,replace)

常用更新,你可以加上where条件等

我们将上面的title内容里的that给替换成this

 UPDATE `posts` SET title=replace(title,'that','this')

注意mysql中字段及表名用``包括,这可不是单引号,是感叹号左边那个,要不会报错,用框架习惯了,刚我就给写错了

完成替换!

在搜索replace函数的时候,一篇作者有一个使用方法比较技巧,我给记下来。

他在插入数据库的时候,由于疏忽,有一列文字前面多了一个空格,于是有强迫症的他打算使用以下命令来给替换掉

UPDATE `example` SET `col`=replace(`col`,' ','') where col 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 ';

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值