Re: CREATE DOMAIN create two not null constraints - Mailing list pgsql-hackers

From Álvaro Herrera
Subject Re: CREATE DOMAIN create two not null constraints
Date
Msg-id 202506011613.7hr4tuji7pl6@alvherre.pgsql
Whole thread Raw
In response to CREATE DOMAIN create two not null constraints  (jian he <jian.universality@gmail.com>)
Responses Re: CREATE DOMAIN create two not null constraints
List pgsql-hackers
On 2025-Jun-01, jian he wrote:

> hi.
> 
> CREATE DOMAIN int_domain1 AS INT CONSTRAINT nn1 NOT NULL CONSTRAINT
> nn2 NOT NULL;
> 
> will install two not-null pg_constraint entries.
> we should have only one?

Hmm, I think it would be more consistent to reject the case of duplicate
constraints, instead of silently ignoring it.  So you'd do it in the
loop that checks for constraints before creating anything, like


diff --git a/src/backend/commands/typecmds.c b/src/backend/commands/typecmds.c
index 45ae7472ab5..b5daa61260b 100644
--- a/src/backend/commands/typecmds.c
+++ b/src/backend/commands/typecmds.c
@@ -944,6 +944,12 @@ DefineDomain(ParseState *pstate, CreateDomainStmt *stmt)
                             errcode(ERRCODE_SYNTAX_ERROR),
                             errmsg("conflicting NULL/NOT NULL constraints"),
                             parser_errposition(pstate, constr->location));
+
+                if (nullDefined)
+                    ereport(ERROR,
+                            errcode(ERRCODE_INVALID_OBJECT_DEFINITION),
+                            errmsg("redundant NOT NULL constraint definition"));
+
                 if (constr->is_no_inherit)
                     ereport(ERROR,
                             errcode(ERRCODE_INVALID_OBJECT_DEFINITION),

-- 
Álvaro Herrera        Breisgau, Deutschland  —  https://www.EnterpriseDB.com/
"Porque Kim no hacía nada, pero, eso sí,
con extraordinario éxito" ("Kim", Kipling)



pgsql-hackers by date:

Previous
From: Peter Geoghegan
Date:
Subject: RelationGetNumberOfBlocks called before vacuum_get_cutoffs
Next
From: Jiří Kavalík
Date:
Subject: [PATCH] Support for basic ALTER TABLE progress reporting.