From: | Peter Eisentraut <peter(at)eisentraut(dot)org> |
---|---|
To: | Jeff Davis <pgsql(at)j-davis(dot)com>, Michael Paquier <michael(at)paquier(dot)xyz> |
Cc: | pgsql-bugs(at)postgresql(dot)org |
Subject: | Re: pg_dump assertion failure with "-n pg_catalog" |
Date: | 2023-09-05 09:45:33 |
Message-ID: | be43b547-3e28-769f-47d8-5b44f95facae@eisentraut.org |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
On 16.06.23 00:47, Jeff Davis wrote:
> else
> {
> appendPQExpBufferStr(q, ", lc_collate = ");
> - appendStringLiteralAH(q, collcollate, fout);
> + appendStringLiteralAH(q, collcollate ? collcollate : "", fout);
> appendPQExpBufferStr(q, ", lc_ctype = ");
> - appendStringLiteralAH(q, collctype, fout);
> + appendStringLiteralAH(q, collctype ? collctype : "", fout);
> }
>
This new code replaces an (unexpected) null value with an empty string.
Is that correct? Empty locale strings have specific behaviors under the
libc and icu providers. It seems to me it would be better to error out
or don't print a CREATE COLLATION command at all rather than
substituting a value that is not a correct substitute.
Alternatively, a more correct way to produce a null value would be to
not issue the assignment at all (omit the " lc_collation = " etc.).
Then we can leave it up to the backend to accept the command or not, but
at least the dump closely reflects the original catalog state.
From | Date | Subject | |
---|---|---|---|
Next Message | Navadvipa Chandra das | 2023-09-05 09:52:09 | Re: BUG #18083: not compile PostgreSQL module in Qt with GCC 11.2 compiler |
Previous Message | PG Bug reporting form | 2023-09-05 09:32:53 | BUG #18085: Error in documentation |