比如我們有一張school表,里面有一個(gè)字段county_name,現(xiàn)在我們要查詢county_name字段中包含a-w字母和數(shù)字以外字符的記錄,那么sql該如何寫呢?請(qǐng)看下面的寫法:
select * from info where name regexp '[^a-w0-9]';
mysql中正則表達(dá)式使用regexp關(guān)鍵字,[^a-w0-9]表示匹配除了a-w字母和數(shù)字以外的字符。
下面向大家介紹mysql正則表達(dá)式的其他使用實(shí)例:
匹配名稱含有1000的所有行
SELECT * FROM a1 WHERE name regexp '1000'
匹配以000結(jié)尾的所有行,(.正則中表示:匹配任意一個(gè)字符)
SELECT * FROM a1 WHERE name regexp '.000'
Mysql正則大小寫都會(huì)匹配,為區(qū)分大小寫可使用binary關(guān)鍵字,如:
SELECT * FROM a1 WHERE name LIKE binary '%J%' #使用LIKE+通配符匹配大寫J
SELECT * FROM a1 WHERE name regexp binary 'j' #使用正則匹配小寫j
|為正則表達(dá)式的OR操作符,表示匹配其中之一
SELECT * FROM a1 WHERE name regexp binary 'a|j|G'
匹配特定字符,使用[]括起來的字符,將會(huì)匹配其中任意單個(gè)字符。
SELECT * FROM a1 WHERE name regexp '[12]st'
以上'[12]st'正則表達(dá)式,[12]定義一組字符,它的意思是匹配1或2
^ 匹配字符開始的部分
select * from info where name regexp '^L'; //從info表name字段中查詢以L開頭的記錄
$ 匹配字符結(jié)束的部分
select * from info where name regexp 'c$'; //從info表name字段中查詢以c結(jié)尾的記錄
. 匹配字符串中的任意一個(gè)字符,包括回車和換行
select * from info where name regexp '^L..y$'; //從info表name字段中查詢以L開頭y結(jié)尾中間有兩個(gè)任意字符的記錄
[字符集合]匹配字符集合中的任意字符
select * from info where name regexp '[ceo]'; //從info表name字段中查詢包含c、e、o三個(gè)字母中任意一個(gè)的記錄
[^字符集合]匹配除了字符集合外的任意字符
select * from info where name regexp '[^a-w0-9]'; //從info表name字段中查詢包含a-w字母和數(shù)字以外字符的記錄
s1|s2|s3 匹配s1s2s3中的任意一個(gè)
select * from info where name regexp 'ic'; //從info表name字段中查詢包含'ic'的記錄
* 代表多個(gè)該字符前的字符,包括0個(gè)或1個(gè)
select * from info where name regexp 'a*c'; 從info表name字段中查詢c之前出現(xiàn)過a的記錄
+ 代表多個(gè)該字符前的字符,包括1個(gè)
select * from info where name regexp 'a+c';//從info表name字段中查詢c之前出現(xiàn)過a的記錄
字符串{N} 字符串出現(xiàn)N次
select * from info where name regexp 'a{3}'; //從info表name字段中查詢出現(xiàn)過a3次的記錄
字符串{M,N}字符串最少出現(xiàn)M次,最多出現(xiàn)N次
select * from info where name regexp 'ab{1,3}'; //從info表name字段中查詢ab出現(xiàn)最少1次最多3次的記錄
MYSQL中自帶通配符(LIKE關(guān)鍵詞),%可以表示任意長度的字符(包括0), -可以表示單個(gè)字符
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
您可能感興趣的文章:- mysql中如何使用正則表達(dá)式查詢
- MySql中使用正則表達(dá)式查詢的方法
- 詳解MySql基本查詢、連接查詢、子查詢、正則表達(dá)查詢
- MySQL使用正則表達(dá)式進(jìn)行查詢操作經(jīng)典實(shí)例總結(jié)
- MySql官方手冊(cè)學(xué)習(xí)筆記2 MySql的模糊查詢和正則表達(dá)式
- MySQL全面瓦解之查詢的正則匹配詳解