summaryrefslogtreecommitdiff
path: root/doc/src
diff options
context:
space:
mode:
authorÁlvaro Herrera <alvherre@kurilemu.de>2025-08-04 13:26:45 +0200
committerÁlvaro Herrera <alvherre@kurilemu.de>2025-08-04 13:26:45 +0200
commit126665289fa8e0f7b30165674983f079a5896d91 (patch)
tree5faad13fd683da39dd33dba6dcadd55f6903055b /doc/src
parentbca9a1900c87df86dd10d227910050cf85000c53 (diff)
doc: mention unusability of dropped CHECK to verify NOT NULL
It's possible to use a CHECK (col IS NOT NULL) constraint to skip scanning a table for nulls when adding a NOT NULL constraint on the same column. However, if the CHECK constraint is dropped on the same command that the NOT NULL is added, this fails, i.e., makes the NOT NULL addition slow. The best we can do about it at this stage is to document this so that users aren't taken by surprise. (In Postgres 18 you can directly add the NOT NULL constraint as NOT VALID instead, so there's no longer much use for the CHECK constraint, therefore no point in building mechanism to support the case better.) Reported-by: Andrew <psy2000usa@yahoo.com> Reviewed-by: David G. Johnston <david.g.johnston@gmail.com> Discussion: https://postgr.es/m/175385113607.786.16774570234342968908@wrigleys.postgresql.org
Diffstat (limited to 'doc/src')
-rw-r--r--doc/src/sgml/ref/alter_table.sgml7
1 files changed, 4 insertions, 3 deletions
diff --git a/doc/src/sgml/ref/alter_table.sgml b/doc/src/sgml/ref/alter_table.sgml
index 1e4f26c13f6..541e093a519 100644
--- a/doc/src/sgml/ref/alter_table.sgml
+++ b/doc/src/sgml/ref/alter_table.sgml
@@ -240,9 +240,10 @@ WITH ( MODULUS <replaceable class="parameter">numeric_literal</replaceable>, REM
provided none of the records in the table contain a
<literal>NULL</literal> value for the column. Ordinarily this is
checked during the <literal>ALTER TABLE</literal> by scanning the
- entire table; however, if a valid <literal>CHECK</literal> constraint is
- found which proves no <literal>NULL</literal> can exist, then the
- table scan is skipped.
+ entire table, unless <literal>NOT VALID</literal> is specified;
+ however, if a valid <literal>CHECK</literal> constraint exists
+ (and is not dropped in the same command) which proves no
+ <literal>NULL</literal> can exist, then the table scan is skipped.
If a column has an invalid not-null constraint,
<literal>SET NOT NULL</literal> validates it.
</para>