美文网首页
Mysql第八章 - 用通配符进行过滤

Mysql第八章 - 用通配符进行过滤

作者: 足__迹 | 来源:发表于2024-03-24 16:41 被阅读0次

前面介绍的所有操作符都是针对已知值进行过滤的。不管是匹配一个还是多个值,测试大于还是小于已知值,或者检查某个范围的值,共同点是过滤中使用的值都是已知的。利用通配符可创建比较特定数据的搜索模式

通配符:用来匹配值的一部分的特殊字符。
搜索模式:由字面值、通配符或两者组合构成的搜索条件。

通配符本身实际是SQL的WHERE子句中有特殊含义的字符,SQL支持几种通配符。为在搜索子句中使用通配符,必须使用LIKE操作符。LIKE指示MySQL,后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较。

百分号(%)通配符

%表示任何字符出现任意次数

  • 举例1:
    输入:SELECT * FROM Test.student s WHERE s.age like '2%'
    分析:在执行这条子句时,检索2开头的数据
    输出:


    image.png
  • 举例2:
    输入:SELECT * FROM Test.student s WHERE s.name like '%王%'
    分析:通配符可在搜索模式中任意位置使用,并且可以使用多个通配符,检索姓名中包含“王”
    输出:


    image.png

下划线(_)通配符

另一个有用的通配符是下划线(_)。下划线的用途与%一样,但下划线只匹配单个字符而不是多个字符。

  • 举例3
    输入:SELECT * FROM Test.student s WHERE s.name like '王_'
    分析:匹配姓名中开头为“王”后一个字的数据

    输入: image.png

使用通配符的技巧

正如所见,MySQL的通配符很有用。但这种功能是有代价的:通配符搜索的处理一般要比前面讨论的其他搜索所花时间更长。
1.不要过度使用通配符。如果其他操作符能达到相同的目的,应该使用其他操作符。
2.在确实需要使用通配符时,除非绝对有必要,否则不要把它们用在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。

相关文章

网友评论

      本文标题:Mysql第八章 - 用通配符进行过滤

      本文链接:https://www.haomeiwen.com/subject/ofmhvdtx.html