当前位置: 代码网 > it编程>数据库>Mysql > MySQL中REPLACE函数与语句举例详解

MySQL中REPLACE函数与语句举例详解

2025年09月14日 Mysql 我要评论
mysql 的 replace 有两个不同的用途,分别是:replace() 函数:用于字符串替换。replace into 语句:用于插入或替换整行记录(类似 insert into ... on

mysql 的 replace 有两个不同的用途,分别是:

  1. replace() 函数:用于字符串替换。
  2. replace into 语句:用于插入或替换整行记录(类似 insert into ... on duplicate key update)。

一、replace()函数

语法:

replace(str, from_str, to_str)

参数说明:

参数类型描述
str字符串原始字符串
from_str字符串要被替换的子字符串
to_str字符串替换后的新子字符串

功能说明:

将字符串 str 中所有的 from_str 子字符串替换成 to_str,并返回新的字符串。如果 str 中不包含 from_str,则返回原始字符串。

示例:

select replace('http://8.130.70.131/image.jpg', '8.130.70.131', 'zhongyuele.top');
-- 返回: http://zhongyuele.top/image.jpg

二、replace into语句

语法:

replace into table_name [(column1, column2, ...)]
values (value1, value2, ...);

参数说明:

参数类型描述
table_name表名要操作的数据表
(column1, column2, ...)列名列表可选,指定插入列
(value1, value2, ...)值列表对应列的值

功能说明:

  • 如果插入的记录与表中已有的主键或唯一索引冲突,则删除旧记录并插入新记录。
  • 否则,直接插入新记录。
  • 本质是“先删除再插入”,不是更新!

示例:

replace into users (id, name) values (1, 'alice');

如果 users 表中已有 id = 1 的记录,则该记录会被删除并插入新记录。

总结对比表格

特性replace(str, from_str, to_str)replace into
类型字符串函数sql 语句
使用场景替换字符串中的部分内容插入或替换整条记录
是否影响原数据不修改原数据,仅返回新字符串实际执行写操作(删除 + 插入)
是否需要唯一索引是(依赖主键或唯一约束)
返回值替换后的字符串影响的行数(1 或 2)
示例select replace(name, 'a', 'a')replace into table values(...)

注意事项

  • replace into 实际上是“删除+插入”,如果有自增主键,会导致 id 变化。
  • replace() 函数区分大小写(默认情况下)。
  • 在使用 replace into 时要确保有合适的主键或唯一索引,否则等同于普通插入。

如需更细粒度控制(例如只更新某些字段),建议使用 insert into ... on duplicate key update

案例

以下是实现批量替换 [goods](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\sys_banner\entity\sysbanner.java#l23-l24) 表中 [image](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\goods\entity\goods.java#l47-l47) 列包含 8.130.70.131 字符串为 zhongyuele.top 的 sql 语句,并对语法中的关键字进行详细说明,最后以表格形式总结。

执行 sql 语句

update goods
set image = replace(image, '8.130.70.131', 'zhongyuele.top')
where image like '%8.130.70.131%';

关键字说明

关键字/函数说明
update用于修改表中的数据。指定要更新的表名(这里是 [goods](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\sys_banner\entity\sysbanner.java#l23-l24))。
set指定要更新的列和新的值。这里将 [image](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\goods\entity\goods.java#l47-l47) 列设置为 replace(...) 的结果。
replace(str, from_str, to_str)mysql 内置字符串函数,用于将 str 中的所有 from_str 替换为 to_str
where可选,但建议加上,用于限定只更新包含 8.130.70.131 的记录,避免全表更新影响性能。
like用于模式匹配,这里的 % 是通配符,表示任意字符序列。'%8.130.70.131%' 表示包含该字符串的所有记录。

总结表格

sql 元素示例含义
updateupdate goods更新 [goods](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\sys_banner\entity\sysbanner.java#l23-l24) 表的数据
setset image = ...设置 [image](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\goods\entity\goods.java#l47-l47) 列的新值
replace()replace(image, '8.130.70.131', 'zhongyuele.top')替换 [image](file://d:\workspace\me\rbac2024\read\后台系统\shop-api\itmk-base-web\src\main\java\com\itmk\web\goods\entity\goods.java#l47-l47) 列中的旧字符串为新字符串
wherewhere image like '%8.130.70.131%'仅更新包含目标字符串的行
like'%'通配符,匹配任意字符组合

注意事项

  • 备份数据:在执行前请先备份表数据。
  • 测试环境验证:建议先在测试环境中运行确认无误后再上线。
  • 性能考虑:若表数据量大,建议在低峰期执行,或分批次更新。

例如分页更新:

update goods
set image = replace(image, '8.130.70.131', 'zhongyuele.top')
where image like '%8.130.70.131%'
limit 1000;

可多次执行直到所有记录处理完毕。

总结

到此这篇关于mysql中replace函数与语句举例的文章就介绍到这了,更多相关mysql中replace函数语句内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com