MySQL 的 REPLACE 函数用途与语句示例详解

 更新时间:2025年11月21日 10:20:40   作者:爱的叹息  
文章介绍了MySQL的REPLACE函数和REPLACEINTO语句的用途、语法和示例,REPLACE函数用于字符串替换,而REPLACEINTO语句用于插入或替换整行记录,两者都可以在特定条件下执行写操作,但REPLACEINTO是真正的删除和插入操作,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧

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函数语句内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql 8.0.28安装配置方法图文教程(压缩包方式)

    mysql 8.0.28安装配置方法图文教程(压缩包方式)

    这篇文章主要为大家详细介绍了mysql 8.0.28安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • mysql中删除数据的几种方法(最新推荐)

    mysql中删除数据的几种方法(最新推荐)

    在MySQL数据库中,删除数据是一个常见的操作,它允许从表中移除不再需要的数据,在执行删除操作时,需要谨慎,以免误删重要数据,本文给大家介绍mysql中删除数据的几种方法,感兴趣的朋友一起看看吧
    2023-11-11
  • MySQL数据类型和表的操作方法

    MySQL数据类型和表的操作方法

    文章系统介绍了SQL常用数据类型(数值、字符串、日期)及表操作(创建、修改、删除),涵盖BIT、TINYINT、VARCHAR、ENUM等类型定义,以及SHOW TABLES、CREATE TABLE、ALTER TABLE等语句用法,强调数据类型选择与表结构管理的关键性,感兴趣的朋友跟随小编一起看看吧
    2025-10-10
  • MySQL索引下推的深入探索

    MySQL索引下推的深入探索

    这篇文章主要介绍了MySQL的索引下推,索引下推是为了解决在过滤条件时,可能导致大量的数据行被检索出来,但实际上只有很少的行满足WHERE子句中的所有条件的情况,需要的朋友可以参考下
    2022-07-07
  • 部署MySQL延迟从库的好处小结

    部署MySQL延迟从库的好处小结

    这篇文章主要给大家介绍了部署MySQL延迟从库的一些好处,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • MySQL如何解决幻读问题

    MySQL如何解决幻读问题

    在高并发数据库系统中,需要保证事务与事务之间的隔离性,还有事务本身的一致性。所以需要解决幻读问题,本文就来介绍一下,感兴趣的可以了解一下
    2021-08-08
  • 一条sql详解MYSQL的架构设计详情

    一条sql详解MYSQL的架构设计详情

    这篇文章主要介绍了一条sql详解MYSQL的架构设计详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下
    2022-09-09
  • mysql生成随机字符串函数分享

    mysql生成随机字符串函数分享

    这篇文章主要介绍了mysql生成随机字符串函数分享,本文直接给出实现代码,需要的朋友可以参考下
    2015-02-02
  • Mac下忘记Mysql的root用户密码的解决方法

    Mac下忘记Mysql的root用户密码的解决方法

    mac中安装MySQL时系统会自动为root 账户生成一个密码(改密码一般为一个不好记的字符串),若自己没有记住改密码,这时 mysql 就无法进入了。解决方案是修改root 账户的密码,问题是mysql进不去如何修改,下面就是改问题的解决方法:
    2017-03-03
  • MySQL根据条件迁移数据的几种方法实现

    MySQL根据条件迁移数据的几种方法实现

    本文主要介绍了MySQL根据条件迁移数据的实现,包括使用INSERT INTO SELECT、UPDATE、DELETE语句以及结合子查询进行迁移,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02

最新评论