《MySQL必知必会》通配符 ( like , % , _ ,)

《MySQL必知必会》通配符 ( like , % , _ ,)

关键字 LIke

WHERE 搜索子句中使用通配符,必须使用 LIKE 操作符。

% 百分号通配符

% 表示任意字符出现任意次数。(这里的任意当然包括 0 、1、无数)

select prod_id,prod_name
from products 
where prod_name like 'jet%';

image-20200816002354006

注意: 通配符搜索是可以区分大小写的。

使用关键字 Binary 即可

select prod_id,prod_name
from products
where prod_name like binary '%S%';

image-20200816002726946

select prod_id,prod_name
from products
where prod_name like binary '%s%';

image-20200816002807284

show viriables like '%lower%';
查看是否区分大小写;
ower_case_table_names参数详解:
lower_case_table_names = 0
其中 0:区分大小写,1:不区分大小写
MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:
   1、数据库名与表名是严格区分大小写的;
   2、表的别名是严格区分大小写的;
   3、列名与列的别名在所有的情况下均是忽略大小写的;
   4、变量名也是严格区分大小写的;

修改不区分大小写,在my.cnf中的[mysqld]后面添加lower_case_table_names=1,重启MYSQL服务

从上面例子也可以看到,是可以使用多个 ‘ % ’ 通配符进行搜索的。

image-202008160034

注意,如果以上例子替换为 ‘%anvil ’ ,anvil 后跟一个空格,那将不会匹配到以上结果,为空格会干扰通配符匹配,这可以通过使用函数取出为空格。

like concat('%','anvil','%');

上一章说到 NULL ,同样 NULL 不能作为有效值被 % 匹配到,NULL 对于数据库来说是未知的,自然不能下定论 NULL 是否匹配。

_ 下划线通配符

_ 只匹配单个字符。

select prod_id,prod_name
from products
where prod_name like binary '_ ton anvil';

image-20200816004214627

再次重申 , _ 总是匹配一个字符,不能多也不能少。

使用通配符的注意事项

正如所见,MySQL的通配符很有用。但这种功能是有代价的:通配符搜索的处理一般要比前面讨论的其他搜索所花时间更长。这里给出一些使用通配符要记住的技巧。

  • 不要过度使用通配符。如B果其他操作符能达到相同的目的,应该使用其他操作符。
  • 在确实需要使用通配符时,除非绝对有必要,否则不要把它们用在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的
  • 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据

不要过度使用通配符

不要过度使用通配符

不要过度使用通配符

以后的函数将搜索会做到更好的处理,更高的性能。

posted @ 2020-08-16 11:43  L1ng14  阅读(934)  评论(0编辑  收藏  举报