> On Jun 23, 2026, at 00:04, Tom Lane <[email protected]> wrote:
> 
> Chao Li <[email protected]> writes:
>> See this repro:
>> ```
>> evantest=# CREATE SCHEMA s CREATE VIEW begin AS SELECT 1;
>> evantest-# end;
>> WARNING:  there is no transaction in progress
>> CREATE SCHEMA
>> COMMIT
>> ```
> 
> Meh.  Yeah, you can fool psql by using non-reserved keywords as
> identifiers.  I'm not super excited about adding complexity that
> resolves specific edge cases of that kind, because there will always
> be more of them.  As an example, this fools both HEAD and the back
> branches:
> 
> regression=# create function begin() returns int
> regression-# begin atomic return 2+2; end;
> regression-# 
> 
> Is it really likely that anyone will use "begin" as an object name?
> 
> Having said that, I agree that what psqlscan.l is doing now is quite
> hokey and maybe we should make it smarter.  I don't like the details
> of your patch too much though.  It's too obviously bolted on: the
> added parsing logic looks nothing like what was there before.
> Also, I think it can still be fooled by
> 
>      create schema s
>        create function f() ... as $$ function body $$
> create view begin as ...
> 
> because you don't reset create_schema_routine_body unless you
> see "end".
> 
> What I'd think about doing, if you want to pursue this, is to
> have a buffer similar to cur_state->identifiers[] but it tracks
> identifiers starting from the most recent CREATE sub-clause
> start within CREATE SCHEMA (ie, a non-nested CREATE keyword),
> and then applies basically the same logic as in the original code
> to decide if we're within a CREATE FUNCTION sub-clause.
> 
> Also, you could avoid cluttering other productions by resetting
> all the new state when identifier_count is zero, in the same place
> where we reset cur_state->identifiers[] today.
> 
> It'd likely be appropriate to pull all this logic out of the
> {identifier} production and put it in a subroutine, just because
> it's getting unduly complicated.
> 
> regards, tom lane

Thanks for the detailed explanation. I will try to rework the patch along the 
direction you suggested.

Best regards,
--
Chao Li (Evan)
HighGo Software Co., Ltd.
https://www.highgo.com/






Reply via email to