| From: | Anthony Bykov <a(dot)bykov(at)postgrespro(dot)ru> |
|---|---|
| To: | pgsql-hackers(at)postgresql(dot)org |
| Subject: | Re: Transform for pl/perl |
| Date: | 2017-10-24 12:27:09 |
| Message-ID: | 20171024152709.641251ae@anthony-24-g082ur |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
There are some moments I should mention:
1. {"1":1}::jsonb is transformed into HV {"1"=>"1"}, while
["1","2"]::jsonb is transformed into AV ["1", "2"]
2. If there is a numeric value appear in jsonb, it will be transformed
to SVnv through string (Numeric->String->SV->SVnv). Not the best
solution, but as far as I understand this is usual practise in
postgresql to serialize Numerics and de-serialize them.
3. SVnv is transformed into jsonb through string
(SVnv->String->Numeric).
An example may also be helpful to understand extension. So, as an
example, function "test" transforms incoming jsonb into perl,
transforms it back into jsonb and returns it.
create extension jsonb_plperl cascade;
create or replace function test(val jsonb)
returns jsonb
transform for type jsonb
language plperl
as $$
return $_[0];
$$;
select test('{"1":1,"example": null}'::jsonb);
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tom Lane | 2017-10-24 13:50:12 | Re: Remove secondary checkpoint |
| Previous Message | Greg Stark | 2017-10-24 12:26:32 | Re: Current int & float overflow checking is slow. |