On this page
9.2. 比较函数和运算符
常用的比较运算符可用,如Table 9.1所示。
表 9.1. 比较运算符
Operator | Description |
---|---|
< |
less than |
> |
greater than |
<= |
小于或等于 |
>= |
大于或等于 |
= |
equal |
<> 或!= |
not equal |
Note
!=
运算符在解析器阶段转换为<>
。无法实现执行不同功能的!=
和<>
运算符。
比较运算符可用于所有相关数据类型。所有比较运算符都是二进制运算符,它们返回boolean
类型的值;诸如1 < 2 < 3
之类的表达式无效(因为没有<
运算符可将布尔值与3
进行比较)。
还有一些比较谓词,如Table 9.2所示。它们的行为很像运算符,但是具有 SQL 标准规定的特殊语法。
表 9.2. 比较谓词
Predicate | Description |
---|---|
a BETWEEN x AND y |
between |
a NOT BETWEEN x AND y |
not between |
a BETWEEN SYMMETRIC x AND y |
在对比较值进行排序之后 |
a NOT BETWEEN SYMMETRIC x AND y |
在对比较值进行排序之后,不在两者之间 |
a IS DISTINCT FROM b |
不相等,将 null 视为普通值 |
a IS NOT DISTINCT FROM b |
相等,将 null 视为普通值 |
expression IS NULL |
is null |
expression IS NOT NULL |
不为空 |
expression ISNULL |
为 null(非标准语法) |
expression NOTNULL |
不为空(非标准语法) |
boolean_expression IS TRUE |
is true |
boolean_expression IS NOT TRUE |
错误或未知 |
boolean_expression IS FALSE |
is false |
boolean_expression IS NOT FALSE |
是真实的还是未知的 |
boolean_expression IS UNKNOWN |
is unknown |
boolean_expression IS NOT UNKNOWN |
是对还是错 |
a BETWEEN x AND y
相当于
a >= x AND a <= y
请注意,BETWEEN
将端点值视为包含在范围内。 NOT BETWEEN
做相反的比较:
a NOT BETWEEN x AND y
相当于
a < x OR a > y
BETWEEN SYMMETRIC
类似于BETWEEN
,但不要求AND
左侧的参数小于或等于右侧的参数。如果不是,则会自动交换这两个参数,以便始终隐含一个非空范围。
当任一 Importing 为 null 时,普通比较运算符将生成 null(表示“未知”),而不是 true 或 false。例如,7 = NULL
和7 <> NULL
一样产生 null。如果此行为不合适,请使用IS [ NOT ] DISTINCT FROM
谓词:
a IS DISTINCT FROM b
a IS NOT DISTINCT FROM b
对于非空 Importing,IS DISTINCT FROM
与<>
运算符相同。但是,如果两个 Importing 均为 null,则返回 false,如果只有一个 Importing 为 null,则返回 true。类似地,对于非空 Importing,IS NOT DISTINCT FROM
与=
相同,但是当两个 Importing 均为空时,它返回 true;而当只有一个 Importing 为空时,它返回 false。因此,这些谓词有效地表现为空值是正常数据值,而不是“未知”。
expression IS NULL
expression IS NOT NULL
或等同但非标准的谓词:
expression ISNULL
expression NOTNULL
不要写expression = NULL
,因为NULL
不等于NULL
。 (空值表示一个未知值,并且未知两个未知值是否相等.)
Tip
如果* expression
*计算为空值,某些应用程序可能期望expression = NULL
返回 true。强烈建议修改这些应用程序以符合 SQL 标准。但是,如果无法做到这一点,则transform_null_equals配置变量可用。如果启用,PostgreSQL 会将x = NULL
子句转换为x IS NULL
。
如果* expression
为行值,则当行表达式本身为 null 或所有行的字段为 null 时,IS NULL
为 true,而当行表达式本身为非 null 且所有行的字段均为 non 时,IS NOT NULL
为 true -空值。由于这种行为,IS NULL
和IS NOT NULL
并不总是返回行值表达式的反结果。特别是,同时包含 null 和 non-null 字段的行值表达式对于两个测试都将返回 false。在某些情况下,最好写入 row
* IS DISTINCT FROM NULL
或* row
* IS NOT DISTINCT FROM NULL
,这将简单地检查总行值是否为空,而无需对行字段进行任何其他测试。
boolean_expression IS TRUE
boolean_expression IS NOT TRUE
boolean_expression IS FALSE
boolean_expression IS NOT FALSE
boolean_expression IS UNKNOWN
boolean_expression IS NOT UNKNOWN
这些将始终返回 true 或 false,即使操作数为 null,也永远不会返回 null 值。空 Importing 被视为逻辑值“未知”。请注意,IS UNKNOWN
和IS NOT UNKNOWN
实际上分别与IS NULL
和IS NOT NULL
相同,除了 Importing 表达式必须为布尔类型。
还提供一些与比较相关的功能,如Table 9.3所示。
表 9.3. 比较功能