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

2025-08-15 09:50

本文主要是介绍MySQL中REPLACE函数与语句举例详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函...

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

  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函数语句内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于MySQL中REPLACE函数与语句举例详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155749

相关文章

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Java中的.close()举例详解

《Java中的.close()举例详解》.close()方法只适用于通过window.open()打开的弹出窗口,对于浏览器的主窗口,如果没有得到用户允许是不能关闭的,:本文主要介绍Java中的.... 目录当你遇到以下三种情况时,一定要记得使用 .close():用法作用举例如何判断代码中的 input

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他