《MySQL必知必会》通配符 ( like , % , _ ,)
关键字 LIke
WHERE 搜索子句中使用通配符,必须使用 LIKE 操作符。
% 百分号通配符
% 表示任意字符出现任意次数。(这里的任意当然包括 0 、1、无数)
select prod_id,prod_name
from products
where prod_name like 'jet%';
注意: 通配符搜索是可以区分大小写的。
使用关键字 Binary 即可
select prod_id,prod_name
from products
where prod_name like binary '%S%';
select prod_id,prod_name
from products
where prod_name like binary '%s%';
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服务
从上面例子也可以看到,是可以使用多个 ‘ % ’ 通配符进行搜索的。
注意,如果以上例子替换为 ‘%anvil ’ ,anvil 后跟一个空格,那将不会匹配到以上结果,为空格会干扰通配符匹配,这可以通过使用函数取出为空格。
like concat('%','anvil','%');
上一章说到 NULL ,同样 NULL 不能作为有效值被 % 匹配到,NULL 对于数据库来说是未知的,自然不能下定论 NULL 是否匹配。
_ 下划线通配符
_ 只匹配单个字符。
select prod_id,prod_name
from products
where prod_name like binary '_ ton anvil';
再次重申 , _ 总是匹配一个字符,不能多也不能少。
使用通配符的注意事项
正如所见,MySQL的通配符很有用。但这种功能是有代价的:通配符搜索的处理一般要比前面讨论的其他搜索所花时间更长。这里给出一些使用通配符要记住的技巧。
- 不要过度使用通配符。如B果其他操作符能达到相同的目的,应该使用其他操作符。
- 在确实需要使用通配符时,除非绝对有必要,否则不要把它们用在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。
- 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。
不要过度使用通配符
不要过度使用通配符
不要过度使用通配符
以后的函数将搜索会做到更好的处理,更高的性能。