两个令人兴奋的 PostgreSQL 特性可改善 NULL 处理#PG认证


     #PG考试# postgresql 培训#postgresql考试#postgresql认证

唯一列中的 NULL 值

一个众所周知但令人讨厌的怪异值 NULLNULL != NULL,因此一 UNIQUE列仍然可以有多个 NULL值。

(为了简单起见,示例使用数字 id 列,但我通常更喜欢更复杂的 id,例如 ULID。)


然而,PostgreSQL 15 发布了一项新功能,可以改变这种行为 UNIQUE NULLS NOT DISTINCT::


确保单个列有值

我遇到的一个常见用例是,一个表有多个外键,但只需要填充一个。例如,假设我们有一个 notifications表来表示我们发出的通知(例如电子邮件、短信等)。这些通知可能会被触发并与我们系统中的特定实体相关,例如订单、用户、公司等。我们想添加外键来表示此通知的用途,但我们只想填充其中一个。

例如:


通常,我会看到像这样的表添加约束以确保至少有一列被填充:


但是,这并不能阻止您意外填充多个列。如果您使用为您生成 SQL 的对象关系映射器 (ORM),并且您意外设置了对象的多个属性,则很容易发生这种情况:


不过,有一对 PostgreSQL 函数可以让我们编写更好的约束检查,称为 num_nulls/num_nonnulls。这让我们可以检查一组列中是否只有一个非 NULL 值。例如:



请使用浏览器的分享功能分享到微信等