MySQL数据库----通配符,正则表达式

目录

1,通配符

定义: 用来匹配值的一部分的特殊字符。通配符本身实际时SQL的WHERE子句中有特殊含义的字符,SQL支持几种通配符。

为了在句子中使用通配符,必须使用LIKE操作符。LIKE指示MySQL后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较。

1.1,百分号(%)通配符

...
% 表示任何字符出现任意次数。

【例1】:为了找出所有以词 jet 起头的字段。

SELECT prod_id , prod_name from products WHERE prod_name LIKE 'jet%';

...

【例2】:表示匹配任何位置包含文本 anvil 的值

SELECT prod_id , prod_name FROM products WHERE prod_name LIKE '%anvil%';

...

【例3】:找出以s起头,以e结尾的所有字段

SELECT prod_name FROM products WHERE prod_name LIKE 's%e';

1.2,下划线(_)通配符

...
与 % 类似,但仅代表单个字符

举个例子:

SELECT prod_id , prod_name FROM products WHERE prod_name LIKE '_ ton anvil';

结果

1 ton anvil

2 ton anvil

如果换成 %

结果

0.55 ton anvil

1 ton anvil

2 ton anvil
【例 1】查询名字为三个字符且中间字符为 "a" 的所有用户:

SELECT * FROM users WHERE name LIKE 'a ';

...

【例 2】查询名字以 "J" 开头且第二个字符任意的所有用户:

SELECT * FROM users WHERE name LIKE 'J_';

1.3,方括号( [] )通配符

功能:用于指定字符集合,代表方括号内的任意一个字符。

【例 1】查询名字第一个字符是 "A"、"B" 或 "C" 的所有用户

SELECT * FROM users WHERE name LIKE '[ABC]%';

...

【例 2】查询名字中包含 "a"、"e" 或 "i" 的所有用户:

SELECT * FROM users WHERE name LIKE '%[aei]%';

1.3,方括号( ^ )通配符

功能:在方括号内使用时,表示否定,即匹配不在方括号内的任意一个字符。

【例 1】查询名字第一个字符不是 "A"、"B" 或 "C" 的所有用户:

SELECT * FROM users WHERE name LIKE '[^ABC]%';

1.4,反斜杠(\)通配符

【例 1】查询名字中包含字符 "%" 的所有用户:

SELECT * FROM users WHERE name LIKE '%\%%';

1.5,注意事项

通配符很有用,但是是有代价的。
通配符搜索的处理一般要比前面讨论的其他搜索花时间更长。

1,不要过度使用通配符。

2,尽量不要把它们用在搜索模式的开始处。

3,仔细注意他通配符的位置

2,正则表达式

定义 :正则表达式是用来匹配文本的特殊的串

2.1,基本字符匹配

关键字:REGEXP

2.1.1 匹配文本 '文本' 表示包含"文本" 的字符串

【例】检索列 prod_name 包含文本 1000 的所有行。

SELECT prod_name FROM products WHERE prod_name REGEXP '1000';

其中 REGEXP '1000' 表示包含 1000 文本。

【注意】: 正则表达式可能会降低性能。

2.1.2 进行OR匹配,搜索两个串之一 '文本1|文本2|文本3'

【例】检索列 prod_name 包含文本 1000 或者 2000 的所有行。

SELECT prod_name FROM products WHERE prod_name REGEXP '1000|2000';

2.1.3 匹配单一特定字符 [123]

【例】匹配 prod_name 字段文本包含 1 ton 或者 2 ton 或者 3 ton 的所有行

SELECT prod_name FROM products WHERE prod_name REGEXP '[123] ton';

123\] 表示匹配 1 或者 2 或者 3 ### 2.2,匹配范围 集合可用来定义要匹配的一个或多个字符。例如,下面的集合要匹配数字 0到9 \[0123456789

为了简化这种集合,可使用 - 来定义一个范围。如 [0-9]

不一定是数字,也可以是字母 如 [a-z]

【例】

SELECT prod_name FROM products WHERE prod_name REGEXP '[1-5] ton';

2.3,匹配特殊字符

正则表达式语言由具有特定含义的特殊字符构成,我们已经看到 [] | - 等,如果你要匹配这些特殊字符,该怎么做呢?

为了匹配特殊字符,必须用 \ 为前导。

【例】找出 vend_name 字段文本中包含 - 字符的所有行

SELECT vend_name FROM vendors WHERE vend_name REGEXP '\-'

转义字符,

项目 Value
\\f 换页
\\n 换行
\\r 回车
\\t 制表
\\v 纵向制表
项目 Value
* 0个或1个匹配
+ 1个或多个匹配
? 0个或1个匹配
{n} 指定数目匹配
{n,} 不少于指定数目的匹配
{n,m} 匹配数目的范围
相关推荐
q_19132846952 小时前
基于SpringBoot2+Vue2的宠物上门服务在线平台
java·vue.js·spring boot·mysql·宠物·计算机毕业设计·源码分享
无限大.2 小时前
计算机十万个为什么--数据库索引
数据库·oracle
思成不止于此2 小时前
MySQL 数据操作:增删改核心语法全解析
数据库·笔记·学习·mysql
得物技术2 小时前
数据库AI方向探索-MCP原理解析&DB方向实战|得物技术
数据库
Arva .2 小时前
MySQL 的锁类型有哪些
数据库·mysql
APIshop3 小时前
微店关键词搜索商品列表 API 实战:micro.item_search 全流程指南
数据库
翔云1234563 小时前
在MySQL中,使用物理备份工具 xtrabackup备份扩容从库,从库上的gtid_executed和gtid_purged变化过程
数据库·mysql
liulilittle4 小时前
Linux shell 搜索指定后缀名文件,并复制到指定目录。
linux·服务器·数据库
必胜刻4 小时前
Redis哨兵模式(Linux)
linux·数据库·redis