MySQL通配符与正则表达式搜过滤数据详解
作者:随处可见的打字员 时间:2024-01-23 03:12:54
通配符过滤
通配符:用来匹配值的一部分特殊字符。
通配符可以在搜索模式中任意位置使用,并且可以使用多个通配符。
搜索模式:由字面值、通配符或者两者组合构成的搜索条件。
语法(使用LIKE操作符):
SELECT [column_name]
FROM [table_name]
WHERE [column_name] LIKE '[string]';
通配符 %
‘%’ 表示任何字符出现任意次数,例如 LIKE ‘jet%’ 匹配词jet起头的值,‘%anvil%’ 匹配任何位置包含文本anvil的值。
注意:
根据MySQL的配置方式,搜索可以是区分大小写的;
‘%’ 可以匹配0个字符;
值的尾空格会干扰通配符匹配,最好在搜索模式最后附加一个%;
‘%’ 不能匹配NULL。
通配符 _
‘_’ 只匹配单个字符。
技巧
不要过度使用通配符,因为这会很花时间;
如有必要,使用通配符匹配在搜索的最后;
正则表达式过滤
语法(使用REGEXP操作符):
SELECT [column_name]
FROM [table_name]
WHERE [column_name] REGEXP '[string]';
字符匹配
基本匹配:‘.’ 表示匹配任意一个字符。
正则表达式匹配不区分大小写,使用BINARY关键字区分,例如WHERE prod_name REGEXP BINARY ‘JetPack .000’。
OR匹配:‘1000|2000’ 表示匹配1000或者2000。
多字符匹配:‘[123]’ 表示匹配 1 或 2 或 3,是 [1|2|3] 的缩写。
但是 ‘[1|2|3] Ton’ 和 ‘1|2|3 Ton’ 匹配结果并不相同,后者表示匹配 1 或 2 或 3 Ton。
否定字符匹配:‘[^123]’ 表示匹配除这些字符外的任何东西。
匹配范围:‘[0-9]’ 与 ‘[0123456789]’ 相同。‘[a-z]’ 匹配任意字母字符。
匹配特殊字符:使用转义字符 ‘\’,例如 ‘\.’ 、’ \|’ 、‘\[’ 、‘\’。
其他字符
空白元字符
元字符 | 说明 |
---|---|
\\f | 换页 |
\\n | 换行 |
\\r | 回车 |
\\t | 制表 |
\\v | 纵向制表 |
字符类
类 | 说明 |
---|---|
[:alnum:] | 任意字母和数字 |
[:alpha:] | 任意字符(同[a-zA-Z]) |
[:blank:] | 空格和制表 |
[:cntrl:] | ASCII控制字符(0-31和127) |
[:digit:] | 任意数字 |
[:graph:] | 与[:print:]相同,但是不包括空格 |
[:lower:] | 任意小写字母 |
[:print:] | 任意可打印字符 |
[:punct:] | 既不在[:alnum:]也不在[:cntrl:] 中的任意字符 |
[:space:] | 包括空格在内的任意空白字符 |
[:upper:] | 任意大写字符 |
[:xdigit:] | 任意十六进制数字 |
重复元字符
元字符 | 说明 |
---|---|
* | 0个或多个匹配 |
+ | 1个或多个匹配 |
? | 0个或多个匹配 |
{n} | 指定数目匹配 |
{n, } | 不少于指定数目的匹配 |
{n, m} | 匹配数目的范围(m不超过255) |
定位元字符
元字符 | 说明 |
---|---|
^ | 文本的开始 |
$ | 文本的结尾 |
[[:<:]] | 词的开始 |
[[:>:]] | 词的结尾 |
举例:
SELECT prod_name
FROM products
WHERE prod_name REGEXP '^[0-9\\.]';
对比
如果匹配文本在列值中出现,则LIKE不会匹配,但是REGEXP会匹配。
可以通过用 ^ 开始每个表达式,用 $ 结束每个表达式,使得REGEXP的作用和LIKE一样。
正则表达式测试
SELECT 'hello' REGEXP '[0-9]';//结果返回0
来源:https://blog.csdn.net/qq_40948559/article/details/123999341
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Oracle PL/SQL入门案例实践
Python连接es之查询方式示例汇总
PHP生成饼图的示例代码
Oracle中instr函数使用方法
详解Python中__str__和__repr__方法的区别
深入探讨SQL Server 2008商务智能(BI)
![](https://img.aspxhome.com/file/UploadPic/200812/20081223182357659.jpg)
SpringBoot用多线程批量导入数据库实现方法
numpy.float32的典型用法
Python实现的直接插入排序算法示例
![](https://img.aspxhome.com/file/2023/1/123531_0s.png)
MySQL七大JOIN的具体使用
![](https://img.aspxhome.com/file/2023/8/80138_0s.png)
Python函数参数定义及传递方式解析
python深度学习之多标签分类器及pytorch实现源码
![](https://img.aspxhome.com/file/2023/1/97491_0s.jpg)
正则表达式不匹配某个字符串
Mootools 1.2教程(9)——输入过滤第二部分(字符串)
Golang中由零值和gob库特性引起BUG解析
SQL Server 2005中数据库镜像的四个问题
SQL实战演练之网上商城数据库用户信息数据操作
我们用什么来衡量设计3:定量研究的风险
详解express + mock让前后台并行开发
![](https://img.aspxhome.com/file/2023/7/129367_0s.png)