Re: pgsql: Add more SQL/JSON constructor functions - Mailing list pgsql-hackers

From Tom Lane
Subject Re: pgsql: Add more SQL/JSON constructor functions
Date
Msg-id 2416639.1717389996@sss.pgh.pa.us
Whole thread Raw
In response to Re: pgsql: Add more SQL/JSON constructor functions  (Peter Eisentraut <peter@eisentraut.org>)
Responses Re: pgsql: Add more SQL/JSON constructor functions
List pgsql-hackers
Peter Eisentraut <peter@eisentraut.org> writes:
> On 29.05.24 18:44, Tom Lane wrote:
>> Yeah, I too think this is a cast, and truncation is the spec-defined
>> behavior for casting to varchar with a specific length limit.

> The SQL standard says essentially that the output of json_serialize() is 
> some string that when parsed back in gives you an equivalent JSON value 
> as the input.  That doesn't seem compatible with truncating the output.

Maybe you should take this up with the SQL committee?  If you don't
like our current behavior, then either you have to say that RETURNING
with a length-limited target type is illegal (which is problematic
for the spec, since they have no such type) or that the cast behaves
like an implicit cast, with errors for overlength input (which I find
to be an unintuitive definition for a construct that names the target
type explicitly).

> If you want output truncation, you can of course use an actual cast. 
> But it makes sense that the RETURNING clause is separate from that.

Are you trying to say that the RETURNING clause's specified type
isn't the actual output type?  I can't buy that either.

Again, if you think our existing behavior isn't right, I think
it's a problem for the SQL committee not us.

            regards, tom lane



pgsql-hackers by date:

Previous
From: Kashif Zeeshan
Date:
Subject: Re: cannot drop intarray extension
Next
From: jian he
Date:
Subject: Re: cannot drop intarray extension