因为一个网站后台要写一个数据库替换的插件,所以去温习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 ';
版权声明:本文为myarche原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。