开发者

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

开发者 https://www.devze.com 2025-08-16 08:59 出处:网络 作者: 爱的叹息
目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数说明:功能说明:示例:总结对比表格注意事项案例执行 SQL 语句关键字说明总结表格注意事项总结mysql 的 REPLACE 有两个不同的
目录
  • 一、REPLACE()函数
    • 语法:
    • 参数说明:
    • 功能说明:
    • 示例:
  • 二、REPLACE INTO语句
    • 语法:
    • 参数说明:
    • 功能说明:
    • 示例:
  • 总结对比表格
    • 注意事项
      • 案例
        • 执行 SQL 语句
        • 关键字说明
        • 总结表格
        • 注意事项
      • 总结

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

        1. REPLACE() 函数:用于字符串替换。
        2. REPLACE INTO 语句:用于插入或替换整行记录(类似 INSERT INTO ... ON DUPLICATE KEY UPDATE)。

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

        一、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, ...)值列表对应列的值

        功能说明:

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

        示例:

        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-appythoni\itmk-base-web\src\main\java\com\itmk\web\sys_banner\entity\SysBanner.java#L23-L24))。
        SET指定要更新的列和新的值。这里将 [image](file://D:PvFXNxhaHworkspace\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(androidimage, '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 PvFXNxhaH'%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函数语句内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

        0

        精彩评论

        暂无评论...
        验证码 换一张
        取 消

        关注公众号