Peter Eisentraut <pe...@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