]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Remove "invalid concatenation of jsonb objects" error case.
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 21 Dec 2020 18:11:30 +0000 (13:11 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 21 Dec 2020 18:11:30 +0000 (13:11 -0500)
commit1d5f3f976b26271b51a619f02436ec5c263db9f3
tree4f47c7cb0a95d9b308a9006a2e009a5358d1f872
parentc336e90b266bb92a7c782eaefbeb038522e41c4b
Remove "invalid concatenation of jsonb objects" error case.

The jsonb || jsonb operator arbitrarily rejected certain combinations
of scalar and non-scalar inputs, while being willing to concatenate
other combinations.  This was of course quite undocumented.  Rather
than trying to document it, let's just remove the restriction,
creating a uniform rule that unless we are handling an object-to-object
concatenation, non-array inputs are converted to one-element arrays,
resulting in an array-to-array concatenation.  (This does not change
the behavior for any case that didn't throw an error before.)

Per complaint from Joel Jacobson.  Back-patch to all supported branches.

Discussion: https://postgr.es/m/163099.1608312033@sss.pgh.pa.us
doc/src/sgml/func.sgml
src/backend/utils/adt/jsonfuncs.c
src/test/regress/expected/jsonb.out
src/test/regress/sql/jsonb.sql