目录
8.1 : like 操作符
8.1.1:百分号(%)通配符
8.1.2: 下划线(_)通配符
8.2: 使用通配符的技巧
8.1 : like 操作符
通配符(wildcard):用来匹配值的一部分的特殊字符;
搜索模式(search pattern):由子棉值,通配符或两者组合构成的搜索条件;
通配符本身实际是SQL的where子句中有特殊含义的字符;
为在搜索子句中使用通配符,必须使用like操作符;
Like指示Mysql,后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较;
谓词(predi-cate):like是谓词而不是操作符;
8.1.1:百分号(%)通配符
最常使用的通配符是百分号(%);在搜索串中,%表示任何字符出现任意次数
- 例子:找出所有以词jet起头的产品;
(从products中选取prod_id和prod_names数据,提取prod_name 中jet起头的产品)
select prod_id, prod_name from products
where prod_name like 'jet%';
区分大小写:
根据mysql的配置方式,搜索可以是区分大小写的。如果区分大小写,‘jet%’ 与JetPack 1000将不匹配;
通配符可在搜索模式中任意位置使用,并且可以使用多个通配符;
例子:使用两个通配符,它们位于模式的两端
select prod_id, prod_name from products
where prod_name like '%anvil%';
搜索模式'%anvil%' 表示匹配任何位置包含文本anvil的值,而不论它之前或之后出现什么字符;
通配符可出现在搜索模式的中间
- 例子:找出以s起头以e结尾的所有产品;
select prod_id, prod_name from products
where prod_name like 's%e';
重要的是要注意到,出了一个或多个字符外,%还能匹配0个字符;
%代表搜索模式中给定位置的0个、1个或多个字符;
注意尾空格:尾空格可能会干扰通配符匹配;ex:‘%anvil% (可通过),反之 '%anvil %(不可通过);
注意null:NULL通配符是不可匹配到的;
8.1.2: 下划线(_)通配符
(_)下划线通用符的用途与%一样,但下划线只匹配单个字符而不是多个字符;
例子:
select prod_id, prod_name from products
where prod_name like '_ ton anvil';
此where子句中的搜索模式给出了后面跟有文本的两个通配符;返回两个产品
对照,使用%通配符,返回三个产品;
select prod_id, prod_name from products
where prod_name like '% ton anvil';
与%能匹配0个字符不一样, _ 总是匹配一个字符,不能多也不能少;
8.2: 使用通配符的技巧
通配符使用技巧建议:
- 不要过度使用通配符;
- 在确实需要使用通配符时,除非绝对必要,否则不要把它们用在搜索模式的开始处;
- 仔细注意通配符的位置;
总之,通配符是一种极重要和有用的搜索工具;