前面介绍的所有操作符都是针对已知值进行过滤的。不管是匹配一个还是多个值,测试大于还是小于已知值,或者检查某个范围的值,共同点是过滤中使用的值都是已知的。利用通配符可创建比较特定数据的搜索模式
通配符:用来匹配值的一部分的特殊字符。
搜索模式:由字面值、通配符或两者组合构成的搜索条件。
通配符本身实际是SQL的WHERE子句中有特殊含义的字符,SQL支持几种通配符。为在搜索子句中使用通配符,必须使用LIKE操作符。LIKE指示MySQL,后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较。
百分号(%)通配符
%表示任何字符出现任意次数
-
举例1:
输入:SELECT * FROM Test.student s WHERE s.age like '2%'
分析:在执行这条子句时,检索2开头的数据
输出:
-
举例2:
输入:SELECT * FROM Test.student s WHERE s.name like '%王%'
分析:通配符可在搜索模式中任意位置使用,并且可以使用多个通配符,检索姓名中包含“王”
输出:
下划线(_)通配符
另一个有用的通配符是下划线(_)。下划线的用途与%一样,但下划线只匹配单个字符而不是多个字符。
-
举例3
输入:
输入:SELECT * FROM Test.student s WHERE s.name like '王_'
分析:匹配姓名中开头为“王”后一个字的数据
使用通配符的技巧
正如所见,MySQL的通配符很有用。但这种功能是有代价的:通配符搜索的处理一般要比前面讨论的其他搜索所花时间更长。
1.不要过度使用通配符。如果其他操作符能达到相同的目的,应该使用其他操作符。
2.在确实需要使用通配符时,除非绝对有必要,否则不要把它们用在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。