Mysql 模糊查询和正则表达式实例详解
作者:有请小发菜
在MySQL中,可以使用LIKE运算符进行模糊查询,LIKE运算符用于匹配字符串模式,其中可以使用通配符来表示任意字符或字符序列,这篇文章主要介绍了Mysql 模糊查询和正则表达式实例详解,需要的朋友可以参考下
一、模糊查询
1.1 LIKE运算符
在MySQL中,可以使用LIKE运算符进行模糊查询。LIKE运算符用于匹配字符串模式,其中可以使用通配符来表示任意字符或字符序列。
示例代码
SELECT * FROM table_name WHERE column_name LIKE 'pattern';
table_name
:要查询的表名column_name
:要查询的列名pattern
:要匹配的模式
通配符
%
:表示任意字符序列(包括空字符)_
:表示任意单个字符
示例
SELECT * FROM users WHERE name LIKE '%John%';
以上示例将返回所有名字中包含"John"的用户。
1.2 NOT LIKE运算符
NOT LIKE运算符用于排除符合指定模式的结果。
示例代码
SELECT * FROM table_name WHERE column_name NOT LIKE 'pattern';
示例
SELECT * FROM users WHERE name NOT LIKE '%John%';
以上示例将返回所有名字中不包含"John"的用户。
1.3 REGEXP运算符
REGEXP运算符用于基于正则表达式进行模糊查询。正则表达式是一种强大的模式匹配工具,可以用于更复杂的模式匹配。
示例代码
SELECT * FROM users WHERE name NOT LIKE '%John%';
示例
SELECT * FROM users WHERE name REGEXP '[Jj]ohn';
以上示例将返回所有名字中包含以"J"或"j"开头,后面跟着"ohn"的用户。
二、正则表达式
2.1 正则表达式基础
正则表达式是一种用于匹配字符串模式的工具。它使用一种特定的语法来描述要匹配的模式。
.
:匹配任意字符^
:匹配字符串的开始位置$
:匹配字符串的结束位置[]
:匹配指定字符集中的任意一个字符[^]
:匹配任意不在指定字符集中的字符*
:匹配前面的元素零次或多次+
:匹配前面的元素一次或多次?
:匹配前面的元素零次或一次|
:匹配两个或多个表达式中的任意一个
SELECT * FROM table_name WHERE column_name REGEXP 'pattern';
2.2 REGEXP运算符
在MySQL中,可以使用REGEXP运算符基于正则表达式进行模糊查询。
示例代码
SELECT * FROM table_name WHERE column_name REGEXP 'pattern';
示例
SELECT * FROM users WHERE name REGEXP '^[A-Za-z]+$';
以上示例将返回所有名字只包含字母的用户。
2.3 RLIKE运算符
RLIKE运算符是REGEXP运算符的同义词,可以使用RLIKE代替REGEXP进行正则表达式匹配。
示例代码
SELECT * FROM table_name WHERE column_name RLIKE 'pattern';
示例
SELECT * FROM users WHERE name RLIKE '^[A-Za-z]+$';
以上示例将返回所有名字只包含字母的用户。
参考资料
到此这篇关于Mysql 模糊查询和正则表达式的文章就介绍到这了,更多相关Mysql 模糊查询正则表达式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!