因为一个网站后台要写一个数据库替换的插件,所以去温习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 ';
————————————————
版权声明:本文为CSDN博主「myarche」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/myarche/article/details/84312787

Thomas2 年前
发表在:SQL Server2008报错:值不能为空[S35]
Thomas2 年前
发表在:解决Composer Installing dependencies from lock file你这都看不清了
1114 年前
发表在:Cetnos7 新手安装ZABBIX4.0.5详解教程有人嘛
Tyreunorm2020-08-27 22:51
发表在:php5.6 连接SQL SERVER<a href=https://mega...
耗子2020-04-08 15:02
发表在:写给正在创业的自己看到了,想写点。可能我开过这网站了,以后...
Thomas2019-11-19 19:57
发表在:twcms您的IP地址已改变,为了安全考虑,请重新登录这个好
酷喵2016-08-03 15:22
发表在:我家侄女成长记前排支持啦!
五爷2015-12-01 03:26
发表在:关于centos中的相关查看命令@admin:呵呵
admin2015-12-01 01:49
发表在:关于centos中的相关查看命令非常不错