「这是我参与11月更文挑战的第15天,活动详情查看:2021最后一次更文挑战」
1、简介
当对未知或者说知道某一部分的值进行过滤时,可以使用like操作符;like操作符用于模糊匹配。
like支持两个通配符,它们分别是:
- %通配符,用于匹配多个字符
- _通配符,用于匹配单个字符
通配符根据其所处未知又分为六种匹配方式:
匹配方式 | 作用 |
---|---|
%xx | 表示右匹配,右边的xx字符需要完全相等,左边可以是任意字符,也可以没有字符 |
_xx | 表示右匹配,右边的xx字符需要完全相等,左边可以是任意一个字符,必须是一个不能没有字符 |
xx% | 表示左匹配,右边的xx字符需要完全相等,右边可以是任意字符,也可以没有字符 |
xx_ | 表示左匹配,左边的xx字符需要完全相等,右边可以是任意一个字符,必须是一个不能没有字符 |
%xx% | 表示中间匹配,中间必须完全相等,左右两边可以是任意字符,左右两边可以没有其他字符 |
xx | 表示中间匹配,中间必须完全相等,左右两边可以是任意一个字符,左右两边必须是一个不能没有字符 |
2、正文
首先准备一张User表,DDL和表数据如下所示,可以直接复制使用。
1 | sql复制代码SET NAMES utf8mb4; |
数据的初始顺序如下所示:
1 | sql复制代码mysql> select * from user; |
2.1 %通配符
%通配符有三种匹配方式,分别是%xx、xx%、%xx%,接下来演示三者的简单用法。
需求:
查询user表中姓氏为张的用户
语句:
1 | sql复制代码mysql> select * from user where name like '张%'; |
需求:
查询user表中姓名以七结尾的用户
语句:
1 | sql复制代码mysql> select * from user where name like '%七'; |
需求:
查询user表中姓名中包含李字符的用户
语句:
1 | sql复制代码mysql> select * from user where name like '%李%'; |
2.2 _通配符
_通配符和%通配符的区别在于 _只匹配一个字符,并且必须匹配一个字符;而%可以匹配多个字符,甚至0个字符。
需求:
查询user表中姓氏为李,并且名字只有两个中文的用户
语句:
1 | sql复制代码mysql> select * from user where name like '李_'; |
需求:
查询user表中名为三的用户
语句:
1 | sql复制代码mysql> select * from user where name like '_三'; |
需求:
查询user表中姓名为三个子,并且第二个子为麻的用户
语句:
1 | sql复制代码mysql> select * from user where name like '_麻_'; |
2.3 通配符使用注意事项
通配符非常强大,我相信很多人都经常使用通配符,但是字符串匹配往往并不是一件性能特别快的事情。因此我们在使用通配符的时候有一些注意事项需要时刻记住。
- 能不用则不用的原则,不用能避免通配符带来的全部问题,所以如果其他操作符能查询出来,就不要使用like
- 在使用通配符的地方,尽量缩小查询范围,如果有多个查询条件,应该考虑能否将通配符放置到其他过滤条件的后面
- 特别注意通配符的选择,以及通配符的位置,可以参考六种匹配方式选择自己合适的
本文转载自: 掘金