need to be searched linearly.
+
+ Because JSON containment is nested, an appropriate query can skip
+ explicit selection of sub-objects. As an example, suppose that we have
+ a doc> column containing objects at the top level, with
+ most objects containing tags> fields that contain arrays of
+ sub-objects. This query finds entries in which sub-objects containing
+ both "term":"paris"> and "term":"food"> appear,
+ while ignoring any such keys outside the tags> array:
+SELECT doc->'site_name' FROM websites
+ WHERE doc @> '{"tags":[{"term":"paris"}, {"term":"food"}]}';
+
+ One could accomplish the same thing with, say,
+SELECT doc->'site_name' FROM websites
+ WHERE doc->'tags' @> '[{"term":"paris"}, {"term":"food"}]';
+
+ but that approach is less flexible, and often less efficient as well.
+
+
+ On the other hand, the JSON existence operator is not nested: it will
+ only look for the specified key or array element at top level of the
+ JSON value.
+
+
+
The various containment and existence operators, along with all other
JSON operators and functions are documented