mysql 的 replace
有两个不同的用途,分别是:
- replace() 函数:用于字符串替换。
- 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 元素 | 示例 | 含义 |
---|---|---|
update | update 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) 表的数据 |
set | set 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) 列中的旧字符串为新字符串 |
where | where 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函数语句内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论