Re: Best way to populate nested composite type from JSON`

From: Merlin Moncure <mmoncure(at)gmail(dot)com>
To: Chris Travers <chris(dot)travers(at)gmail(dot)com>
Cc: Postgres General <pgsql-general(at)postgresql(dot)org>
Subject: Re: Best way to populate nested composite type from JSON`
Date: 2013-09-12 15:47:32
Message-ID: CAHyXU0ysrOa2qpEApfhDO_z0JRzcg-VnDd5tFS8eQqRfwNeF_w@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

On Wed, Sep 11, 2013 at 11:55 PM, Chris Travers <chris(dot)travers(at)gmail(dot)com> wrote:
> Hi everyone;
>
> I have been starting to experiment with the JSON accessors in 9.3. I
> immediately found that my preferred use, populating nested composite types,
> is not supported. Also of course one cannot manipulate JSON nodes, which
> leads to the question of how best to do this. I had some ideas:
>
> 1. A custom C function utilizing the internal functions PostgreSQL offers
> for JSON parsing (probably looking at the json_populate_record() as a base)
>
> 2. Utilizing hstore as an intermediate representation along with
> json_each()
>
> 3. Perhaps using something like pl/perlu or the like.
>
> This leads to a few questions, including whether it would be worthwhile
> looking at trying to handle nested types in json_populate_record() and if
> anyone is working on such a thing currently.

Can we see a hypothetical example? json best practices for me are to
use standard tables and than serialize/deserialize json as it goes
through the door and not use nested composite types in your actual
table definitions. I think it should all fit if you do it right: you
json_[each/array_elements] the wrapping json then insert it into
un-nested actual tables. If you must have a final destination as a
nested composite, I think at the worst case you might have to make
some transition composites...

merlin

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Michael Paquier 2013-09-12 15:54:31 Re: 9.2 Replication in Ubuntu ; need help
Previous Message rob stone 2013-09-12 15:28:33 Re: Need help with Inet type