kavo

熟练使用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 ';

 

posted on 2018-11-21 08:40  下雨天唱情歌  阅读(6)  评论(0编辑  收藏  举报  来源

导航