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