SQLite 关键字

SQLite GLOB 关键字用于 WHERE 子句中搜索指定模式指定的列。与 GLOB 关键字结合使用的通配符如下:

注意:NOT GLOB 关键字是 GLOB 的否定 关键字。

注意:与 LIKE 关键字,GLOB 区分大小写,它遵循 UNIX 语法来指定给定的通配符。

SQLite 中的通配符

符号说明示例
*表示零个、一个或多个字符。'J*'表示以"J"开头的值,例如 - John、Jo 和 Jack 等。
?代表一个字符。'?o*' 表示第二个位置有"o"的值,例如 - John、Jo 和 Journey 等。

语法

在 SQLite 中使用 GLOB 关键字的语法如下:

SELECT column1, column2, ...
FROM table_name
WHERE column GLOB pattern; 

下表描述了与 GLOB 关键字一起使用的模式,并使用 (*) 和 (? ).

模式描述
' J*'以"J"开头的值。
'*n'以"结尾的值n"。
'*oh*'任意位置有"oh"的值。
'?o*'第二个位置有"o"的值。
'J?*'以"J"开头且至少包含 2 个字符的值。
'J??*'以"J"开头的值包含"J"且至少包含 3 个字符。
'J*n'以"J"开头并以"n"结尾的值".

示例:

考虑一个数据库,其中包含一个名为 Employee 的表,其中包含以下记录:

EmpIDNameCityAgeSalary
1JohnLondon253000
2MarryNew York242750
3JoParis272800
4KimAmsterdam303100
5RameshNew Delhi283000
6HuangBeijing282800

从 Employee 表中获取 Salary 以 3 开头并以 3 结尾的所有记录0,查询为:

SELECT * FROM Employee
WHERE Salary GLOB '3*0'; 

这将产生如下所示的结果:

EmpIDNameCityAgeSalary
1JohnLondon253000
4KimAmsterdam303100
5RameshNew Delhi283000

同样,要从 Employee 表中获取员工 Name 以"Jo"开头的所有记录,查询为:

SELECT * FROM Employee
WHERE Name GLOB 'Jo*'; 

这将产生如下所示的结果:

EmpIDNameCityAgeSalary
1JohnLondon253000
3JoParis272800

使用 NOT GLOB 关键字:NOT GLOB 关键字用作否定GLOB 关键字。例如,要选择 Employee 表中 Name 不以"Jo"开头的所有记录,可以使用以下查询:

SELECT * FROM Employee
WHERE Name NOT GLOB 'Jo*'; 

这将产生如下所示的结果:

EmpIDNameCityAgeSalary
2MarryNew York242750
4KimAmsterdam303100
5RameshNew Delhi283000
6HuangBeijing282800