On 2022-07-05 Tu 14:36, Andres Freund wrote:
> Hi,
>
> On 2022-06-24 10:29:06 -0400, Andrew Dunstan wrote:
>> On 2022-06-23 Th 21:51, Andres Freund wrote:
>>> On 2022-06-23 16:38:12 +0900, Michael Paquier wrote:
>>>> On Tue, Jun 21, 2022 at 05:41:07PM -0400, Andrew Dunstan wrote:
>>>>> Yes, but I don't guarantee to have a fix in time for Beta2.
>>>> IMHO, it would be nice to get something done for beta2. Now the
>>>> thread is rather fresh and I guess that more performance study is
>>>> required even for 0004, so..
>>> I don't think there's a whole lot of performance study needed for 0004 - the
>>> current state is obviously wrong.
>>>
>>> I think Andrew's beta 2 comment was more about my other architectural
>>> complains around the json expression eval stuff.
>>
>> Right. That's being worked on but it's not going to be a mechanical fix.
> Any updates here?
Not yet. A colleague and I are working on it. I'll post a status this
week if we can't post a fix.
>
> I'd mentioned the significant space use due to all JsonCoercionsState for all
> the types. Another related aspect is that this code is just weird - the same
> struct name (JsonCoercionsState), nested in each other?
>
> struct JsonCoercionsState
> {
> struct JsonCoercionState
> {
> JsonCoercion *coercion; /* coercion expression */
> ExprState *estate; /* coercion expression state */
> } null,
> string,
> numeric ,
> boolean,
> date,
> time,
> timetz,
> timestamp,
> timestamptz,
> composite;
> } coercions; /* states for coercion from SQL/JSON item
> * types directly to the output type */
>
> Also note the weird numeric indentation that pgindent does...
Yeah, we'll try to fix that.
>
>
>> The attached very small patch applies on top of your 0002 and deals with
>> the FmgrInfo complaint.
> Now that the FmgrInfo is part of a separately allocated struct, that doesn't
> seem necessary anymore.
Right, but you complained that we should do it the same way as it's done
elsewhere, so I thought I'd do that anyway.
cheers
andrew
--
Andrew Dunstan
EDB: https://www.enterprisedb.com