MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析
本文實(shí)例講述了MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法。分享給大家供大家參考,具體如下:
今天一個(gè)朋友問(wèn)我,如果將數(shù)據(jù)庫(kù)中查到的類(lèi)似于“./uploads/110100_cityHotel_北京富豪華賓館.jpg”這樣的格式都修改為“./uploads/110100cityHotel北京富豪華賓館.jpg”這樣的格式。我本人是沒(méi)有這樣處理過(guò)數(shù)據(jù)的,但是我知道m(xù)ysql是可以使用replace做到的,而且正則表達(dá)式也可以做到。
如何做呢?
我們只需要這樣一條語(yǔ)句即可,
update master_data.md_employee set name=replace(name,"_",'') where id = 825;
-- 注replace(字段名,"需要替換的字符","替換的字符"),這樣即可。
在Mysql中,replace和regexp主要是通過(guò)sql語(yǔ)句實(shí)現(xiàn)數(shù)據(jù)的替換。
我們先來(lái)說(shuō)說(shuō)replace 的具體用法。
mysql replace用法
1.replace into
此語(yǔ)句的作用是向表table中插入兩條記錄。如果主鍵id為1或2不存在
就相當(dāng)于
insert into table (id,name) values('1′,'aa'),('2′,'bb')
如果存在相同的值則不會(huì)插入數(shù)據(jù)
2.replace(object,search,replace)
把object中出現(xiàn)search的全部替換為replace
select replace('www.dbjr.com.cn','w','Ww')
—>WwWwww.dbjr.com.cn
例:把表table中的name字段中的aa替換為bb
update table set name=replace(name,'aa','bb')
由MySQL提供的模式匹配的其它類(lèi)型是使用擴(kuò)展正則表達(dá)式。
當(dāng)你對(duì)這類(lèi)模式進(jìn)行匹配測(cè)試時(shí),使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它們是同義詞)。
擴(kuò)展正則表達(dá)式的一些字符是:
· ‘.'匹配任何單個(gè)的字符。
· 字符類(lèi)“[...]”匹配在方括號(hào)內(nèi)的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。為了命名字符的范圍,使用一個(gè)“-”?!癧a-z]”匹配任何字母,而“[0-9]”匹配任何數(shù)字。
· “ * ”匹配零個(gè)或多個(gè)在它前面的字符。例如,“x*”匹配任何數(shù)量的“x”字符,“[0-9]*”匹配任何數(shù)量的數(shù)字,而“.*”匹配任何數(shù)量的任何字符。
如果REGEXP模式與被測(cè)試值的任何地方匹配,模式就匹配(這不同于LIKE模式匹配,只有與整個(gè)值匹配,模式才匹配)。
為了定位一個(gè)模式以便它必須匹配被測(cè)試值的開(kāi)始或結(jié)尾,在模式開(kāi)始處使用“^”或在模式的結(jié)尾用“$”。
為了說(shuō)明擴(kuò)展正則表達(dá)式如何工作,下面使用REGEXP重寫(xiě)上面所示的LIKE查詢(xún):
1.為了找出以“d”開(kāi)頭的名字,使用“^”匹配名字的開(kāi)始:
SELECT * FROM master_data.md_employee WHERE name REGEXP '^d';
這樣的結(jié)果集是不區(qū)分大小寫(xiě)的,如果你想強(qiáng)制使REGEXP比較區(qū)分大小寫(xiě),使用BINARY關(guān)鍵字使其中一個(gè)字符串變?yōu)槎M(jìn)制字符串。該查詢(xún)只匹配名稱(chēng)首字母的小寫(xiě)‘d'。
SELECT * FROM master_data.md_employee WHERE name REGEXP BINARY'^d';
為了找出以“l(fā)ove”結(jié)尾的名字,使用“$”匹配名字的結(jié)尾:
SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'love$';
為了找出包含一個(gè)“w”的名字,使用以下查詢(xún):
SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'w';
既然如果一個(gè)正則表達(dá)式出現(xiàn)在值的任何地方,其模式匹配了,就不必在先前的查詢(xún)中在模式的兩側(cè)放置一個(gè)通配符以使得它匹配整個(gè)值,就像你使用了一個(gè)SQL模式那樣。
為了找出包含正好5個(gè)字符的名字,使用“^”和“$”匹配名字的開(kāi)始和結(jié)尾,和5個(gè)“.”實(shí)例在兩者之間:
SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.....$';
你也可以使用“{n}”“重復(fù)n次”操作符重寫(xiě)前面的查詢(xún):
SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.{5}$';
這些知識(shí)一些簡(jiǎn)單的mysql的replace和regexp的用法,對(duì)于深入的學(xué)習(xí),我們會(huì)在之后的文章會(huì)將具體的例子以及用法寫(xiě)出
PS:這里再為大家提供2款非常方便的正則表達(dá)式工具供大家參考使用:
JavaScript正則表達(dá)式在線(xiàn)測(cè)試工具:
http://tools.jb51.net/regex/javascript
正則表達(dá)式在線(xiàn)生成工具:
http://tools.jb51.net/regex/create_reg
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過(guò)程技巧大全》及《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》
希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。
- MySQL中REGEXP正則表達(dá)式使用大全
- mysql數(shù)據(jù)庫(kù)replace、regexp的用法
- Mysql中正則表達(dá)式Regexp常見(jiàn)用法
- 老生常談MYSQL模式匹配 REGEXP和like的用法
- mysql模糊查詢(xún)like和regexp小結(jié)
- mysql模糊查詢(xún)like與REGEXP的使用詳細(xì)介紹
- MySQL正則表達(dá)式REGEXP使用詳解
- MySQL regexp 命令詳解
- MySql比較運(yùn)算符正則式匹配REGEXP的詳細(xì)使用詳解
- Mysql中正則表達(dá)式Regexp常見(jiàn)用法及說(shuō)明
- MYSQL中REGEXP的實(shí)現(xiàn)示例
相關(guān)文章
MYSQL中有關(guān)SUM字段按條件統(tǒng)計(jì)使用IF函數(shù)(case)問(wèn)題
MYSQL中SUM字段按條件統(tǒng)計(jì)使用IF函數(shù),具體實(shí)現(xiàn)代碼如下,感興趣的朋友不要錯(cuò)過(guò)2014-01-01
借助PHP的mysql_query()函數(shù)來(lái)創(chuàng)建MySQL數(shù)據(jù)庫(kù)的教程
這篇文章主要介紹了借助PHP的mysql_query()函數(shù)來(lái)創(chuàng)建MySQL數(shù)據(jù)庫(kù)的教程,將函數(shù)配合CREATE DATABASE語(yǔ)句使用,需要的朋友可以參考下2015-12-12
Mysql Binlog快速遍歷搜索記錄及binlog數(shù)據(jù)查看的方法
這篇文章主要介紹了Mysql Binlog快速遍歷搜索記錄及binlog數(shù)據(jù)查看的方法的相關(guān)資料,需要的朋友可以參考下2016-01-01
MySQL實(shí)現(xiàn)查詢(xún)數(shù)據(jù)庫(kù)表記錄數(shù)
這篇文章主要介紹了MySQL實(shí)現(xiàn)查詢(xún)數(shù)據(jù)庫(kù)表記錄數(shù),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
MySQL派生表合并優(yōu)化的原理和實(shí)現(xiàn)過(guò)程
本文從一個(gè)案例出發(fā)梳理了MySQL派生表合并優(yōu)化的流程實(shí)現(xiàn)和優(yōu)化原理,并對(duì)優(yōu)化前后同一條SQL語(yǔ)句在代碼層面的類(lèi)實(shí)例映射關(guān)系進(jìn)行了對(duì)比,這篇文章主要介紹了MySQL派生表合并優(yōu)化的原理和實(shí)現(xiàn),需要的朋友可以參考下2024-07-07
Windows下mysql?8.0.28?安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了Windows下mysql?8.0.28?安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
MySQL開(kāi)啟遠(yuǎn)程訪問(wèn)權(quán)限的最新方法
這篇文章主要給大家介紹了關(guān)于MySQL開(kāi)啟遠(yuǎn)程訪問(wèn)權(quán)限的最新方法,在MySQL中,要實(shí)現(xiàn)遠(yuǎn)程訪問(wèn),首先需要在MySQL服務(wù)端上開(kāi)啟相應(yīng)的權(quán)限,需要的朋友可以參考下2023-08-08

