六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線(xiàn)學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

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

[摘要]這篇文章主要介紹了MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法,結(jié)合具體實(shí)例形式分析了replace、regexp正則替換的使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下本文實(shí)例講述了MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法。分享給大家供大家參考,...
這篇文章主要介紹了MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法,結(jié)合具體實(shí)例形式分析了replace、regexp正則替換的使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下

本文實(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

代碼如下:

replace into table (id,name) values('1′,'aa'),('2′,'bb')

此語(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.jb51.net','w','Ww')

例:把表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ě)出

以上就是MySQL中使用replace、regexp進(jìn)行正則表達(dá)式替換的用法分析的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。




主站蜘蛛池模板: 日日碰夜夜爽 | 色吊丝欧美 | 中文字幕高清免费不卡视频 | 亚洲精品在线观看91 | 天天射美女 | 性感美女香蕉视频 | 亚洲福利在线看 | 在线视频欧美精品 | 色综合色狠狠天天综合色hd | 欧美午夜免费看爽爽爽 | 色五夜婷婷 | 色爱区综合激情五月综合激情 | 伊人电院网 | 在线播放国产一区二区三区 | 一级做a爰片久久毛片免费 一级做a爰片久久毛片美女图片 | 亚洲免费在线观看视频 | 日韩一区精品视频在线看 | 日韩欧美在线不卡 | 亚洲精品91大神在线观看 | 日韩三级一区二区三区 | 欧美视频中文字幕 | 欧美一级网址 | 做a视频大全 | 中文字幕在线观看日本 | 日韩毛片在线影视 | 欧洲真实呦女网站 | 最新欧美伦禁片在线观看 | 天干夜天天夜天干天 | 婷婷综合激情网 | 情侣国产 | 日韩aa在线观看 | 亚洲成a人v大片在线观看 | 日韩中文字幕在线不卡 | 亚洲欧美日韩一区高清中文字幕 | 欧美伊人久久大香线蕉在观 | 视频国产91 | 午夜视频在线观看完整高清在线 | 性刺激免费视频观看在线观看 | 婷婷伊人 | 亚洲欧美综合图片 | 伊人官网|