
There are 2-arguments and 4-arguments versions of jsonb_path_match() and jsonb_path_exists(). But 4-arguments versions have optional 3rd and 4th arguments, that leads to ambiguity. In the same time 2-arguments versions are needed only for @@ and @? operators. So, rename 2-arguments versions to remove the ambiguity. Catversion is bumped.
372 lines
20 KiB
SQL
372 lines
20 KiB
SQL
select jsonb '{"a": 12}' @? '$';
|
|
select jsonb '{"a": 12}' @? '1';
|
|
select jsonb '{"a": 12}' @? '$.a.b';
|
|
select jsonb '{"a": 12}' @? '$.b';
|
|
select jsonb '{"a": 12}' @? '$.a + 2';
|
|
select jsonb '{"a": 12}' @? '$.b + 2';
|
|
select jsonb '{"a": {"a": 12}}' @? '$.a.a';
|
|
select jsonb '{"a": {"a": 12}}' @? '$.*.a';
|
|
select jsonb '{"b": {"a": 12}}' @? '$.*.a';
|
|
select jsonb '{"b": {"a": 12}}' @? '$.*.b';
|
|
select jsonb '{"b": {"a": 12}}' @? 'strict $.*.b';
|
|
select jsonb '{}' @? '$.*';
|
|
select jsonb '{"a": 1}' @? '$.*';
|
|
select jsonb '{"a": {"b": 1}}' @? 'lax $.**{1}';
|
|
select jsonb '{"a": {"b": 1}}' @? 'lax $.**{2}';
|
|
select jsonb '{"a": {"b": 1}}' @? 'lax $.**{3}';
|
|
select jsonb '[]' @? '$[*]';
|
|
select jsonb '[1]' @? '$[*]';
|
|
select jsonb '[1]' @? '$[1]';
|
|
select jsonb '[1]' @? 'strict $[1]';
|
|
select jsonb_path_query('[1]', 'strict $[1]');
|
|
select jsonb_path_query('[1]', 'strict $[1]', silent => true);
|
|
select jsonb '[1]' @? 'lax $[10000000000000000]';
|
|
select jsonb '[1]' @? 'strict $[10000000000000000]';
|
|
select jsonb_path_query('[1]', 'lax $[10000000000000000]');
|
|
select jsonb_path_query('[1]', 'strict $[10000000000000000]');
|
|
select jsonb '[1]' @? '$[0]';
|
|
select jsonb '[1]' @? '$[0.3]';
|
|
select jsonb '[1]' @? '$[0.5]';
|
|
select jsonb '[1]' @? '$[0.9]';
|
|
select jsonb '[1]' @? '$[1.2]';
|
|
select jsonb '[1]' @? 'strict $[1.2]';
|
|
select jsonb '{"a": [1,2,3], "b": [3,4,5]}' @? '$ ? (@.a[*] > @.b[*])';
|
|
select jsonb '{"a": [1,2,3], "b": [3,4,5]}' @? '$ ? (@.a[*] >= @.b[*])';
|
|
select jsonb '{"a": [1,2,3], "b": [3,4,"5"]}' @? '$ ? (@.a[*] >= @.b[*])';
|
|
select jsonb '{"a": [1,2,3], "b": [3,4,"5"]}' @? 'strict $ ? (@.a[*] >= @.b[*])';
|
|
select jsonb '{"a": [1,2,3], "b": [3,4,null]}' @? '$ ? (@.a[*] >= @.b[*])';
|
|
select jsonb '1' @? '$ ? ((@ == "1") is unknown)';
|
|
select jsonb '1' @? '$ ? ((@ == 1) is unknown)';
|
|
select jsonb '[{"a": 1}, {"a": 2}]' @? '$[0 to 1] ? (@.a > 1)';
|
|
|
|
select jsonb_path_exists('[{"a": 1}, {"a": 2}, 3]', 'lax $[*].a', silent => false);
|
|
select jsonb_path_exists('[{"a": 1}, {"a": 2}, 3]', 'lax $[*].a', silent => true);
|
|
select jsonb_path_exists('[{"a": 1}, {"a": 2}, 3]', 'strict $[*].a', silent => false);
|
|
select jsonb_path_exists('[{"a": 1}, {"a": 2}, 3]', 'strict $[*].a', silent => true);
|
|
|
|
select jsonb_path_query('1', 'lax $.a');
|
|
select jsonb_path_query('1', 'strict $.a');
|
|
select jsonb_path_query('1', 'strict $.*');
|
|
select jsonb_path_query('1', 'strict $.a', silent => true);
|
|
select jsonb_path_query('1', 'strict $.*', silent => true);
|
|
select jsonb_path_query('[]', 'lax $.a');
|
|
select jsonb_path_query('[]', 'strict $.a');
|
|
select jsonb_path_query('[]', 'strict $.a', silent => true);
|
|
select jsonb_path_query('{}', 'lax $.a');
|
|
select jsonb_path_query('{}', 'strict $.a');
|
|
select jsonb_path_query('{}', 'strict $.a', silent => true);
|
|
|
|
select jsonb_path_query('1', 'strict $[1]');
|
|
select jsonb_path_query('1', 'strict $[*]');
|
|
select jsonb_path_query('[]', 'strict $[1]');
|
|
select jsonb_path_query('[]', 'strict $["a"]');
|
|
select jsonb_path_query('1', 'strict $[1]', silent => true);
|
|
select jsonb_path_query('1', 'strict $[*]', silent => true);
|
|
select jsonb_path_query('[]', 'strict $[1]', silent => true);
|
|
select jsonb_path_query('[]', 'strict $["a"]', silent => true);
|
|
|
|
select jsonb_path_query('{"a": 12, "b": {"a": 13}}', '$.a');
|
|
select jsonb_path_query('{"a": 12, "b": {"a": 13}}', '$.b');
|
|
select jsonb_path_query('{"a": 12, "b": {"a": 13}}', '$.*');
|
|
select jsonb_path_query('{"a": 12, "b": {"a": 13}}', 'lax $.*.a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[*].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[*].*');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[0].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[1].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[2].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[0,1].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[0 to 10].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}]', 'lax $[0 to 10 / 0].a');
|
|
select jsonb_path_query('[12, {"a": 13}, {"b": 14}, "ccc", true]', '$[2.5 - 1 to $.size() - 2]');
|
|
select jsonb_path_query('1', 'lax $[0]');
|
|
select jsonb_path_query('1', 'lax $[*]');
|
|
select jsonb_path_query('[1]', 'lax $[0]');
|
|
select jsonb_path_query('[1]', 'lax $[*]');
|
|
select jsonb_path_query('[1,2,3]', 'lax $[*]');
|
|
select jsonb_path_query('[1,2,3]', 'strict $[*].a');
|
|
select jsonb_path_query('[1,2,3]', 'strict $[*].a', silent => true);
|
|
select jsonb_path_query('[]', '$[last]');
|
|
select jsonb_path_query('[]', '$[last ? (exists(last))]');
|
|
select jsonb_path_query('[]', 'strict $[last]');
|
|
select jsonb_path_query('[]', 'strict $[last]', silent => true);
|
|
select jsonb_path_query('[1]', '$[last]');
|
|
select jsonb_path_query('[1,2,3]', '$[last]');
|
|
select jsonb_path_query('[1,2,3]', '$[last - 1]');
|
|
select jsonb_path_query('[1,2,3]', '$[last ? (@.type() == "number")]');
|
|
select jsonb_path_query('[1,2,3]', '$[last ? (@.type() == "string")]');
|
|
select jsonb_path_query('[1,2,3]', '$[last ? (@.type() == "string")]', silent => true);
|
|
|
|
select * from jsonb_path_query('{"a": 10}', '$');
|
|
select * from jsonb_path_query('{"a": 10}', '$ ? (@.a < $value)');
|
|
select * from jsonb_path_query('{"a": 10}', '$ ? (@.a < $value)', '1');
|
|
select * from jsonb_path_query('{"a": 10}', '$ ? (@.a < $value)', '[{"value" : 13}]');
|
|
select * from jsonb_path_query('{"a": 10}', '$ ? (@.a < $value)', '{"value" : 13}');
|
|
select * from jsonb_path_query('{"a": 10}', '$ ? (@.a < $value)', '{"value" : 8}');
|
|
select * from jsonb_path_query('{"a": 10}', '$.a ? (@ < $value)', '{"value" : 13}');
|
|
select * from jsonb_path_query('[10,11,12,13,14,15]', '$[*] ? (@ < $value)', '{"value" : 13}');
|
|
select * from jsonb_path_query('[10,11,12,13,14,15]', '$[0,1] ? (@ < $x.value)', '{"x": {"value" : 13}}');
|
|
select * from jsonb_path_query('[10,11,12,13,14,15]', '$[0 to 2] ? (@ < $value)', '{"value" : 15}');
|
|
select * from jsonb_path_query('[1,"1",2,"2",null]', '$[*] ? (@ == "1")');
|
|
select * from jsonb_path_query('[1,"1",2,"2",null]', '$[*] ? (@ == $value)', '{"value" : "1"}');
|
|
select * from jsonb_path_query('[1,"1",2,"2",null]', '$[*] ? (@ == $value)', '{"value" : null}');
|
|
select * from jsonb_path_query('[1, "2", null]', '$[*] ? (@ != null)');
|
|
select * from jsonb_path_query('[1, "2", null]', '$[*] ? (@ == null)');
|
|
select * from jsonb_path_query('{}', '$ ? (@ == @)');
|
|
select * from jsonb_path_query('[]', 'strict $ ? (@ == @)');
|
|
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{0}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{0 to last}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{1}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{1 to last}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{2}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{2 to last}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{3 to last}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{last}');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{0}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{1}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{0 to last}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{1 to last}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"b": 1}}', 'lax $.**{1 to 2}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**{0}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**{1}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**{0 to last}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**{1 to last}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**{1 to 2}.b ? (@ > 0)');
|
|
select jsonb_path_query('{"a": {"c": {"b": 1}}}', 'lax $.**{2 to 3}.b ? (@ > 0)');
|
|
|
|
select jsonb '{"a": {"b": 1}}' @? '$.**.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"b": 1}}' @? '$.**{0}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"b": 1}}' @? '$.**{1}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"b": 1}}' @? '$.**{0 to last}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"b": 1}}' @? '$.**{1 to last}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"b": 1}}' @? '$.**{1 to 2}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**{0}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**{1}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**{0 to last}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**{1 to last}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**{1 to 2}.b ? ( @ > 0)';
|
|
select jsonb '{"a": {"c": {"b": 1}}}' @? '$.**{2 to 3}.b ? ( @ > 0)';
|
|
|
|
select jsonb_path_query('{"g": {"x": 2}}', '$.g ? (exists (@.x))');
|
|
select jsonb_path_query('{"g": {"x": 2}}', '$.g ? (exists (@.y))');
|
|
select jsonb_path_query('{"g": {"x": 2}}', '$.g ? (exists (@.x ? (@ >= 2) ))');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'lax $.g ? (exists (@.x))');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'lax $.g ? (exists (@.x + "3"))');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'lax $.g ? ((exists (@.x + "3")) is unknown)');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'strict $.g[*] ? (exists (@.x))');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'strict $.g[*] ? ((exists (@.x)) is unknown)');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'strict $.g ? (exists (@[*].x))');
|
|
select jsonb_path_query('{"g": [{"x": 2}, {"y": 3}]}', 'strict $.g ? ((exists (@[*].x)) is unknown)');
|
|
|
|
--test ternary logic
|
|
select
|
|
x, y,
|
|
jsonb_path_query(
|
|
'[true, false, null]',
|
|
'$[*] ? (@ == true && ($x == true && $y == true) ||
|
|
@ == false && !($x == true && $y == true) ||
|
|
@ == null && ($x == true && $y == true) is unknown)',
|
|
jsonb_build_object('x', x, 'y', y)
|
|
) as "x && y"
|
|
from
|
|
(values (jsonb 'true'), ('false'), ('"null"')) x(x),
|
|
(values (jsonb 'true'), ('false'), ('"null"')) y(y);
|
|
|
|
select
|
|
x, y,
|
|
jsonb_path_query(
|
|
'[true, false, null]',
|
|
'$[*] ? (@ == true && ($x == true || $y == true) ||
|
|
@ == false && !($x == true || $y == true) ||
|
|
@ == null && ($x == true || $y == true) is unknown)',
|
|
jsonb_build_object('x', x, 'y', y)
|
|
) as "x || y"
|
|
from
|
|
(values (jsonb 'true'), ('false'), ('"null"')) x(x),
|
|
(values (jsonb 'true'), ('false'), ('"null"')) y(y);
|
|
|
|
select jsonb '{"a": 1, "b":1}' @? '$ ? (@.a == @.b)';
|
|
select jsonb '{"c": {"a": 1, "b":1}}' @? '$ ? (@.a == @.b)';
|
|
select jsonb '{"c": {"a": 1, "b":1}}' @? '$.c ? (@.a == @.b)';
|
|
select jsonb '{"c": {"a": 1, "b":1}}' @? '$.c ? ($.c.a == @.b)';
|
|
select jsonb '{"c": {"a": 1, "b":1}}' @? '$.* ? (@.a == @.b)';
|
|
select jsonb '{"a": 1, "b":1}' @? '$.** ? (@.a == @.b)';
|
|
select jsonb '{"c": {"a": 1, "b":1}}' @? '$.** ? (@.a == @.b)';
|
|
|
|
select jsonb_path_query('{"c": {"a": 2, "b":1}}', '$.** ? (@.a == 1 + 1)');
|
|
select jsonb_path_query('{"c": {"a": 2, "b":1}}', '$.** ? (@.a == (1 + 1))');
|
|
select jsonb_path_query('{"c": {"a": 2, "b":1}}', '$.** ? (@.a == @.b + 1)');
|
|
select jsonb_path_query('{"c": {"a": 2, "b":1}}', '$.** ? (@.a == (@.b + 1))');
|
|
select jsonb '{"c": {"a": -1, "b":1}}' @? '$.** ? (@.a == - 1)';
|
|
select jsonb '{"c": {"a": -1, "b":1}}' @? '$.** ? (@.a == -1)';
|
|
select jsonb '{"c": {"a": -1, "b":1}}' @? '$.** ? (@.a == -@.b)';
|
|
select jsonb '{"c": {"a": -1, "b":1}}' @? '$.** ? (@.a == - @.b)';
|
|
select jsonb '{"c": {"a": 0, "b":1}}' @? '$.** ? (@.a == 1 - @.b)';
|
|
select jsonb '{"c": {"a": 2, "b":1}}' @? '$.** ? (@.a == 1 - - @.b)';
|
|
select jsonb '{"c": {"a": 0, "b":1}}' @? '$.** ? (@.a == 1 - +@.b)';
|
|
select jsonb '[1,2,3]' @? '$ ? (+@[*] > +2)';
|
|
select jsonb '[1,2,3]' @? '$ ? (+@[*] > +3)';
|
|
select jsonb '[1,2,3]' @? '$ ? (-@[*] < -2)';
|
|
select jsonb '[1,2,3]' @? '$ ? (-@[*] < -3)';
|
|
select jsonb '1' @? '$ ? ($ > 0)';
|
|
|
|
-- arithmetic errors
|
|
select jsonb_path_query('[1,2,0,3]', '$[*] ? (2 / @ > 0)');
|
|
select jsonb_path_query('[1,2,0,3]', '$[*] ? ((2 / @ > 0) is unknown)');
|
|
select jsonb_path_query('0', '1 / $');
|
|
select jsonb_path_query('0', '1 / $ + 2');
|
|
select jsonb_path_query('0', '-(3 + 1 % $)');
|
|
select jsonb_path_query('1', '$ + "2"');
|
|
select jsonb_path_query('[1, 2]', '3 * $');
|
|
select jsonb_path_query('"a"', '-$');
|
|
select jsonb_path_query('[1,"2",3]', '+$');
|
|
select jsonb_path_query('1', '$ + "2"', silent => true);
|
|
select jsonb_path_query('[1, 2]', '3 * $', silent => true);
|
|
select jsonb_path_query('"a"', '-$', silent => true);
|
|
select jsonb_path_query('[1,"2",3]', '+$', silent => true);
|
|
select jsonb '["1",2,0,3]' @? '-$[*]';
|
|
select jsonb '[1,"2",0,3]' @? '-$[*]';
|
|
select jsonb '["1",2,0,3]' @? 'strict -$[*]';
|
|
select jsonb '[1,"2",0,3]' @? 'strict -$[*]';
|
|
|
|
-- unwrapping of operator arguments in lax mode
|
|
select jsonb_path_query('{"a": [2]}', 'lax $.a * 3');
|
|
select jsonb_path_query('{"a": [2]}', 'lax $.a + 3');
|
|
select jsonb_path_query('{"a": [2, 3, 4]}', 'lax -$.a');
|
|
-- should fail
|
|
select jsonb_path_query('{"a": [1, 2]}', 'lax $.a * 3');
|
|
select jsonb_path_query('{"a": [1, 2]}', 'lax $.a * 3', silent => true);
|
|
|
|
-- extension: boolean expressions
|
|
select jsonb_path_query('2', '$ > 1');
|
|
select jsonb_path_query('2', '$ <= 1');
|
|
select jsonb_path_query('2', '$ == "2"');
|
|
select jsonb '2' @? '$ == "2"';
|
|
|
|
select jsonb '2' @@ '$ > 1';
|
|
select jsonb '2' @@ '$ <= 1';
|
|
select jsonb '2' @@ '$ == "2"';
|
|
select jsonb '2' @@ '1';
|
|
select jsonb '{}' @@ '$';
|
|
select jsonb '[]' @@ '$';
|
|
select jsonb '[1,2,3]' @@ '$[*]';
|
|
select jsonb '[]' @@ '$[*]';
|
|
select jsonb_path_match('[[1, true], [2, false]]', 'strict $[*] ? (@[0] > $x) [1]', '{"x": 1}');
|
|
select jsonb_path_match('[[1, true], [2, false]]', 'strict $[*] ? (@[0] < $x) [1]', '{"x": 2}');
|
|
|
|
select jsonb_path_match('[{"a": 1}, {"a": 2}, 3]', 'lax exists($[*].a)', silent => false);
|
|
select jsonb_path_match('[{"a": 1}, {"a": 2}, 3]', 'lax exists($[*].a)', silent => true);
|
|
select jsonb_path_match('[{"a": 1}, {"a": 2}, 3]', 'strict exists($[*].a)', silent => false);
|
|
select jsonb_path_match('[{"a": 1}, {"a": 2}, 3]', 'strict exists($[*].a)', silent => true);
|
|
|
|
|
|
select jsonb_path_query('[null,1,true,"a",[],{}]', '$.type()');
|
|
select jsonb_path_query('[null,1,true,"a",[],{}]', 'lax $.type()');
|
|
select jsonb_path_query('[null,1,true,"a",[],{}]', '$[*].type()');
|
|
select jsonb_path_query('null', 'null.type()');
|
|
select jsonb_path_query('null', 'true.type()');
|
|
select jsonb_path_query('null', '123.type()');
|
|
select jsonb_path_query('null', '"123".type()');
|
|
|
|
select jsonb_path_query('{"a": 2}', '($.a - 5).abs() + 10');
|
|
select jsonb_path_query('{"a": 2.5}', '-($.a * $.a).floor() % 4.3');
|
|
select jsonb_path_query('[1, 2, 3]', '($[*] > 2) ? (@ == true)');
|
|
select jsonb_path_query('[1, 2, 3]', '($[*] > 3).type()');
|
|
select jsonb_path_query('[1, 2, 3]', '($[*].a > 3).type()');
|
|
select jsonb_path_query('[1, 2, 3]', 'strict ($[*].a > 3).type()');
|
|
|
|
select jsonb_path_query('[1,null,true,"11",[],[1],[1,2,3],{},{"a":1,"b":2}]', 'strict $[*].size()');
|
|
select jsonb_path_query('[1,null,true,"11",[],[1],[1,2,3],{},{"a":1,"b":2}]', 'strict $[*].size()', silent => true);
|
|
select jsonb_path_query('[1,null,true,"11",[],[1],[1,2,3],{},{"a":1,"b":2}]', 'lax $[*].size()');
|
|
|
|
select jsonb_path_query('[0, 1, -2, -3.4, 5.6]', '$[*].abs()');
|
|
select jsonb_path_query('[0, 1, -2, -3.4, 5.6]', '$[*].floor()');
|
|
select jsonb_path_query('[0, 1, -2, -3.4, 5.6]', '$[*].ceiling()');
|
|
select jsonb_path_query('[0, 1, -2, -3.4, 5.6]', '$[*].ceiling().abs()');
|
|
select jsonb_path_query('[0, 1, -2, -3.4, 5.6]', '$[*].ceiling().abs().type()');
|
|
|
|
select jsonb_path_query('[{},1]', '$[*].keyvalue()');
|
|
select jsonb_path_query('[{},1]', '$[*].keyvalue()', silent => true);
|
|
select jsonb_path_query('{}', '$.keyvalue()');
|
|
select jsonb_path_query('{"a": 1, "b": [1, 2], "c": {"a": "bbb"}}', '$.keyvalue()');
|
|
select jsonb_path_query('[{"a": 1, "b": [1, 2]}, {"c": {"a": "bbb"}}]', '$[*].keyvalue()');
|
|
select jsonb_path_query('[{"a": 1, "b": [1, 2]}, {"c": {"a": "bbb"}}]', 'strict $.keyvalue()');
|
|
select jsonb_path_query('[{"a": 1, "b": [1, 2]}, {"c": {"a": "bbb"}}]', 'lax $.keyvalue()');
|
|
select jsonb_path_query('[{"a": 1, "b": [1, 2]}, {"c": {"a": "bbb"}}]', 'strict $.keyvalue().a');
|
|
select jsonb '{"a": 1, "b": [1, 2]}' @? 'lax $.keyvalue()';
|
|
select jsonb '{"a": 1, "b": [1, 2]}' @? 'lax $.keyvalue().key';
|
|
|
|
select jsonb_path_query('null', '$.double()');
|
|
select jsonb_path_query('true', '$.double()');
|
|
select jsonb_path_query('null', '$.double()', silent => true);
|
|
select jsonb_path_query('true', '$.double()', silent => true);
|
|
select jsonb_path_query('[]', '$.double()');
|
|
select jsonb_path_query('[]', 'strict $.double()');
|
|
select jsonb_path_query('{}', '$.double()');
|
|
select jsonb_path_query('[]', 'strict $.double()', silent => true);
|
|
select jsonb_path_query('{}', '$.double()', silent => true);
|
|
select jsonb_path_query('1.23', '$.double()');
|
|
select jsonb_path_query('"1.23"', '$.double()');
|
|
select jsonb_path_query('"1.23aaa"', '$.double()');
|
|
select jsonb_path_query('"nan"', '$.double()');
|
|
select jsonb_path_query('"NaN"', '$.double()');
|
|
select jsonb_path_query('"inf"', '$.double()');
|
|
select jsonb_path_query('"-inf"', '$.double()');
|
|
select jsonb_path_query('"inf"', '$.double()', silent => true);
|
|
select jsonb_path_query('"-inf"', '$.double()', silent => true);
|
|
|
|
select jsonb_path_query('{}', '$.abs()');
|
|
select jsonb_path_query('true', '$.floor()');
|
|
select jsonb_path_query('"1.2"', '$.ceiling()');
|
|
select jsonb_path_query('{}', '$.abs()', silent => true);
|
|
select jsonb_path_query('true', '$.floor()', silent => true);
|
|
select jsonb_path_query('"1.2"', '$.ceiling()', silent => true);
|
|
|
|
select jsonb_path_query('["", "a", "abc", "abcabc"]', '$[*] ? (@ starts with "abc")');
|
|
select jsonb_path_query('["", "a", "abc", "abcabc"]', 'strict $ ? (@[*] starts with "abc")');
|
|
select jsonb_path_query('["", "a", "abd", "abdabc"]', 'strict $ ? (@[*] starts with "abc")');
|
|
select jsonb_path_query('["abc", "abcabc", null, 1]', 'strict $ ? (@[*] starts with "abc")');
|
|
select jsonb_path_query('["abc", "abcabc", null, 1]', 'strict $ ? ((@[*] starts with "abc") is unknown)');
|
|
select jsonb_path_query('[[null, 1, "abc", "abcabc"]]', 'lax $ ? (@[*] starts with "abc")');
|
|
select jsonb_path_query('[[null, 1, "abd", "abdabc"]]', 'lax $ ? ((@[*] starts with "abc") is unknown)');
|
|
select jsonb_path_query('[null, 1, "abd", "abdabc"]', 'lax $[*] ? ((@ starts with "abc") is unknown)');
|
|
|
|
select jsonb_path_query('[null, 1, "abc", "abd", "aBdC", "abdacb", "adc\nabc", "babc"]', 'lax $[*] ? (@ like_regex "^ab.*c")');
|
|
select jsonb_path_query('[null, 1, "abc", "abd", "aBdC", "abdacb", "adc\nabc", "babc"]', 'lax $[*] ? (@ like_regex "^a b.* c " flag "ix")');
|
|
select jsonb_path_query('[null, 1, "abc", "abd", "aBdC", "abdacb", "adc\nabc", "babc"]', 'lax $[*] ? (@ like_regex "^ab.*c" flag "m")');
|
|
select jsonb_path_query('[null, 1, "abc", "abd", "aBdC", "abdacb", "adc\nabc", "babc"]', 'lax $[*] ? (@ like_regex "^ab.*c" flag "s")');
|
|
|
|
-- jsonpath operators
|
|
|
|
SELECT jsonb_path_query('[{"a": 1}, {"a": 2}]', '$[*]');
|
|
SELECT jsonb_path_query('[{"a": 1}, {"a": 2}]', '$[*] ? (@.a > 10)');
|
|
|
|
SELECT jsonb_path_query_array('[{"a": 1}, {"a": 2}, {}]', 'strict $[*].a');
|
|
SELECT jsonb_path_query_array('[{"a": 1}, {"a": 2}]', '$[*].a');
|
|
SELECT jsonb_path_query_array('[{"a": 1}, {"a": 2}]', '$[*].a ? (@ == 1)');
|
|
SELECT jsonb_path_query_array('[{"a": 1}, {"a": 2}]', '$[*].a ? (@ > 10)');
|
|
SELECT jsonb_path_query_array('[{"a": 1}, {"a": 2}, {"a": 3}, {"a": 5}]', '$[*].a ? (@ > $min && @ < $max)', vars => '{"min": 1, "max": 4}');
|
|
SELECT jsonb_path_query_array('[{"a": 1}, {"a": 2}, {"a": 3}, {"a": 5}]', '$[*].a ? (@ > $min && @ < $max)', vars => '{"min": 3, "max": 4}');
|
|
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}, {}]', 'strict $[*].a');
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}, {}]', 'strict $[*].a', silent => true);
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}]', '$[*].a');
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}]', '$[*].a ? (@ == 1)');
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}]', '$[*].a ? (@ > 10)');
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}, {"a": 3}, {"a": 5}]', '$[*].a ? (@ > $min && @ < $max)', vars => '{"min": 1, "max": 4}');
|
|
SELECT jsonb_path_query_first('[{"a": 1}, {"a": 2}, {"a": 3}, {"a": 5}]', '$[*].a ? (@ > $min && @ < $max)', vars => '{"min": 3, "max": 4}');
|
|
|
|
SELECT jsonb '[{"a": 1}, {"a": 2}]' @? '$[*].a ? (@ > 1)';
|
|
SELECT jsonb '[{"a": 1}, {"a": 2}]' @? '$[*] ? (@.a > 2)';
|
|
SELECT jsonb_path_exists('[{"a": 1}, {"a": 2}]', '$[*].a ? (@ > 1)');
|
|
SELECT jsonb_path_exists('[{"a": 1}, {"a": 2}, {"a": 3}, {"a": 5}]', '$[*] ? (@.a > $min && @.a < $max)', vars => '{"min": 1, "max": 4}');
|
|
SELECT jsonb_path_exists('[{"a": 1}, {"a": 2}, {"a": 3}, {"a": 5}]', '$[*] ? (@.a > $min && @.a < $max)', vars => '{"min": 3, "max": 4}');
|
|
|
|
SELECT jsonb '[{"a": 1}, {"a": 2}]' @@ '$[*].a > 1';
|
|
SELECT jsonb '[{"a": 1}, {"a": 2}]' @@ '$[*].a > 2';
|
|
SELECT jsonb_path_match('[{"a": 1}, {"a": 2}]', '$[*].a > 1');
|