Peter Eisentraut <peter.eisentr...@enterprisedb.com> writes: > When reverse-compiling a query, ruleutils.c has some complicated code to > handle the join output columns of a JOIN USING join. There used to be > no way to qualify those columns, and so if there was a naming conflict > anywhere in the query, those output columns had to be renamed to be > unique throughout the query.
> Since PostgreSQL 14, we have a new feature that allows adding an alias > to a JOIN USING clause. This provides a better solution to this > problem. I looked this over briefly, and came away fairly dissatisfied. My big fear is that it will reduce portability of pg_dump output: views that would have loaded successfully into pre-v14 servers no longer will, and your chances of porting them to other RDBMSes probably go down too. Once v13 becomes EOL, that will be less of a concern, but I think it's a valid objection for awhile yet. Also, it doesn't seem like we're getting much in return for the portability hazard. AFAICS the patch actually makes a net addition of code to ruleutils.c, which perhaps means that you've not worked hard enough on removing no-longer-needed code. Maybe there's an argument that the new output is more readable, but these regression test changes don't look like any huge step forward to me. > I also just named the generated > aliases "ju" with numbers added, maybe there are other ideas for how to > generate these names. For my taste, names like "join_N" would be better. On the whole, I'd recommend putting this idea on the back burner for three or four years more. regards, tom lane