這篇文章主要介紹了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(<a href="http://www.php.cn/wiki/60.html" target="_blank">object</a>,search,replace)
把object中出現search的全部替換為replace
程式碼如下:
select replace('www.jb51.net','w','Ww')
範例:把表格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中使用replace、regexp進行正規表示式替換的用法分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境