亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2017年03月10日 08:56:54   作者:張佳美  
這篇文章主要介紹了MySQL中使用replace、regexp進行正則表達式替換的用法,結(jié)合具體實例形式分析了replace、regexp正則替換的使用技巧與相關(guān)注意事項,需要的朋友可以參考下

本文實例講述了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

復(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')

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

2.replace(object,search,replace)

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

select replace('chabaoo.cn','w','Ww')

—>WwWchabaoo.cn

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

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

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

當(dāng)你對這類模式進行匹配測試時,使用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”開頭的名字,使用“^”匹配名字的開始:

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

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

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

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

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

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

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}$';

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

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

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

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

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

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

相關(guān)文章

  • mysql隔離級別詳解及示例

    mysql隔離級別詳解及示例

    經(jīng)常提到數(shù)據(jù)庫的事務(wù),那你知道數(shù)據(jù)庫還有事務(wù)隔離的說法嗎,本文主要介紹了mysql的四種隔離級別,具有一定的參考價值,感興趣的可以了解一下
    2021-09-09
  • 詳解MySQL的用戶密碼過期功能

    詳解MySQL的用戶密碼過期功能

    這篇文章主要為大家詳細(xì)介紹了MySQL的用戶密碼過期功能的相關(guān)資料,需要的朋友可以參考下
    2016-02-02
  • 最新版MySQL 8.0.22下載安裝超詳細(xì)教程(Windows 64位)

    最新版MySQL 8.0.22下載安裝超詳細(xì)教程(Windows 64位)

    這篇文章主要介紹了最新版MySQL 8.0.22下載安裝超詳細(xì)教程(Windows 64位),本文通過圖文實例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • MySQL創(chuàng)建數(shù)據(jù)庫的兩種方法

    MySQL創(chuàng)建數(shù)據(jù)庫的兩種方法

    這篇文章主要為大家詳細(xì)介紹了MySQL創(chuàng)建數(shù)據(jù)庫的兩種方法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • MySQL select、insert、update批量操作語句代碼實例

    MySQL select、insert、update批量操作語句代碼實例

    這篇文章主要介紹了MySQL select、insert、update批量操作語句代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • MySQL存儲引擎InnoDB與Myisam的區(qū)別分析

    MySQL存儲引擎InnoDB與Myisam的區(qū)別分析

    INNODB會支持一些關(guān)系數(shù)據(jù)庫的高級功能,如事務(wù)功能和行級鎖,MYISAM不支持。MYISAM的性能更優(yōu),占用的存儲空間少。所以,選擇何種存儲引擎,視具體應(yīng)用而定。
    2022-12-12
  • MySql 5.7.17 winx64的安裝配置詳細(xì)教程

    MySql 5.7.17 winx64的安裝配置詳細(xì)教程

    這篇文章主要介紹了MySql 5.7.17 winx64的安裝配置教程,初始化數(shù)據(jù)庫、配置相關(guān)信息的方法在本文中介紹的非常詳細(xì),需要的朋友參考下
    2017-01-01
  • mysql 精簡過程(刪除一些文件)

    mysql 精簡過程(刪除一些文件)

    這篇文章主要是介紹了mysql的精簡方法,因為默認(rèn)安裝的時候有一些文件一般用不到,這里只是為了經(jīng)常一些組合工具,服務(wù)器使用不建議精簡
    2013-06-06
  • MySQL表復(fù)合查詢的實現(xiàn)

    MySQL表復(fù)合查詢的實現(xiàn)

    本文主要介紹了MySQL表的復(fù)合查詢,如何使用多表查詢、子查詢、自連接、內(nèi)外連接等復(fù)合查詢的案例,感興趣的可以了解一下
    2023-05-05
  • MySQL升級PostgreSQL遇到的一些常見問題及解決方案

    MySQL升級PostgreSQL遇到的一些常見問題及解決方案

    MySQL是一款性能優(yōu)越、數(shù)據(jù)可靠性高的數(shù)據(jù)庫軟件,然而為了保證其長期有效運行,數(shù)據(jù)庫升級是非常重要的,下面這篇文章主要給大家介紹了關(guān)于MySQL升級PostgreSQL遇到的一些常見問題及解決方案的相關(guān)資料,需要的朋友可以參考下
    2024-05-05

最新評論