目录

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: 使用通配符的技巧

通配符使用技巧建议:

  • 不要过度使用通配符;
  • 在确实需要使用通配符时,除非绝对必要,否则不要把它们用在搜索模式的开始处;
  • 仔细注意通配符的位置;

总之,通配符是一种极重要和有用的搜索工具;