#PG考试# postgresql 培训#postgresql考试#postgresql认证
唯一列中的 NULL 值
一个众所周知但令人讨厌的怪异值
NULL
是
NULL != NULL
,因此一
UNIQUE
列仍然可以有多个
NULL
值。
(为了简单起见,示例使用数字 id 列,但我通常更喜欢更复杂的 id,例如 ULID。)
然而,PostgreSQL 15 发布了一项新功能,可以改变这种行为
UNIQUE NULLS NOT DISTINCT
::
确保单个列有值
我遇到的一个常见用例是,一个表有多个外键,但只需要填充一个。例如,假设我们有一个
notifications
表来表示我们发出的通知(例如电子邮件、短信等)。这些通知可能会被触发并与我们系统中的特定实体相关,例如订单、用户、公司等。我们想添加外键来表示此通知的用途,但我们只想填充其中一个。
例如:
通常,我会看到像这样的表添加约束以确保至少有一列被填充:
但是,这并不能阻止您意外填充多个列。如果您使用为您生成 SQL 的对象关系映射器 (ORM),并且您意外设置了对象的多个属性,则很容易发生这种情况:
不过,有一对 PostgreSQL 函数可以让我们编写更好的约束检查,称为
num_nulls/num_nonnulls
。这让我们可以检查一组列中是否只有一个非 NULL 值。例如: