Re: unknownin/out patch (was [HACKERS] PQescapeBytea is
От | Tatsuo Ishii |
---|---|
Тема | Re: unknownin/out patch (was [HACKERS] PQescapeBytea is |
Дата | |
Msg-id | 20020409140856E.t-ishii@sra.co.jp обсуждение исходный текст |
Ответ на | Re: unknownin/out patch (was [HACKERS] PQescapeBytea is (Tatsuo Ishii <t-ishii@sra.co.jp>) |
Список | pgsql-patches |
> > Tatsuo Ishii wrote: > > > > > > > > > Try a multibyte encoding database. For example, > > > > > > $ createdb -E EUC_JP test > > > $ psql -c 'SELECT SUBSTRING('1234567890' FROM 3)' test > > > substring > > > ----------- > > > 3456 > > > (1 row) > > > > > > Apparently this is wrong. > > > -- > > > Tatsuo Ishii > > > > This problem exists in CVS tip *without* the unknownin/out patch: > > Sure. That has been broken for a while. I guess this actually happened in 1.79 of varlena.c: --------------------------------------------------------------------------- revision 1.79 date: 2002/03/05 05:33:19; author: momjian; state: Exp; lines: +45 -42 I attach a version of my toast-slicing patch, against current CVS (current as of a few hours ago.) This patch: 1. Adds PG_GETARG_xxx_P_SLICE() macros and associated support routines. 2. Adds routines in src/backend/access/tuptoaster.c for fetching only necessary chunks of a toasted value. (Modelled on latest changes to assume chunks are returned in order). 3. Amends text_substr and bytea_substr to use new methods. It now handles multibyte cases -and should still lead to a performance improvement in the multibyte case where the substring is near the beginning of the string. 4. Added new command: ALTER TABLE tabname ALTER COLUMN colname SET STORAGE {PLAIN | EXTERNAL | EXTENDED | MAIN} to parser and documented in alter-table.sgml. (NB I used ColId as the item type for the storage mode string, rather than a new production - I hope this makes sense!). All this does is sets attstorage for the specified column. 4. AlterTableAlterColumnStatistics is now AlterTableAlterColumnFlags and handles both statistics and storage (it uses the subtype code to distinguish). The previous version of my patch also re-arranged other code in backend/commands/command.c but I have dropped that from this patch.(I plan to return to it separately). 5. Documented new macros (and also the PG_GETARG_xxx_P_COPY macros) in xfunc.sgml. ref/alter_table.sgml also contains documentation for ALTER COLUMN SET STORAGE. John Gray ---------------------------------------------------------------------------
В списке pgsql-patches по дате отправления: