国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-24 12:52:23
字體:
供稿:網(wǎng)友

本文實例講述了MySQL中使用replace、regexp進行正則表達式替換的用法。,具體如下:

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

如何做呢?

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

復制代碼 代碼如下:
update master_data.md_employee set name=replace(name,"_",'') where id = 825;

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

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

我們先來說說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')

如果存在相同的值則不會插入數(shù)據(jù)

2.replace(object,search,replace)

把object中出現(xiàn)search的全部替換為replace

復制代碼 代碼如下:
select replace('m.survivalescaperooms.com','w','Ww')

—>WwWm.survivalescaperooms.com

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

復制代碼 代碼如下:
update table set name=replace(name,'aa','bb')

由MySQL提供的模式匹配的其它類型是使用擴展正則表達式。

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

擴展正則表達式的一些字符是:

· ‘.'匹配任何單個的字符。

· 字符類“[...]”匹配在方括號內(nèi)的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。為了命名字符的范圍,使用一個“-”。“[a-z]”匹配任何字母,而“[0-9]”匹配任何數(shù)字。

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

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

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 湘阴县| 杭锦旗| 枣庄市| 千阳县| 德保县| 大荔县| 毕节市| 沾化县| 宣恩县| 新竹市| 麦盖提县| 蛟河市| 左云县| 泸西县| 北安市| 桑植县| 同心县| 盘山县| 岳西县| 广丰县| 肥城市| 任丘市| 嘉义市| 光泽县| 延吉市| 赞皇县| 勐海县| 前郭尔| 公主岭市| 贵州省| 东宁县| 弋阳县| 广汉市| 黄平县| 新宾| 资溪县| 通化市| 双柏县| 邢台县| 凌云县| 珲春市|