mysql 正则替换 换行,MySQL中使用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('www.jb51.net','w','Ww')
—>WwWwWw.jb51.net
例:把表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”開頭的名字,使用“^”匹配名字的開始:
總結
以上是生活随笔為你收集整理的mysql 正则替换 换行,MySQL中使用replace、regexp进行正则表达式替换的用法分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 基于java+springboot+la
- 下一篇: 《springcloud超级入门》Spr