Re: SQL:2011 application time

From: Paul Jungwirth <pj(at)illuminatedcomputing(dot)com>
To: Peter Eisentraut <peter(at)eisentraut(dot)org>
Cc: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, jian he <jian(dot)universality(at)gmail(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, vignesh C <vignesh21(at)gmail(dot)com>
Subject: Re: SQL:2011 application time
Date: 2025-01-23 23:20:10
Message-ID: bca3e7e6-ac1f-476d-9725-d6aec9100ed0@illuminatedcomputing.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 1/23/25 07:31, Peter Eisentraut wrote:
> On 22.01.25 05:00, Tom Lane wrote:
>> Peter Eisentraut <peter(at)eisentraut(dot)org> writes:
>>> I have committed the fix for foreign key NO ACTION (patch 0002, this did
>>> not require patch 0001).
>>
>> That commit seems to be causing occasional buildfarm failures:
>>
>> https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=indri&dt=2025-01-22%2001%3A29%3A35
>> https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=mylodon&dt=2025-01-22%2001%3A17%3A14
>>
>> Both of these look like
>>
>> --- /Users/buildfarm/bf-data/HEAD/pgsql.build/src/test/regress/expected/without_overlaps.out
>> 2025-01-21 20:29:36
>> +++ /Users/buildfarm/bf-data/HEAD/pgsql.build/src/test/regress/results/without_overlaps.out
>> 2025-01-21 20:43:08
>> @@ -1792,8 +1792,6 @@
>>     SET valid_at = CASE WHEN lower(valid_at) = '2018-01-01' THEN daterange('2018-01-01',
>> '2018-01-05')
>>                         WHEN lower(valid_at) = '2018-02-01' THEN daterange('2018-01-05',
>> '2018-03-01') END
>>     WHERE id = '[6,7)';
>> -ERROR:  update or delete on table "temporal_rng" violates RESTRICT setting of foreign key
>> constraint "temporal_fk_rng2rng_fk" on table "temporal_fk_rng2rng"
>> -DETAIL:  Key (id, valid_at)=([6,7), [2018-01-01,2018-02-01)) is referenced from table
>> "temporal_fk_rng2rng".
>>   -- a PK update that fails because both are referenced (even before commit):
>>   BEGIN;
>>     ALTER TABLE temporal_fk_rng2rng
>>
>> ie, an expected error did not get thrown.
>
> I suspect the nested locking clauses in the new SQL query in the patch. I don't see anything else in
> the patch that would possibly create this kind unstable behavior.

I can't find a regression.diffs in the second link. Is there one? I can't tell if it's the same
failure as in the first link as not.

I ran installcheck-parallel on my own machine continuously over night and haven't been able to
reproduce this yet. How many cases have appeared on the build farm? More than these two? And just to
confirm: they are only since committing 1772d554b0?

The strange thing is that the omitted error message is for a RESTRICT foreign key, and 1772d554b0
only changes behavior when is_no_action. That makes me think the bug is with the original temporal
FK commit. But that has been running on the build farm for a long time, so probably not.

Likewise, I don't see how it can be the nested locking, when that SQL isn't used for RESTRICT
constraints.

The infrequent failure made me suspect a memory error. It's hard to come up with explanations.

What about caching the FK's query plan? Could the RESTRICT test ever reuse the constraint oid from
the NO ACTION tests just above it? I'm pretty sure that's not supposed to happen, but if it used a
plan generated from the NO ACTION SQL, it would exhibit the behavior we're seeing. It also makes
sense why it only appeared after 1772d554b0.

I'll dig into that hypothesis and let you know if I figure anything out.

Yours,

--
Paul ~{:-)
pj(at)illuminatedcomputing(dot)com

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Tom Lane 2025-01-23 23:20:24 Re: Self contradictory examining on rel's baserestrictinfo
Previous Message Tom Lane 2025-01-23 23:13:26 Re: Increase of maintenance_work_mem limit in 64-bit Windows