MySQL中REPLACE函數(shù)與語(yǔ)句舉例詳解
MySQL 的 REPLACE 有兩個(gè)不同的用途,分別是:
- REPLACE() 函數(shù):用于字符串替換。
- REPLACE INTO 語(yǔ)句:用于插入或替換整行記錄(類似
INSERT INTO ... ON DUPLICATE KEY UPDATE)。

一、REPLACE()函數(shù)
語(yǔ)法:
REPLACE(str, from_str, to_str)
參數(shù)說(shuō)明:
| 參數(shù) | 類型 | 描述 |
|---|---|---|
str | 字符串 | 原始字符串 |
from_str | 字符串 | 要被替換的子字符串 |
to_str | 字符串 | 替換后的新子字符串 |
功能說(shuō)明:
將字符串 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語(yǔ)句
語(yǔ)法:
REPLACE INTO table_name [(column1, column2, ...)] VALUES (value1, value2, ...);
參數(shù)說(shuō)明:
| 參數(shù) | 類型 | 描述 |
|---|---|---|
table_name | 表名 | 要操作的數(shù)據(jù)表 |
(column1, column2, ...) | 列名列表 | 可選,指定插入列 |
(value1, value2, ...) | 值列表 | 對(duì)應(yīng)列的值 |
功能說(shuō)明:
- 如果插入的記錄與表中已有的主鍵或唯一索引沖突,則刪除舊記錄并插入新記錄。
- 否則,直接插入新記錄。
- 本質(zhì)是“先刪除再插入”,不是更新!
示例:
REPLACE INTO users (id, name) VALUES (1, 'Alice');
如果 users 表中已有 id = 1 的記錄,則該記錄會(huì)被刪除并插入新記錄。
總結(jié)對(duì)比表格
| 特性 | REPLACE(str, from_str, to_str) | REPLACE INTO |
|---|---|---|
| 類型 | 字符串函數(shù) | SQL 語(yǔ)句 |
| 使用場(chǎng)景 | 替換字符串中的部分內(nèi)容 | 插入或替換整條記錄 |
| 是否影響原數(shù)據(jù) | 不修改原數(shù)據(jù),僅返回新字符串 | 實(shí)際執(zhí)行寫操作(刪除 + 插入) |
| 是否需要唯一索引 | 否 | 是(依賴主鍵或唯一約束) |
| 返回值 | 替換后的字符串 | 影響的行數(shù)(1 或 2) |
| 示例 | SELECT REPLACE(name, 'a', 'A') | REPLACE INTO table VALUES(...) |
注意事項(xiàng)
REPLACE INTO實(shí)際上是“刪除+插入”,如果有自增主鍵,會(huì)導(dǎo)致 ID 變化。REPLACE()函數(shù)區(qū)分大小寫(默認(rèn)情況下)。- 在使用
REPLACE INTO時(shí)要確保有合適的主鍵或唯一索引,否則等同于普通插入。
如需更細(xì)粒度控制(例如只更新某些字段),建議使用 INSERT INTO ... ON DUPLICATE KEY UPDATE。
案例
以下是實(shí)現(xiàn)批量替換 [goods](file://D:\workspace\me\rbac2024\read\后臺(tái)系統(tǒng)\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\后臺(tái)系統(tǒng)\shop-api\itmk-base-web\src\main\java\com\itmk\web\goods\entity\Goods.java#L47-L47) 列包含 8.130.70.131 字符串為 zhongyuele.top 的 SQL 語(yǔ)句,并對(duì)語(yǔ)法中的關(guān)鍵字進(jìn)行詳細(xì)說(shuō)明,最后以表格形式總結(jié)。
執(zhí)行 SQL 語(yǔ)句
UPDATE goods SET image = REPLACE(image, '8.130.70.131', 'zhongyuele.top') WHERE image LIKE '%8.130.70.131%';
關(guān)鍵字說(shuō)明
| 關(guān)鍵字/函數(shù) | 說(shuō)明 |
|---|---|
UPDATE | 用于修改表中的數(shù)據(jù)。指定要更新的表名(這里是 [goods](file://D:\workspace\me\rbac2024\read\后臺(tái)系統(tǒng)\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\后臺(tái)系統(tǒng)\shop-api\itmk-base-web\src\main\java\com\itmk\web\goods\entity\Goods.java#L47-L47) 列設(shè)置為 REPLACE(...) 的結(jié)果。 |
REPLACE(str, from_str, to_str) | MySQL 內(nèi)置字符串函數(shù),用于將 str 中的所有 from_str 替換為 to_str。 |
WHERE | 可選,但建議加上,用于限定只更新包含 8.130.70.131 的記錄,避免全表更新影響性能。 |
LIKE | 用于模式匹配,這里的 % 是通配符,表示任意字符序列。'%8.130.70.131%' 表示包含該字符串的所有記錄。 |
總結(jié)表格
| SQL 元素 | 示例 | 含義 |
|---|---|---|
UPDATE | UPDATE goods | 更新 [goods](file://D:\workspace\me\rbac2024\read\后臺(tái)系統(tǒng)\shop-api\itmk-base-web\src\main\java\com\itmk\web\sys_banner\entity\SysBanner.java#L23-L24) 表的數(shù)據(jù) |
SET | SET image = ... | 設(shè)置 [image](file://D:\workspace\me\rbac2024\read\后臺(tái)系統(tǒng)\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\后臺(tái)系統(tǒng)\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%' | 僅更新包含目標(biāo)字符串的行 |
LIKE | '%' | 通配符,匹配任意字符組合 |
注意事項(xiàng)
- 備份數(shù)據(jù):在執(zhí)行前請(qǐng)先備份表數(shù)據(jù)。
- 測(cè)試環(huán)境驗(yàn)證:建議先在測(cè)試環(huán)境中運(yùn)行確認(rèn)無(wú)誤后再上線。
- 性能考慮:若表數(shù)據(jù)量大,建議在低峰期執(zhí)行,或分批次更新。
例如分頁(yè)更新:
UPDATE goods SET image = REPLACE(image, '8.130.70.131', 'zhongyuele.top') WHERE image LIKE '%8.130.70.131%' LIMIT 1000;
可多次執(zhí)行直到所有記錄處理完畢。
總結(jié)
到此這篇關(guān)于MySQL中REPLACE函數(shù)與語(yǔ)句舉例的文章就介紹到這了,更多相關(guān)MySQL中REPLACE函數(shù)語(yǔ)句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決MySQL Sending data導(dǎo)致查詢很慢問(wèn)題的方法與思路
這篇文章主要介紹了解決MySQL Sending data導(dǎo)致查詢很慢問(wèn)題的方法與思路,感興趣的小伙伴們可以參考一下2016-04-04
MySQL啟動(dòng)失敗之MySQL服務(wù)無(wú)法啟動(dòng)的原因及解決
這篇文章主要介紹了MySQL啟動(dòng)失敗之MySQL服務(wù)無(wú)法啟動(dòng)的原因及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12
MySQL用戶權(quán)限設(shè)置保護(hù)數(shù)據(jù)庫(kù)安全
MySQL用戶權(quán)限設(shè)置是保護(hù)數(shù)據(jù)庫(kù)安全的重要措施之一。通過(guò)為用戶設(shè)置不同的權(quán)限,可以控制用戶對(duì)數(shù)據(jù)庫(kù)的訪問(wèn)能力,包括讀取、修改、刪除、創(chuàng)建等操作。合理設(shè)置用戶權(quán)限可以避免誤操作、非法訪問(wèn)等安全問(wèn)題2023-05-05
詳解JDBC數(shù)據(jù)庫(kù)鏈接及相關(guān)方法的封裝
這篇文章主要介紹了詳解JDBC數(shù)據(jù)庫(kù)鏈接及相關(guān)方法的封裝的相關(guān)資料,下面是封裝的具體類,用到了泛型和反射,希望能幫助到大家,需要的朋友可以參考下2017-08-08
解決MySql版本問(wèn)題sql_mode=only_full_group_by
這篇文章主要介紹了解決MySql版本問(wèn)題sql_mode=only_full_group_by,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11

