如表 9.1所示,提供了常规的比较运算符。
表 9.1. 比较运算符
运算符 | 描述 |
---|---|
数据类型 < 数据类型 → boolean |
小于 |
数据类型 > 数据类型 → boolean |
大于 |
数据类型 <= 数据类型 → boolean |
小于等于 |
数据类型 >= 数据类型 → boolean |
大于等于 |
数据类型 = 数据类型 → boolean |
等于 |
数据类型 <> 数据类型 → boolean |
不等于 |
数据类型 != 数据类型 → boolean |
不等于 |
<>
是标准的 SQL 表示“不等于”的记法。!=
是一个别名,它在解析的早期阶段被转换成 <>
。因此,不可能实现具有不同行为的 !=
和 <>
运算符。
这些比较运算符可用于所有具有自然顺序的内置数据类型,包括数值、字符串和日期/时间类型。此外,如果数组、复合类型和范围的组成数据类型是可比较的,则它们也可以进行比较。
通常也可以比较相关数据类型的值;例如,integer
>
bigint
可以工作。这种类型的一些情况是通过“交叉类型”比较运算符直接实现的,但如果没有此类运算符,解析器将把不那么通用的类型强制转换为更通用的类型,并应用后者(更通用类型)的比较运算符。
如上所示,所有比较运算符都是返回 boolean
类型值的二元运算符。因此,像 1 < 2 < 3
这样的表达式无效(因为没有 <
运算符可以将布尔值与 3
进行比较)。使用下面显示的 BETWEEN
谓词来执行范围测试。
还有一些比较谓词,如表 9.2所示。它们的作用与运算符非常相似,但具有 SQL 标准强制的特殊语法。
表 9.2. 比较谓词
谓词 描述 示例 |
---|
在…之间(包含范围的端点)。
|
不在…之间(
|
在…之间,对两个端点值进行排序后。
|
不在…之间,对两个端点值进行排序后。
|
不等于,将 NULL 视为可比较的值。
|
等于,将 NULL 视为可比较的值。
|
测试值是否为 NULL。
|
测试值是否不为 NULL。
|
测试值是否为 NULL(非标准语法)。 |
测试值是否不为 NULL(非标准语法)。 |
测试布尔表达式是否结果为 TRUE。
|
测试布尔表达式是否结果为 FALSE 或 UNKNOWN。
|
测试布尔表达式是否结果为 FALSE。
|
测试布尔表达式是否结果为 TRUE 或 UNKNOWN。
|
测试布尔表达式是否结果为 UNKNOWN。
|
测试布尔表达式是否结果为 TRUE 或 FALSE。
|
a
BETWEENx
ANDy
等同于
a
>=x
ANDa
<=y
BETWEEN
将端点值视为包含在范围内。 BETWEEN SYMMETRIC
类似于 BETWEEN
,只是它不要求 AND
左侧的参数小于或等于右侧的参数。如果不是,则这两个参数会自动交换,因此总会隐含一个非空范围。
BETWEEN
的各种变体是基于普通比较运算符实现的,因此它们适用于任何可比较的数据类型。
BETWEEN
语法中使用 AND
会与 AND
作为逻辑运算符的使用产生歧义。为解决此问题,BETWEEN
子句的第二个参数只允许有限类型的表达式。如果您需要在 BETWEEN
中编写更复杂的子表达式,请将子表达式括在括号中。
普通比较运算符在任一输入为 NULL 时会产生 NULL(表示“未知”),而不是 TRUE 或 FALSE。例如,7 = NULL
会产生 NULL,7 <> NULL
也是如此。当这种行为不合适时,请使用 IS [ NOT ] DISTINCT FROM
谓词。
a
IS DISTINCT FROMb
a
IS NOT DISTINCT FROMb
对于非 NULL 输入,IS DISTINCT FROM
与 <>
运算符相同。但是,如果两个输入都为 NULL,它将返回 FALSE;如果只有一个输入为 NULL,它将返回 TRUE。类似地,对于非 NULL 输入,IS NOT DISTINCT FROM
与 =
相同,但当两个输入都为 NULL 时它返回 TRUE,当只有一个输入为 NULL 时它返回 FALSE。因此,这些谓词有效地像 NULL 是普通数据值一样进行处理,而不是“未知”。
expression
IS NULLexpression
IS NOT NULL
或等效的、但非标准的谓词
expression
ISNULLexpression
NOTNULL
请不要写
,因为 表达式
= NULLNULL
不“等于”NULL
。(NULL 值代表一个未知值,无法确定两个未知值是否相等。)
某些应用程序可能期望
在 表达式
= NULL表达式
计算为 NULL 值时返回 TRUE。强烈建议修改这些应用程序以符合 SQL 标准。但是,如果无法做到这一点,可以使用 transform_null_equals 配置变量。如果启用,PostgreSQL 会将 x = NULL
子句转换为 x IS NULL
。
如果 表达式
是行值,则当行表达式本身为 NULL 或行中的所有字段都为 NULL 时,IS NULL
为 TRUE;当行表达式非 NULL 且行中的所有字段都非 NULL 时,IS NOT NULL
为 TRUE。由于这种行为,对于行值表达式,IS NULL
和 IS NOT NULL
不总是返回相反的结果;特别地,包含 NULL 和非 NULL 字段的行值表达式对这两种测试都返回 FALSE。例如
SELECT ROW(1,2.5,'this is a test') = ROW(1, 3, 'not the same'); SELECT ROW(table.*) IS NULL FROM table; -- detect all-null rows SELECT ROW(table.*) IS NOT NULL FROM table; -- detect all-non-null rows SELECT NOT(ROW(table.*) IS NOT NULL) FROM TABLE; -- detect at least one null in rows
在某些情况下,最好使用 行
IS DISTINCT FROM NULL
或 行
IS NOT DISTINCT FROM NULL
,它将简单地检查整个行值是否为 NULL,而无需对行字段进行任何额外测试。
boolean_expression
IS TRUEboolean_expression
IS NOT TRUEboolean_expression
IS FALSEboolean_expression
IS NOT FALSEboolean_expression
IS UNKNOWNboolean_expression
IS NOT UNKNOWN
即使操作数为 NULL,这些谓词也总是返回 TRUE 或 FALSE,绝不会返回 NULL 值。NULL 输入被视为逻辑值“未知”。请注意,IS UNKNOWN
和 IS NOT UNKNOWN
在功能上分别等同于 IS NULL
和 IS NOT NULL
,只是输入表达式必须是布尔类型。
一些与比较相关的函数也可用,如表 9.3所示。
表 9.3. 比较函数
如果您在文档中发现任何不正确之处,与您对特定功能的体验不符,或者需要进一步澄清,请使用此表单报告文档问题。