比如我們有一張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), -可以表示單個字符
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!