pgsql: SQL/JSON: Rethink c2d93c3802b

From: Amit Langote <amitlan(at)postgresql(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: SQL/JSON: Rethink c2d93c3802b
Date: 2024-07-17 08:47:12
Message-ID: E1sU0Jc-0020xH-MS@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

SQL/JSON: Rethink c2d93c3802b

This essentially reverts c2d93c3802b except tests. The problem with
c2d93c3802b was that it only changed the casting behavior for types
with typmod, and had coding issues noted in the post-commit review.

This commit changes coerceJsonFuncExpr() to use assignment-level casts
instead of explicit casts to coerce the result of JSON constructor
functions to the specified or the default RETURNING type. Using
assignment-level casts fixes the problem that using explicit casts was
leading to the wrong typmod / length coercion behavior -- truncating
results longer than the specified length instead of erroring out --
which c2d93c3802b aimed to solve.

That restricts the set of allowed target types to string types, the
same set that's currently allowed.

Discussion: https://postgr.es/m/202406291824.reofujy7xdj3@alvherre.pgsql

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/86d33987e8b0364b468c9b40c5f2a0a1aed87ef1

Modified Files
--------------
src/backend/parser/parse_expr.c | 34 ++++++++++------------------------
1 file changed, 10 insertions(+), 24 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Andrew Dunstan 2024-07-17 14:46:33 pgsql: Avoid error in recovery test if history file is not yet present
Previous Message Amit Langote 2024-07-17 08:46:59 pgsql: SQL/JSON: Rethink c2d93c3802b