当前位置: 首页 > news >正文

SQL通配符字符

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

http://www.lryc.cn/news/248397.html

相关文章:

  • 力扣 144.二叉树的前序遍历
  • Ubuntu网络问题的解决
  • Git 本地服务器搭建 Windows
  • 【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向后Euler)【理论到程序】
  • mac安装homebrew/brew遇到443
  • VSCODE 在新窗口中打开
  • Python与设计模式--解释器模式
  • 代码随想录算法训练营第36天| 435. 无重叠区间 763.划分字母区间 56. 合并区间
  • 1990-2021年上市公司排污费和环境保护税数据
  • MySQL主从复制架构
  • 制作心理咨询小程序的详细指南
  • Apache httpd-2.4安装并配置转发
  • 【Cisco Packet Tracer】DHCP/FTP/WEB/DNS实验
  • 模糊C均值聚类(Fuzzy C-means clustering,FCM)的基本概念,详细流程以及广泛应用!
  • chapter10-homework-Java
  • 前端如何中断请求 ( axios、原生 ajax、fetch)
  • CSS实现一些小功能
  • Ubuntu安装nfs服务步骤
  • android开发:子线程更新UI界面
  • P9242 [蓝桥杯 2023 省 B] 接龙数列(dp+最长接龙序列+分类)
  • 网络运维与网络安全 学习笔记2023.11.29
  • Java实现通过经纬度求两个任意地点在球面上的距离
  • vscode使用插件KoroFileHeader添加注释
  • NSAttributedString设置折行方式NSLineBreakByTruncatingTail,计算高度出错,高度返回异常。
  • YOLOv8改进 | 2023 | DWRSeg扩张式残差助力小目标检测 (附修改后的C2f+Bottleneck)
  • ssm+vue的物资物流系统的设计与实现(有报告)。Javaee项目,ssm vue前后端分离项目。
  • 纵行科技获评“汽车物流行业优秀技术装备供应商”
  • Chrome和chromedriver版本不匹配导致的UI自动化测试无法运行的问题
  • [go 面试] 深入理解进程、线程和协程的概念及区别
  • 人工智能即将彻底改变你使用计算机的方式