主頁 > 知識(shí)庫 > MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析

MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析

熱門標(biāo)簽:電銷機(jī)器人市場價(jià) 地圖標(biāo)注直通車 dq8 全地圖標(biāo)注 南寧智能電銷機(jī)器人價(jià)格 永州智能外呼系統(tǒng) 邯鄲400電話注冊辦理 遂寧400電話申請 哈爾濱云外呼系統(tǒng)運(yùn)營商 趙縣地圖標(biāo)注

本文實(shí)例講述了MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法。分享給大家供大家參考,具體如下:

今天一個(gè)朋友問我,如果將數(shù)據(jù)庫中查到的類似于“./uploads/110100_cityHotel_北京富豪華賓館.jpg”這樣的格式都修改為“./uploads/110100cityHotel北京富豪華賓館.jpg”這樣的格式。我本人是沒有這樣處理過數(shù)據(jù)的,但是我知道m(xù)ysql是可以使用replace做到的,而且正則表達(dá)式也可以做到。

如何做呢?

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

update master_data.md_employee set name=replace(name,"_",'') where id = 825;

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

在Mysql中,replace和regexp主要是通過sql語句實(shí)現(xiàn)數(shù)據(jù)的替換。

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

mysql replace用法

1.replace into

復(fù)制代碼 代碼如下:
replace into table (id,name) values('1′,'aa'),('2′,'bb')

此語句的作用是向表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.jb51.net','w','Ww')

—>WwWwWw.jb51.net

例:把表table中的name字段中的aa替換為bb

update table set name=replace(name,'aa','bb')

由MySQL提供的模式匹配的其它類型是使用擴(kuò)展正則表達(dá)式。

當(dāng)你對這類模式進(jìn)行匹配測試時(shí),使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它們是同義詞)。

擴(kuò)展正則表達(dá)式的一些字符是:

· ‘.'匹配任何單個(gè)的字符。

· 字符類“[...]”匹配在方括號(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模式與被測試值的任何地方匹配,模式就匹配(這不同于LIKE模式匹配,只有與整個(gè)值匹配,模式才匹配)。

為了定位一個(gè)模式以便它必須匹配被測試值的開始或結(jié)尾,在模式開始處使用“^”或在模式的結(jié)尾用“$”。

為了說明擴(kuò)展正則表達(dá)式如何工作,下面使用REGEXP重寫上面所示的LIKE查詢:

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

SELECT * FROM master_data.md_employee WHERE name REGEXP '^d';

這樣的結(jié)果集是不區(qū)分大小寫的,如果你想強(qiáng)制使REGEXP比較區(qū)分大小寫,使用BINARY關(guān)鍵字使其中一個(gè)字符串變?yōu)槎M(jìn)制字符串。該查詢只匹配名稱首字母的小寫‘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”的名字,使用以下查詢:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'w';

既然如果一個(gè)正則表達(dá)式出現(xiàn)在值的任何地方,其模式匹配了,就不必在先前的查詢中在模式的兩側(cè)放置一個(gè)通配符以使得它匹配整個(gè)值,就像你使用了一個(gè)SQL模式那樣。

為了找出包含正好5個(gè)字符的名字,使用“^”和“$”匹配名字的開始和結(jié)尾,和5個(gè)“.”實(shí)例在兩者之間:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.....$';

你也可以使用“{n}”“重復(fù)n次”操作符重寫前面的查詢:

SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.{5}$';

這些知識(shí)一些簡單的mysql的replace和regexp的用法,對于深入的學(xué)習(xí),我們會(huì)在之后的文章會(huì)將具體的例子以及用法寫出

PS:這里再為大家提供2款非常方便的正則表達(dá)式工具供大家參考使用:

JavaScript正則表達(dá)式在線測試工具:
http://tools.jb51.net/regex/javascript

正則表達(dá)式在線生成工具:
http://tools.jb51.net/regex/create_reg

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》

希望本文所述對大家MySQL數(shù)據(jù)庫計(jì)有所幫助。

您可能感興趣的文章:
  • Mysql中正則表達(dá)式Regexp常見用法
  • 正則表達(dá)式(RegExp)判斷文本框中是否包含特殊符號(hào)
  • MySQL中REGEXP正則表達(dá)式使用大全
  • oracle正則表達(dá)式regexp_like的用法詳解
  • js正則表達(dá)式講解之index屬性(RegExp對象)
  • js正則表達(dá)式之RegExp對象屬性lastIndex,lastMatch,lastParen,lastContext,rightContext屬性講解
  • ES9的新特性之正則表達(dá)式RegExp詳解

標(biāo)簽:上海 中衛(wèi) 張家界 南寧 阿里 鄂州 定西 浙江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析》,本文關(guān)鍵詞  MySQL,中,使用,replace,regexp,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章