一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL中使用replace、regexp進行正則表達式替換的用法分析

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

2020-07-19 16:31張佳美 Mysql

這篇文章主要介紹了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(object,search,replace)

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

select replace('m.ythuaji.com.cn','w','Ww')

—>m.ythuaji.com.cn

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

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

由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 '^d';

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

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

為了找出以“love”結尾的名字,使用“$”匹配名字的結尾:

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

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

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

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

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

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

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

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

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

希望本文所述對大家MySQL數據庫計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产日韩欧美色视频色在线观看 | 四虎在线最新地址公告 | 午夜影院费试看黄 | 好看华人华人经典play | 美女和男人一起差差 | 好大用力深一点女公交车 | 国产精品免费 | 思久久 | 久久九九精品国产自在现线拍 | 亚洲情射 | 美女1819xxxx | 大胸孕妇孕交pregnantsex 大象视频污 | 欧美日韩一区二区三区久久 | 极端 成熟 性别 视频 | 国产成人精品午夜在线播放 | 色综合综合 | 亚洲国产精品久久卡一 | 亚洲欧美日韩综合在线播放 | 色综合图片 | 精品无人乱码一区二区三区 | 亚洲国产精品成人午夜在线观看 | 国产色视频一区二区三区 | 操美女骚b | 扒开斗罗美女了的胸罩和内裤漫画 | 三级黄色图片 | 羞羞私人影院可以直接免费观影吗 | 精品国产品香蕉在线观看 | 精品视频一区二区 | 欧美a级在线观看 | 天天干天天日天天射天天操毛片 | 金发美女与黑人做爰 | 爱欲荡漾在线观看 | 麻豆网站在线免费观看 | 色综合天天五月色 | 边吃胸边膜下刺激免费男对女 | sao虎在线精品永久 s0e一923春菜花在线播放 | 996热精品视频在线观看 | 亚洲v成人天堂影视 | 欧美丝袜videohd| 韩日视频在线观看 | 日韩毛片高清在线看 |