通常我使用手动查找替换文本在MySQL数据库使用phpMyAdmin。我现在厌倦了,我怎么能运行一个查询,在phpMyAdmin的整个表中找到和替换一个新的文本?

例如:查找关键字domain。例如,替换为www.domain.example。


当前回答

这是一个如何在数据库中查找和替换的例子

 UPDATE TABLE_NAME
 SET COLUMN = replace(COLUMN,'domain.example', 'www.domain.example') 

TABLE_NAME =>修改为你的表名

COLUMN =>将其更改为您的列,确保它存在

其他回答

 UPDATE table SET field = replace(field, text_needs_to_be_replaced, text_required);

比如,如果我想把所有出现的约翰替换为马克,我会用下面的方法,

UPDATE student SET student_name = replace(student_name, 'John', 'Mark');

对于单个表更新

 UPDATE `table_name`
 SET `field_name` = replace(same_field_name, 'unwanted_text', 'wanted_text')

从多个表-

如果您希望从所有表中进行编辑,最好的方法是获取转储,然后查找/替换并上传回来。

生成变更SQL查询(FAST)

mysql -e "SELECT CONCAT('update ', table_name,' set ', column_name,' = replace(', column_name,', " www.oldsite.example ", " www.newsite.example ");') AS语句FROM information_schema。-u root -p your_db_name_here > upgrade_script.sql . WHERE table_name LIKE 'wp_%'

删除文件开头的任何垃圾。我吃了一些。

纳米upgrade_script.sql

使用——force选项运行生成的脚本以跳过错误。(慢速-如果DB大,可以喝杯咖啡)

Mysql -u root -p your_db_name_here——force < upgrade_script.sql

另一种选择是为数据库中的每一列生成语句:

SELECT CONCAT(
    'update ', table_name ,
    ' set ', column_name, ' = replace(', column_name,', ''www.oldDomain.example'', ''www.newDomain.example'');'
) AS statement
FROM information_schema.columns
WHERE table_schema = 'mySchema' AND table_name LIKE 'yourPrefix_%';

这将生成一个更新语句列表,然后您可以执行这些更新语句。

在有大小写字母的句子中, 我们可以使用二进制REPACE

UPDATE `table_1`  SET  `field_1` =  BINARY REPLACE(`field_1`, 'find_string', 'replace_string')