On 2025-Apr-26, jian he wrote: > I am wondering if we need to change the following comments in getTableAttrs. > > * We track in notnull_islocal whether the constraint was defined directly > * in this table or via an ancestor, for binary upgrade. flagInhAttrs > * might modify this later for servers older than 18; it's also in charge > * of determining the correct inhcount. > since we also changed notnull_islocal for pg18.
Yeah. > Also do we need to adjust the following comments in determineNotNullFlags? > * In a child table that inherits from a parent already containing NOT NULL > * constraints and the columns in the child don't have their own NOT NULL > * declarations, we suppress printing constraints in the child: the > * constraints are acquired at the point where the child is attached to the > * parent. This is tracked in ->notnull_islocal (which is set in flagInhAttrs > * for servers pre-18). Adjusted this one as well. I also fixed the business with multiple inheritance: with the commit I just pushed, we stop printing the child constraint if at least one parent has a validated constraint. With that, I believe this open item is closed, so I'm going to mark it as such in the wiki page momentarily. > > Patch 0002 is a part of your proposed patch that I don't think we need, > > but I'm open to hearing arguments about why we do, preferrably with some > > test cases. > > ------------ > CREATE TABLE inhnn (a int); > insert into inhnn values(NULL); > ALTER TABLE inhnn ADD CONSTRAINT cc not null a NOT VALID; > CREATE TABLE inhnn_cc(a INTEGER) INHERITS(inhnn); > CREATE TABLE inhnn_cc_1(a INTEGER) INHERITS(inhnn_cc, inhnn); > -------- > As you can see, "conislocal" is not consistent, maybe in practical it > does not matter, > but here we can make pg_dump, "conislocal" value being consistent. Yeah, I realize that this effect exists, but I find it very hard to justify spending time on this issue given that there are no visible consequences. What I can offer is that if you come up with a test setup that fails when this patch is not applied, and works when it is applied, then I'm open to considering it. -- Álvaro Herrera PostgreSQL Developer — https://www.EnterpriseDB.com/ Syntax error: function hell() needs an argument. Please choose what hell you want to involve.