I'm trying to test out the json
type in PostgreSQL 9.3.
I have a json
column called data
in a table called reports
. The JSON looks something like this:
{
"objects": [
{"src":"foo.png"},
{"src":"bar.png"}
],
"background":"background.png"
}
I would like to query the table for all reports that match the 'src' value in the 'objects' array. For example, is it possible to query the DB for all reports that match 'src' = 'foo.png'
? I successfully wrote a query that can match the "background"
:
SELECT data AS data FROM reports where data->>'background' = 'background.png'
But since "objects"
has an array of values, I can't seem to write something that works. Is it possible to query the DB for all reports that match 'src' = 'foo.png'
? I've looked through these sources but still can't get it:
- http://www.postgresql.org/docs/9.3/static/functions-json.html
- How do I query using fields inside the new PostgreSQL JSON datatype?
- http://michael.otacoo.com/postgresql-2/postgres-9-3-feature-highlight-json-operators/
I've also tried things like this but to no avail:
SELECT json_array_elements(data->'objects') AS data from reports
WHERE data->>'src' = 'foo.png';
I'm not an SQL expert, so I don't know what I am doing wrong.
jsonb
/ pg 9.4. Aside: for the simple case (1 level of nesting), the->
operator also does the trick forjson
in pg 9.3. – Koh