Re: Confused comment about drop replica identity index
От | Euler Taveira |
---|---|
Тема | Re: Confused comment about drop replica identity index |
Дата | |
Msg-id | 41e5697a-b7eb-45d7-9f7b-d802d3fdbcf6@www.fastmail.com обсуждение исходный текст |
Ответ на | Re: Confused comment about drop replica identity index (Michael Paquier <michael@paquier.xyz>) |
Список | pgsql-hackers |
On Thu, Dec 16, 2021, at 8:55 PM, Michael Paquier wrote:
On Thu, Dec 16, 2021 at 03:08:46PM -0300, Alvaro Herrera wrote:> Hmm, so if a table has REPLICA IDENTITY INDEX and there is a publication> with an explicit column list, then we need to forbid the DROP INDEX for> that index.Hmm. I have not followed this thread very closely.> I wonder why don't we just forbid DROP INDEX of an index that's been> defined as replica identity. It seems quite silly an operation to> allow.
It would avoid pilot errors.
The commit logs talk about b23b0f55 here for this code, to ease thehandling of relcache entries for rd_replidindex. 07cacba is theorigin of the logic (see RelationGetIndexList). Andres?I don't think that this is really an argument against putting morerestrictions as anything that deals with an index drop, including theinternal ones related to constraints, would need to go throughindex_drop(), and new features may want more restrictions in place asyou say.Now, I don't see a strong argument in changing this behavior either(aka I have not looked at what this implies for the new publicationtypes), and we still need to do something for the comment/docs inexisting branches, anyway. So I would still fix this gap as a firststep, then deal with the rest on HEAD as necessary.
I've never understand the weak dependency between the REPLICA IDENTITY and the
index used by it. I'm afraid we will receive complaints about this unexpected
behavior (my logical replication setup is broken because I dropped an index) as
far as new logical replication features are added. Row filtering imposes some
restrictions in UPDATEs and DELETEs (an error message is returned and the
replication stops) if a column used in the expression isn't part of the REPLICA
IDENTITY anymore.
It seems we already have some code in RangeVarCallbackForDropRelation() that
deals with a system index error condition. We could save a syscall and provide
a test for indisreplident there.
If this restriction is undesirable, we should at least document this choice and
probably emit a WARNING for DROP INDEX.
В списке pgsql-hackers по дате отправления: