BUG #13996: json_to_record() returns non-NULL, malformed value for omitted key under some circumstances

From: johann(at)visagie(dot)za(dot)net
To: pgsql-bugs(at)postgresql(dot)org
Subject: BUG #13996: json_to_record() returns non-NULL, malformed value for omitted key under some circumstances
Date: 2016-03-02 08:03:10
Message-ID: 20160302080310.2629.98690@wrigleys.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

The following bug has been logged on the website:

Bug reference: 13996
Logged by: Johann Visagie
Email address: johann(at)visagie(dot)za(dot)net
PostgreSQL version: 9.5.1
Operating system: OS X 10.11.3
Description:

In the following call to json_to_record(), the target row format `t`
specifies a text column `c` which does *not* appear as a key in the JSON
object used as the function’s argument.

SELECT t.*
FROM json_to_record('{"a":1, "b":{"c":16, "d":2}, "x":8}'::json)
AS t(a int, b json, c text, x int);

By the definition of the function in section 9.15 of the manual, the
statement should return a NULL value for the column `c`. This is made
explicit in the second Note at the bottom of that manual page, which states
i.a.:

>JSON fields that do not appear in the target row type will be omitted from
the output, and target columns that do not match any JSON field will simply
be NULL.

However, if (as in this example) another key in the JSON object — `b` in
this case — refers to a nested JSON object which *does* contain a key `c`,
the function returns a malformed JSON string as (text) value for column
`c`:

a | b | c | x
---+----------------+---------+---
1 | {"c":16,"d":2} | {"c":16 | 8
(1 row)

I have not tested whether json_ro_recordset() exhibits the same
misbehaviour.

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Magnus Hagander 2016-03-02 08:29:14 Re: could not migrate 8.0.13 database with large object data to 9.5.1
Previous Message Mark Kirkwood 2016-03-02 05:21:52 Re: Re: could not migrate 8.0.13 database with large object data to 9.5.1