MySQL中使用replace、regexp進行正規表示式替換的用法分析

黄舟
發布: 2017-03-15 17:17:02
原創
3965 人瀏覽過

這篇文章主要介紹了MySQL中使用replace、regexp進行正規表示式替換的用法,結合具體實例形式分析了replace、regexp正則替換的使用技巧與相關注意事項,需要的朋友可以參考下方

本文實例講述了MySQL中使用replace、regexp進行正規表示式替換的用法。分享給大家供大家參考,具體如下:

今天一個朋友問我,如果將資料庫中查到的類似「./uploads/110100_cityHotel_北京富豪華賓館.jpg」這樣的格式都修改為「./uploads/110100cityHotel北京富豪華賓館.jpg」這樣的格式。我自己是沒有這樣處理過資料的,但是我知道mysql是可以用replace做到的,而且正規表示式也可以做到。

如何做呢?

我們只需要這樣一條語句即可,

#程式碼如下:

update master_data.md_employee set name=replace(name,"_",'') where id = 825;
登入後複製

-- 註replace(字段名,"需要替換的字元","替換的字元"),這樣即可。

在Mysql中,replace和regexp主要是透過sql語句實現資料的替換。

我們先來談談replace 的具體用法。

mysql replace用法

1.replace into

程式碼如下:

replace into table (id,name) values('1′,'aa'),('2′,'bb')
登入後複製

此語句的作用是在表table中插入兩筆記錄。如果主鍵id為1或2不存在

就相當於

程式碼如下:

insert into table (id,name) values('1′,'aa'),('2′,'bb')
登入後複製

如果存在相同的值則不會插入資料

2.replace(<a href="http://www.php.cn/wiki/60.html" target="_blank">object</a>,search,replace)

把object中出現search的全部替換為replace

程式碼如下:

select replace(&#39;www.jb51.net&#39;,&#39;w&#39;,&#39;Ww&#39;)
登入後複製

範例:把表格table中的name欄位中的aa替換為bb 

 程式碼如下:

update table set name=replace(name,&#39;aa&#39;,&#39;bb&#39;)
登入後複製

由MySQL提供的模式匹配的其它類型是使用擴充正規表示式。

當你對這類模式進行配對測試時,使用REGEXP和NOT REGEXP運算子(或RLIKE和NOT RLIKE,它們是同義詞)。

擴充正規表示式的一些字元是:

· ‘.'符合任何單一的字元。

· 字元類別“[...]”符合在方括號內的任何字元。例如,「[abc]」符合「a」、「b」或「c」。為了命名字元的範圍,使用一個“-”。 「[a-z]」符合任何字母,而「[0-9]」則符合任何數字。

· “ * ”符合零個或多個在它前面的字元。例如,“x*”匹配任何數量的“x”字符,“[0-9]*”匹配任何數量的數字,而“.*”匹配任何數量的任何字符。

如果REGEXP模式與被測試值的任何地方匹配,模式就匹配(這不同於LIKE模式匹配,只有與整個值匹配,模式才匹配)。

為了定位一個模式以便它必須匹配被測試值的開始或結尾,在模式開始處使用「^」或在模式的結尾用「$」。

為了說明擴充正規表示式如何運作,以下使用REGEXP重寫上面所示的LIKE查詢

1.為了找出以「d 」開頭的名字,使用「^」匹配名字的開始:

 程式碼如下:

SELECT * FROM master_data.md_employee WHERE name REGEXP &#39;^d&#39;;
登入後複製

這樣的結果集是不區分大小寫的,如果你想強制使REGEXP比較區​​分大小寫,使用BINARY關鍵字使其中一個字串變成二進位字串。此查詢只符合名稱首字母的小寫‘d'。

 程式碼如下:

SELECT * FROM master_data.md_employee WHERE name REGEXP BINARY&#39;^d&#39;;
登入後複製

為了找出以「love」結尾的名字,使用「$」符合名字的結尾:

程式碼如下:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP &#39;love$&#39;;
登入後複製

為了找出包含一個「w」的名字,使用以下查詢:

# 程式碼如下:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP &#39;w&#39;;
登入後複製

既然如果一個正規表示式出現在值的任何地方,其模式匹配了,就不必在先前的查詢中在模式的兩側放置一個通配符以使得它匹配整個值,就像你使用了一個SQL模式那樣。

為了找出包含正好5個字元的名字,使用「^」和「$」來匹配名字的開始和結尾,和5個「.」實例在兩者之間:

程式碼如下:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP &#39;^.....$&#39;;
登入後複製

你也可以使用“{n}”“重复n次”操作符重写前面的查询:

代码如下:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP &#39;^.{5}$&#39;;
登入後複製

这些知识一些简单的mysql的replace和regexp的用法,对于深入的学习,我们会在之后的文章会将具体的例子以及用法写出

以上是MySQL中使用replace、regexp進行正規表示式替換的用法分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板