pgsql: Refactor code into new JsonbValueAsText, and use it more

From: Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: Refactor code into new JsonbValueAsText, and use it more
Date: 2019-09-20 22:37:20
Message-ID: E1iBRWi-0002ou-Gl@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Refactor code into new JsonbValueAsText, and use it more

jsonb_object_field_text and jsonb_array_element_text both contained
identical copies of this code, so extract that into new routine
JsonbValueAsText. This can also be used in other places, to measurable
performance benefit: the jsonb_each() and jsonb_array_elements()
functions can use it for outputting text forms instead of their less
efficient current implementation (because we no longer need to build
intermediate a jsonb representation of each value).

Author: Nikita Glukhov
Discussion: https://postgr.es/m/7c417f90-f95f-247e-ba63-d95e39c0ad14@postgrespro.ru

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/abb014a63106653f2872a3b1662a79ab80d4dcbb

Modified Files
--------------
src/backend/utils/adt/jsonfuncs.c | 173 ++++++++++++++------------------------
1 file changed, 61 insertions(+), 112 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Alvaro Herrera 2019-09-20 23:23:03 pgsql: Split out code into new getKeyJsonValueFromContainer()
Previous Message Tom Lane 2019-09-20 18:23:06 pgsql: Fix some minor spec-compliance issues in jsonpath lexer.