Alvaro Herrera <alvhe...@alvh.no-ip.org> 于2024年10月28日周一 17:16写道:

> On 2024-Oct-27, Tender Wang wrote:
>
> > BTW, while reviewing the v2 patch, I found the parentConTup in
> > foreach(cell, fks) block
> > didn't need it anymore. We can remove the related codes.
>
> True.  Done so in this v3.
>
> I noticed another problem here: we're grabbing the wrong lock type on
> the referenced rel (AccessShareLock) during detach.  (What's more: we
> release it afterwards, which is the wrong thing to do.  We need to keep
> such locks until end of transaction).  I didn't try to construct a case
> where this would be a problem, but if I change AccessShare to NoLock,
> the assertion that says we don't hold _any_ lock on that relation fires,
> which means that we're not taking any locks on those rels before this
> point.  So this lock strength choice is definitely wrong.  I changed it
> to ShareRowExclusive, which is what we're suppose to use when adding a
> trigger.


In CloneFKReferencing(), the constrForm->confrelid uses the same lock type.
I think you're right. I don't find any other problem.


-- 
Thanks,
Tender Wang

Reply via email to