比如我們有一張school表,里面有一個字段county_name,現(xiàn)在我們要查詢county_name字段中包含a-w字母和數(shù)字以外字符的記錄,那么sql該如何寫呢?請看下面的寫法:
select * from info where name regexp '[^a-w0-9]';
mysql中正則表達式使用regexp關(guān)鍵字,[^a-w0-9]表示匹配除了a-w字母和數(shù)字以外的字符。
下面向大家介紹mysql正則表達式的其他使用實例:
匹配名稱含有1000的所有行
SELECT * FROM a1 WHERE name regexp '1000'
匹配以000結(jié)尾的所有行,(.正則中表示:匹配任意一個字符)
SELECT * FROM a1 WHERE name regexp '.000'
Mysql正則大小寫都會匹配,為區(qū)分大小寫可使用binary關(guān)鍵字,如:
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開頭的記錄
$ 匹配字符結(jié)束的部分
select * from info where name regexp 'c$'; //從info表name字段中查詢以c結(jié)尾的記錄
. 匹配字符串中的任意一個字符,包括回車和換行
select * from info where name regexp '^L..y$'; //從info表name字段中查詢以L開頭y結(jié)尾中間有兩個任意字符的記錄
[字符集合]匹配字符集合中的任意字符
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字母和數(shù)字以外字符的記錄
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之前出現(xiàn)過a的記錄
+ 代表多個該字符前的字符,包括1個
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), -可以表示單個字符
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
您可能感興趣的文章:- mysql中如何使用正則表達式查詢
- MySql中使用正則表達式查詢的方法
- 詳解MySql基本查詢、連接查詢、子查詢、正則表達查詢
- MySQL使用正則表達式進行查詢操作經(jīng)典實例總結(jié)
- MySql官方手冊學習筆記2 MySql的模糊查詢和正則表達式
- MySQL全面瓦解之查詢的正則匹配詳解