pgsql: Optimize escaping of JSON strings

From: David Rowley <drowley(at)postgresql(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: Optimize escaping of JSON strings
Date: 2024-07-27 11:46:57
Message-ID: E1sXft3-001Rr7-BX@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Optimize escaping of JSON strings

There were quite a few places where we either had a non-NUL-terminated
string or a text Datum which we needed to call escape_json() on. Many of
these places required that a temporary string was created due to the fact
that escape_json() needs a NUL-terminated cstring. For text types, those
first had to be converted to cstring before calling escape_json() on them.

Here we introduce two new functions to make escaping JSON more optimal:

escape_json_text() can be given a text Datum to append onto the given
buffer. This is more optimal as it foregoes the need to convert the text
Datum into a cstring. A temporary allocation is only required if the text
Datum needs to be detoasted.

escape_json_with_len() can be used when the length of the cstring is
already known or the given string isn't NUL-terminated. Having this
allows various places which were creating a temporary NUL-terminated
string to just call escape_json_with_len() without any temporary memory
allocations.

Discussion: https://postgr.es/m/CAApHDvpLXwMZvbCKcdGfU9XQjGCDm7tFpRdTXuB9PVgpNUYfEQ@mail.gmail.com
Reviewed-by: Melih Mutlu, Heikki Linnakangas

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/17a5871d9d58ea639b6d1ba4f0ce58462d55a33c

Modified Files
--------------
contrib/hstore/hstore_io.c | 41 ++++-----
src/backend/backup/backup_manifest.c | 2 +-
src/backend/utils/adt/json.c | 156 +++++++++++++++++++++++------------
src/backend/utils/adt/jsonb.c | 2 +-
src/backend/utils/adt/jsonfuncs.c | 34 ++++----
src/backend/utils/adt/jsonpath.c | 15 +++-
src/include/utils/json.h | 2 +
7 files changed, 151 insertions(+), 101 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Tom Lane 2024-07-27 19:38:58 pgsql: Doc: fix text's description of regexp_replace's arguments.
Previous Message Heikki Linnakangas 2024-07-27 11:17:46 pgsql: Support absolute bindir/libdir in regression tests with meson