mysql替換部分字符串的方法:1、使用REPLACE()函數(shù),語法“REPLACE(字符串,查找值,替換值)”;2、使用INSERT()函數(shù),語法“INSERT(字符串,替換開始位置,要替換的字符數(shù),替換值)”。
本教程操作環(huán)境:windows7系統(tǒng)、mysql8版本、Dell G3電腦。
mysql替換部分字符串
1、使用REPLACE()函數(shù)
REPLACE()函數(shù)用新的子字符串替換字符串中所有出現(xiàn)的子字符串。
注意:此函數(shù)執(zhí)行區(qū)分大小寫的替換。
語法
REPLACE(string, from_string, new_string)
參數(shù) | 描述 |
---|---|
string | 必須項。原始字符串 |
from_string | 必須項。要替換的子字符串 |
new_string | 必須項。新的替換子字符串 |
【實例】使用 REPLACE 函數(shù)進行字符串替換操作
mysql> SELECT REPLACE('aaa.mysql.com','a','w'); +----------------------------------+ | REPLACE('aaa.mysql.com','a','w') | +----------------------------------+ | www.mysql.com | +----------------------------------+ 1 row in set (0.00 sec)
由運行結果可以看出,使用 REPLACE('aaa.mysql.com','a','w')
將“aaa.mysql.com
”字符串的“a”字符替換為“w”字符,結果為“www.mysql.com
”。
2、使用INSERT()函數(shù)
INSERT()函數(shù)在指定位置的字符串中插入一個字符串,并插入一定數(shù)量的字符。
語法
INSERT(string, position, number, string2)
參數(shù) | 描述 |
---|---|
string | 必須項。要修改的字符串 |
position | 必須項。插入string2的位置 |
number | 必須項。要替換的字符數(shù) |
string2 | 必須項。要插入字符串的字符串 |
若 position 超過字符串長度,則返回值為原始字符串。假如 number 的長度大于其他字符串的長度,則從位置 position 開始替換。若任何一個參數(shù)為 NULL,則返回值為 NULL。
【實例】使用 INSERT 函數(shù)進行字符串替換操作
mysql> SELECT INSERT('Football',2,4,'Play') AS col1, -> INSERT('Football',-1,4,'Play') AS col2, -> INSERT('Football',3,20,'Play') AS col3; +----------+----------+--------+ | col1 | col2 | col3 | +----------+----------+--------+ | FPlayall | Football | FoPlay | +----------+----------+--------+ 1 row in set (0.04 sec)
由執(zhí)行結果可知:
-
第一個函數(shù)
INSERT('Football',2,4,'Play')
將“Football”從第 2 個字符開始長度為 4 的字符串替換為 Play,結果為“FPlayall”; -
第二個函數(shù)
INSERT('Football',-1,4,'Play')
中的起始位置 -1 超出了字符串長度,直接返回原字符串; -
第三個函數(shù)
INSERT('Football',3,20,'Play')
替換長度超出了原字符串長度,則從第 3 個字符開始,截取后面所有的字符,并替換為指定字符 Play,結果為“FoPlay”。
【