程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql 正則表達式查詢含有非數字和字符的記錄,mysql正則表達式

mysql 正則表達式查詢含有非數字和字符的記錄,mysql正則表達式

編輯:MySQL綜合教程

mysql 正則表達式查詢含有非數字和字符的記錄,mysql正則表達式


比如我們有一張school表,裡面有一個字段county_name,現在我們要查詢county_name字段中包含a-w字母和數字以外字符的記錄,那麼sql該如何寫呢?請看下面的寫法:

select * from info where name regexp '[^a-w0-9]'; 

mysql中正則表達式使用regexp關鍵字,[^a-w0-9]表示匹配除了a-w字母和數字以外的字符。

下面向大家介紹mysql正則表達式的其他使用實例:

匹配名稱含有1000的所有行

SELECT * FROM a1 WHERE name regexp '1000'

匹配以000結尾的所有行,(.正則中表示:匹配任意一個字符)

SELECT * FROM a1 WHERE name regexp '.000'

Mysql正則大小寫都會匹配,為區分大小寫可使用binary關鍵字,如:

SELECT * FROM a1 WHERE name LIKE binary '%J%'  #使用LIKE+通配符匹配大寫J
SELECT * FROM a1 WHERE name regexp binary 'j'  #使用正則匹配小寫j

|為正則表達式的OR操作符,表示匹配其中之一

SELECT * FROM a1 WHERE name regexp binary 'a|j|G' 

匹配特定字符,使用[]括起來的字符,將會匹配其中任意單個字符。

SELECT * FROM a1 WHERE name regexp '[12]st'

以上'[12]st'正則表達式,[12]定義一組字符,它的意思是匹配1或2

^ 匹配字符開始的部分

select * from info where name regexp '^L'; //從info表name字段中查詢以L開頭的記錄 

$ 匹配字符結束的部分

select * from info where name regexp 'c$'; //從info表name字段中查詢以c結尾的記錄 

. 匹配字符串中的任意一個字符,包括回車和換行

select * from info where name regexp '^L..y$'; //從info表name字段中查詢以L開頭y結尾中間有兩個任意字符的記錄 

[字符集合]匹配字符集合中的任意字符

select * from info where name regexp '[ceo]'; //從info表name字段中查詢包含c、e、o三個字母中任意一個的記錄 

[^字符集合]匹配除了字符集合外的任意字符

select * from info where name regexp '[^a-w0-9]'; //從info表name字段中查詢包含a-w字母和數字以外字符的記錄 

s1|s2|s3 匹配s1s2s3中的任意一個

select * from info where name regexp 'ic'; //從info表name字段中查詢包含'ic'的記錄 

* 代表多個該字符前的字符,包括0個或1個

select * from info where name regexp 'a*c'; 從info表name字段中查詢c之前出現過a的記錄 

+ 代表多個該字符前的字符,包括1個

select * from info where name regexp 'a+c';//從info表name字段中查詢c之前出現過a的記錄 

字符串{N} 字符串出現N次

select * from info where name regexp 'a{3}'; //從info表name字段中查詢出現過a3次的記錄

字符串{M,N}字符串最少出現M次,最多出現N次

select * from info where name regexp 'ab{1,3}'; //從info表name字段中查詢ab出現最少1次最多3次的記錄

MYSQL中自帶通配符(LIKE關鍵詞),%可以表示任意長度的字符(包括0), -可以表示單個字符

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved