Re: CREATE/ALTER PUBLICATION improvements for syntax synopsis
| От | Chao Li |
|---|---|
| Тема | Re: CREATE/ALTER PUBLICATION improvements for syntax synopsis |
| Дата | |
| Msg-id | 5217AD5E-4C6A-4BA3-B222-0C919F950EE5@gmail.com обсуждение исходный текст |
| Ответ на | Re: CREATE/ALTER PUBLICATION improvements for syntax synopsis (Peter Smith <smithpb2250@gmail.com>) |
| Ответы |
Re: CREATE/ALTER PUBLICATION improvements for syntax synopsis
|
| Список | pgsql-hackers |
> On Nov 20, 2025, at 09:41, Peter Smith <smithpb2250@gmail.com> wrote: > > On Thu, Nov 20, 2025 at 12:03 PM Fujii Masao <masao.fujii@gmail.com> wrote: >> >> On Thu, Nov 20, 2025 at 9:02 AM Chao Li <li.evan.chao@gmail.com> wrote: >>> V6 looks better. >> >> +1. Thanks for updating the patch! >> >> +<phrase>and <replaceable class="parameter">table</replaceable> is:</phrase> >> + >> + [ ONLY ] <replaceable class="parameter">table_name</replaceable> [ * ] >> >> I have one question: in lock.sgml and truncate.sgml, the syntax >> "[ ONLY ] name [ * ] [, ... ]" seems shown as acceptable (though >> I'm not entirely sure it's actually valid). If that form is allowed, >> then this change may not be necessary? >> > > I think if this were strict BNF rules, then the bindings of the "..." > are not correct. I think the Postgres documentation is a bit loose > with the rules (e.g. your TRUNCATE example is deemed acceptable) > > A user might also wonder if "ONLY a,b" means the same as "ONLY a", "ONLY b"? > > But, in the interest of not bloating the ALTER PUBLICATION synopsis > too much, and still being consistent with what seems accepted by > existing PG docs, I am happy to remove that extra 'table' replacement > class. Maybe it's a bit ambiguous, but it seems mostly harmless. > > Thoughts? > I think the new code of publication_drop_object has changed the original meaning. Old code: ``` - TABLE [ ONLY ] <replaceable class="parameter">table_name</replaceable> [ * ] [, ... ] ``` Means the drop clause can be: ``` ALTER PUBLICATION DROP TABLE ONLY t1*, TABLE ONLY t2* ``` Now, the new code: ``` + TABLE <replaceable class="parameter">table</replaceable> [, … ] <phrase>and <replaceable class="parameter">table</replaceable> is:</phrase> + + [ ONLY ] <replaceable class="parameter">table_name</replaceable> [ * ] ``` Changes the meaning to: ``` ALTER PUBLICATION DROP TABLE ONLY t1*, ONLY t2* ``` So, I think we should keep the old code. Best regards, -- Chao Li (Evan) HighGo Software Co., Ltd. https://www.highgo.com/
В списке pgsql-hackers по дате отправления: