前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL 通配符:用于模糊搜索和匹配的 SQL 关键技巧

SQL 通配符:用于模糊搜索和匹配的 SQL 关键技巧

原创
作者头像
小万哥
发布2023-11-24 20:08:05
2280
发布2023-11-24 20:08:05
举报
文章被收录于专栏:程序人生丶程序人生丶

SQL通配符字符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE 'a%';

通配符字符

符号

描述

%

表示零个或多个字符

_

表示一个单个字符

[]

表示括号内的任何单个字符

^

表示括号内不在括号内的任何字符

-

表示指定范围内的任何单个字符

{}

表示任何转义字符

  • *不支持在PostgreSQL和MySQL数据库中。
  • **仅支持在Oracle数据库中。

演示数据库

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

CustomerID

CustomerName

ContactName

Address

City

PostalCode

Country

1

Alfreds Futterkiste

Maria Anders

Obere Str. 57

Berlin

12209

Germany

2

Ana Trujillo Emparedados y helados

Ana Trujillo

Avda. de la Constitución 2222

México D.F.

05021

Mexico

3

Antonio Moreno Taquería

Antonio Moreno

Mataderos 2312

México D.F.

05023

Mexico

4

Around the Horn

Thomas Hardy

120 Hanover Sq.

London

WA1 1DP

UK

5

Berglunds snabbköp

Christina Berglund

Berguvsvägen 8

Luleå

S-958 22

Sweden

使用 % 通配符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE '%es';

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE '%mer%';

使用 _ 通配符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE City LIKE '_ondon';

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE City LIKE 'L___on';

使用 [] 通配符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE '[bsp]%';

使用 - 通配符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE '[a-f]%';

组合通配符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE 'a__%';

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE CustomerName LIKE '_r%';

没有通配符

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

示例

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

代码语言:sql
复制
SELECT * FROM Customers
WHERE Country LIKE 'Spain';

Microsoft Access通配符

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

符号

描述

示例

*

表示零个或多个字符

bl* 可以找到 bl、black、blue 和 blob

?

表示一个单个字符

h?t 可以找到 hot、hat 和 hit

[]

表示括号内的任何单个字符

hoat 可以找到 hot 和 hat,但不会找到 hit

!

表示括号内不在括号内的任何字符

h!oat 可以找到 hit,但不会找到 hot 和 hat

-

表示指定范围内的任何单个字符

ca-bt 可以找到 cat 和 cbt

表示一个单个数字符号

2#5 可以找到 205、215、225、235、245、255、265、275、285 和 295

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • SQL通配符字符
  • 示例
  • 通配符字符
  • 演示数据库
  • 使用 % 通配符
    • 示例
      • 示例
      • 使用 _ 通配符
        • 示例
          • 示例
          • 使用 [] 通配符
            • 示例
            • 使用 - 通配符
              • 示例
              • 组合通配符
                • 示例
                  • 示例
                  • 没有通配符
                    • 示例
                    • Microsoft Access通配符
                    相关产品与服务
                    云数据库 MySQL
                    腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                    领券
                    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档