Thread: pgsql: Fix the fastpath rule for jsonb_concat with an empty operand.

pgsql: Fix the fastpath rule for jsonb_concat with an empty operand.

From
Andrew Dunstan
Date:
Fix the fastpath rule for jsonb_concat with an empty operand.

To prevent perverse results, we now only return the other operand if
it's not scalar, and if both operands are of the same kind (array or
object).

Original bug complaint and patch from Oskari Saarenmaa, extended by me
to cover the cases of different kinds of jsonb.

Backpatch to 9.5 where jsonb_concat was introduced.

Branch
------
master

Details
-------
http://git.postgresql.org/pg/commitdiff/e7e3ac2d51130d707792e657facc58c160182342

Modified Files
--------------
src/backend/utils/adt/jsonfuncs.c     |   16 ++++++++++-----
src/test/regress/expected/jsonb.out   |   36 +++++++++++++++++++++++++++++++++
src/test/regress/expected/jsonb_1.out |   36 +++++++++++++++++++++++++++++++++
src/test/regress/sql/jsonb.sql        |    7 +++++++
4 files changed, 90 insertions(+), 5 deletions(-)