MySQL通配符模糊搜索匹配的使用关键技巧

 更新时间:2023年11月26日 10:46:34   作者:小万哥  
这篇文章主要为大家介绍了MySQL通配符模糊搜索匹配的使用关键技巧详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

SQL通配符字符

通配符字符用于替代字符串中的一个或多个字符。通配符字符与LIKE运算符一起使用。LIKE运算符用于在WHERE子句中搜索列中的指定模式。

返回所有以字母 'a' 开头的客户:

SELECT * FROM Customers
WHERE CustomerName LIKE 'a%';

通配符字符

符号描述
%表示零个或多个字符
_表示一个单个字符
[]表示括号内的任何单个字符
^表示括号内不在括号内的任何字符
-表示指定范围内的任何单个字符
{}表示任何转义字符
  • *不支持在PostgreSQL和MySQL数据库中。
  • **仅支持在Oracle数据库中。

演示数据库

以下是示例中使用的 Customers 表的一部分:

CustomerIDCustomerNameContactNameAddressCityPostalCodeCountry
1Alfreds FutterkisteMaria AndersObere Str. 57Berlin12209Germany
2Ana Trujillo Emparedados y heladosAna TrujilloAvda. de la Constitución 2222México D.F.05021Mexico
3Antonio Moreno TaqueríaAntonio MorenoMataderos 2312México D.F.05023Mexico
4Around the HornThomas Hardy120 Hanover Sq.LondonWA1 1DPUK
5Berglunds snabbköpChristina BerglundBerguvsvägen 8LuleåS-958 22Sweden

使用 % 通配符

% 通配符表示任意数量的字符,甚至是零个字符。

示例

返回以模式 'es' 结尾的所有客户:

SELECT * FROM Customers
WHERE CustomerName LIKE '%es';

示例

返回包含模式 'mer' 的所有客户:

SELECT * FROM Customers
WHERE CustomerName LIKE '%mer%';

使用 _ 通配符

通配符表示一个单个字符。它可以是任何字符或数字,但每个 代表一个且仅代表一个字符。

示例

返回所有以任何字符开头,然后是 "ondon" 的城市的客户:

SELECT * FROM Customers
WHERE City LIKE '_ondon';

示例

返回所有以 "L" 开头,然后是任何 3 个字符,以 "on" 结尾的城市的客户:

SELECT * FROM Customers
WHERE City LIKE 'L___on';

使用 [] 通配符

[] 通配符返回一个结果,如果括号内的任何字符都匹配。

示例

返回以 "b"、"s" 或 "p" 中的任何字符开头的所有客户:

SELECT * FROM Customers
WHERE CustomerName LIKE '[bsp]%';

使用 - 通配符

  • 通配符允许您在 [] 通配符内指定字符范围。

示例

返回以 "a"、"b"、"c"、"d"、"e" 或 "f" 开头的所有客户:

SELECT * FROM Customers
WHERE CustomerName LIKE '[a-f]%';

组合通配符

任何通配符,如 % 和 _,都可以与其他通配符一起使用。

示例

返回以 "a" 开头且至少为 3 个字符长的客户:

SELECT * FROM Customers
WHERE CustomerName LIKE 'a__%';

示例

返回第二个位置有 "r" 的客户:

SELECT * FROM Customers
WHERE CustomerName LIKE '_r%';

没有通配符

如果没有指定通配符,短语必须精确匹配才能返回结果。

示例

返回所有来自西班牙的客户:

SELECT * FROM Customers
WHERE Country LIKE 'Spain';

Microsoft Access通配符

Microsoft Access数据库有一些其他的通配符:

符号描述示例
*表示零个或多个字符bl* 可以找到 bl、black、blue 和 blob
?表示一个单个字符h?t 可以找到 hot、hat 和 hit
[]表示括号内的任何单个字符h[oa]t 可以找到 hot 和 hat,但不会找到 hit
!表示括号内不在括号内的任何字符h[!oa]t 可以找到 hit,但不会找到 hot 和 hat
-表示指定范围内的任何单个字符c[a-b]t 可以找到 cat 和 cbt
#表示一个单个数字符号2#5 可以找到 205、215、225、235、245、255、265、275、285 和 295

以上就是MySQL通配符模糊搜索匹配的使用关键技巧的详细内容,更多关于MySQL通配符模糊搜索匹配的资料请关注脚本之家其它相关文章!

相关文章

  • 宝塔服务器的mysql数据库自动备份到gitee项目

    宝塔服务器的mysql数据库自动备份到gitee项目

    文章介绍了一个开源脚本,用于自动备份宝塔服务器上的所有数据库,并将备份文件上传到Gitee项目中,脚本支持多服务器数据信息备份,并且可以定时执行备份任务
    2025-12-12
  • 登录mysql报错Can‘t connect to MySQL server on ‘localhost:3306‘ (10061)解决方法

    登录mysql报错Can‘t connect to MySQL server&n

    这篇文章主要给大家介绍了登录mysql报错 Can‘t connect to MySQL server on ‘localhost:3306‘ (10061)解决方法,文中有详细的解决步骤,需要的朋友可以参考下
    2023-09-09
  • 查看和修改MySQL最大连接数的完整步骤

    查看和修改MySQL最大连接数的完整步骤

    MySQL的max_connections是控制服务器同时允许的最大客户端连接数的参数,修改的时候要区分临时生效(重启失效)和永久生效(重启保留),且需结合服务器内存合理设置,避免内存耗尽,以下是完整的查看、修改步骤及注意事项,需要的朋友可以参考下
    2025-12-12
  • Mysql大表数据归档实现方案

    Mysql大表数据归档实现方案

    本文介绍了MySQL大表数据归档,通过创建历史订单表并基于主键id进行分批处理,避免影响线上业务和产生慢SQL,下面就来详细的介绍一下,感兴趣的可以了解一下
    2024-11-11
  • 如何解决mysql的count()函数条件表达式不生效问题

    如何解决mysql的count()函数条件表达式不生效问题

    该文章总结了SQL查询中`count`函数统计错误的原因,以及三种解决方法:使用`ornull`方法、`IF()`函数和`casewhen`表达式,当不满足条件时,表达式的值为NULL
    2024-11-11
  • Mysql关于数据库是否应该使用外键约束详解说明

    Mysql关于数据库是否应该使用外键约束详解说明

    MySQL 外键约束(FOREIGN KEY)是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表,外键所在的表就是从表。外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性
    2021-10-10
  • MySQL中的联合索引学习教程

    MySQL中的联合索引学习教程

    这篇文章主要介绍了MySQL中的联合索引学习教程,其中谈到了联合索引对排序的优化等知识点,需要的朋友可以参考下
    2015-11-11
  • windows10安装mysql5.7.18教程

    windows10安装mysql5.7.18教程

    windows10安装mysql5.7.18是这样安装的吗?这篇文章主要为大家详细介绍了win10下mysql5.7.18安装配置方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • MySQL中的存储过程异常处理

    MySQL中的存储过程异常处理

    这篇文章主要介绍了MySQL中的存储过程异常处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • mybatis mysql delete in操作只能删除第一条数据的方法

    mybatis mysql delete in操作只能删除第一条数据的方法

    这篇文章主要介绍了mybatis mysql delete in操作只能删除第一条数据的问题及解决方法,需要的朋友可以参考下
    2018-09-09

最新评论