mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-01-24 17:06:50 +00:00
ad79ef48a2
* add tests * add bench
683 lines
11 KiB
Plaintext
683 lines
11 KiB
Plaintext
|
|
SELECT json_array(1,2.5,null,'hello');
|
|
|
|
|
|
SELECT json_array(1,'{"abc":2.5,"def":null,"ghi":hello
|
|
|
|
SELECT json_array(1,json('{"abc":2.5,"def":null,"ghi":"hello"
|
|
|
|
SELECT json_array(1,json_object('abc',2.5,'def',null,'ghi','hello'),99);
|
|
-- the second term goes in as JSON
|
|
|
|
|
|
SELECT hex(json_array('String "\ Test'));
|
|
|
|
|
|
SELECT json_array(-9223372036854775808,9223372036854775807,0,1,-1,
|
|
0.0, 1.0, -1.0, -1e99, +2e100,
|
|
'one','two','three',
|
|
4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18,
|
|
19, NULL, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
|
|
'abcdefghijklmnopqrstuvwyxzABCDEFGHIJKLMNOPQRSTUVWXYZ',
|
|
'abcdefghijklmnopqrstuvwyxzABCDEFGHIJKLMNOPQRSTUVWXYZ',
|
|
'abcdefghijklmnopqrstuvwyxzABCDEFGHIJKLMNOPQRSTUVWXYZ',
|
|
99);
|
|
|
|
|
|
SELECT json_object('a',1,'b',2.5,'c',null,'d','String Test');
|
|
|
|
|
|
SELECT json_replace('{"a":1,"b":2
|
|
|
|
SELECT json_replace('{"a":1,"b":2
|
|
|
|
SELECT json_type(json_set('{"a":1,"b":2
|
|
|
|
SELECT json_type(json_set('{"a":1,"b":2
|
|
|
|
SELECT fullkey, atom, '|' FROM json_tree(json_set('{
|
|
|
|
CREATE TABLE j1(x);
|
|
INSERT INTO j1(x)
|
|
VALUES('true'),('false'),('null'),('123'),('-234'),('34.5e+6'),
|
|
('""'),('"\""'),('"\\"'),('"abcdefghijlmnopqrstuvwxyz"'),
|
|
('[]'),('{
|
|
|
|
SELECT * FROM j1 WHERE NOT json_valid(char(0x20,0x09,0x0a,0x0d)||x);
|
|
|
|
|
|
SELECT * FROM j1 WHERE NOT json_valid(x||char(0x20,0x09,0x0a,0x0d));
|
|
|
|
|
|
SELECT json_valid(''), json_valid(char(0x20,0x09,0x0a,0x0d));
|
|
|
|
|
|
SELECT x FROM j1 WHERE json_remove(x)<>x;
|
|
|
|
|
|
SELECT x FROM j1 WHERE json_replace(x)<>x;
|
|
|
|
|
|
SELECT x FROM j1 WHERE json_set(x)<>x;
|
|
|
|
|
|
SELECT x FROM j1 WHERE json_insert(x)<>x;
|
|
|
|
|
|
SELECT json_insert('{"a":1
|
|
|
|
SELECT count(*) FROM j1 WHERE json_type(x) IN ('object','array');
|
|
SELECT x FROM j1
|
|
WHERE json_extract(x,'$')<>x
|
|
AND json_type(x) IN ('object','array');
|
|
|
|
|
|
CREATE TABLE j2(id INTEGER PRIMARY KEY, json, src);
|
|
INSERT INTO j2(id,json,src)
|
|
VALUES(1,'{
|
|
"firstName": "John",
|
|
"lastName": "Smith",
|
|
"isAlive": true,
|
|
"age": 25,
|
|
"address": {
|
|
"streetAddress": "21 2nd Street",
|
|
"city": "New York",
|
|
"state": "NY",
|
|
"postalCode": "10021-3100"
|
|
|
|
|
|
SELECT id, json_valid(json), json_type(json), '|' FROM j2 ORDER BY id;
|
|
|
|
|
|
SELECT j2.rowid, jx.rowid, fullkey, path, key
|
|
FROM j2, json_tree(j2.json) AS jx
|
|
WHERE fullkey!=(path || CASE WHEN typeof(key)=='integer' THEN '['||key||']'
|
|
ELSE '.'||key END);
|
|
|
|
|
|
SELECT j2.rowid, jx.rowid, fullkey, path, key
|
|
FROM j2, json_each(j2.json) AS jx
|
|
WHERE fullkey!=(path || CASE WHEN typeof(key)=='integer' THEN '['||key||']'
|
|
ELSE '.'||key END);
|
|
|
|
|
|
SELECT j2.rowid, jx.rowid, fullkey, path, key
|
|
FROM j2, json_each(j2.json) AS jx
|
|
WHERE jx.json<>j2.json;
|
|
|
|
|
|
SELECT j2.rowid, jx.rowid, fullkey, path, key
|
|
FROM j2, json_tree(j2.json) AS jx
|
|
WHERE jx.json<>j2.json;
|
|
|
|
|
|
SELECT j2.rowid, jx.rowid, fullkey, path, key
|
|
FROM j2, json_each(j2.json) AS jx
|
|
WHERE jx.value<>jx.atom AND type NOT IN ('array','object');
|
|
|
|
|
|
SELECT j2.rowid, jx.rowid, fullkey, path, key
|
|
FROM j2, json_tree(j2.json) AS jx
|
|
WHERE jx.value<>jx.atom AND type NOT IN ('array','object');
|
|
|
|
|
|
SELECT json_valid('{"a":55,"b":72,
|
|
|
|
SELECT json_error_position('{"a":55,"b":72,
|
|
|
|
SELECT json_valid(json('{"a":55,"b":72,
|
|
|
|
SELECT json_valid('{"a":55,"b":72 ,
|
|
|
|
SELECT json_error_position('{"a":55,"b":72 ,
|
|
|
|
SELECT json_error_position('{"a":55,"b":72,,
|
|
|
|
SELECT json_valid('{"a":55,"b":72
|
|
|
|
SELECT json_error_position('["a",55,"b",72,]');
|
|
|
|
|
|
SELECT json_error_position('["a",55,"b",72 , ]');
|
|
|
|
|
|
SELECT json_error_position('["a",55,"b",72,,]');
|
|
|
|
|
|
SELECT json_valid('["a",55,"b",72]');
|
|
|
|
|
|
DROP TABLE IF EXISTS t8;
|
|
CREATE TABLE t8(a,b);
|
|
INSERT INTO t8(a) VALUES('abc' || char(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35) || 'xyz');
|
|
UPDATE t8 SET b=json_array(a);
|
|
SELECT b FROM t8;
|
|
|
|
|
|
SELECT a=json_extract(b,'$[0]') FROM t8;
|
|
|
|
|
|
SELECT json_valid(char(0x22,0xe4,0x22));
|
|
|
|
|
|
SELECT unicode(json_extract(char(0x22,228,0x22),'$'));
|
|
|
|
|
|
SELECT json_quote('abc"xyz');
|
|
|
|
|
|
SELECT json_quote(3.14159);
|
|
|
|
|
|
SELECT json_quote(12345);
|
|
|
|
|
|
SELECT json_quote(null);
|
|
|
|
|
|
SELECT json_valid('" \ "');
|
|
|
|
|
|
SELECT json_valid('" \! "');
|
|
|
|
|
|
SELECT json_valid('" \" "');
|
|
|
|
|
|
SELECT json_valid('" \# "');
|
|
|
|
|
|
SELECT json_valid('" \$ "');
|
|
|
|
|
|
SELECT json_valid('" \% "');
|
|
|
|
|
|
SELECT json_valid('" \& "');
|
|
|
|
|
|
SELECT json_valid('" \'' "');
|
|
|
|
|
|
SELECT json_valid('" \( "');
|
|
|
|
|
|
SELECT json_valid('" \) "');
|
|
|
|
|
|
SELECT json_valid('" \* "');
|
|
|
|
|
|
SELECT json_valid('" \+ "');
|
|
|
|
|
|
SELECT json_valid('" \, "');
|
|
|
|
|
|
SELECT json_valid('" \- "');
|
|
|
|
|
|
SELECT json_valid('" \. "');
|
|
|
|
|
|
SELECT json_valid('" \/ "');
|
|
|
|
|
|
SELECT json_valid('" \0 "');
|
|
|
|
|
|
SELECT json_valid('" \1 "');
|
|
|
|
|
|
SELECT json_valid('" \2 "');
|
|
|
|
|
|
SELECT json_valid('" \3 "');
|
|
|
|
|
|
SELECT json_valid('" \4 "');
|
|
|
|
|
|
SELECT json_valid('" \5 "');
|
|
|
|
|
|
SELECT json_valid('" \6 "');
|
|
|
|
|
|
SELECT json_valid('" \7 "');
|
|
|
|
|
|
SELECT json_valid('" \8 "');
|
|
|
|
|
|
SELECT json_valid('" \9 "');
|
|
|
|
|
|
SELECT json_valid('" \: "');
|
|
|
|
|
|
SELECT json_valid('" \; "');
|
|
|
|
|
|
SELECT json_valid('" \< "');
|
|
|
|
|
|
SELECT json_valid('" \= "');
|
|
|
|
|
|
SELECT json_valid('" \> "');
|
|
|
|
|
|
SELECT json_valid('" \? "');
|
|
|
|
|
|
SELECT json_valid('" \@ "');
|
|
|
|
|
|
SELECT json_valid('" \A "');
|
|
|
|
|
|
SELECT json_valid('" \B "');
|
|
|
|
|
|
SELECT json_valid('" \C "');
|
|
|
|
|
|
SELECT json_valid('" \D "');
|
|
|
|
|
|
SELECT json_valid('" \E "');
|
|
|
|
|
|
SELECT json_valid('" \F "');
|
|
|
|
|
|
SELECT json_valid('" \G "');
|
|
|
|
|
|
SELECT json_valid('" \H "');
|
|
|
|
|
|
SELECT json_valid('" \I "');
|
|
|
|
|
|
SELECT json_valid('" \J "');
|
|
|
|
|
|
SELECT json_valid('" \K "');
|
|
|
|
|
|
SELECT json_valid('" \L "');
|
|
|
|
|
|
SELECT json_valid('" \M "');
|
|
|
|
|
|
SELECT json_valid('" \N "');
|
|
|
|
|
|
SELECT json_valid('" \O "');
|
|
|
|
|
|
SELECT json_valid('" \P "');
|
|
|
|
|
|
SELECT json_valid('" \Q "');
|
|
|
|
|
|
SELECT json_valid('" \R "');
|
|
|
|
|
|
SELECT json_valid('" \S "');
|
|
|
|
|
|
SELECT json_valid('" \T "');
|
|
|
|
|
|
SELECT json_valid('" \U "');
|
|
|
|
|
|
SELECT json_valid('" \V "');
|
|
|
|
|
|
SELECT json_valid('" \W "');
|
|
|
|
|
|
SELECT json_valid('" \X "');
|
|
|
|
|
|
SELECT json_valid('" \Y "');
|
|
|
|
|
|
SELECT json_valid('" \Z "');
|
|
|
|
|
|
SELECT json_valid('" \[ "');
|
|
|
|
|
|
SELECT json_valid('" \\ "');
|
|
|
|
|
|
SELECT json_valid('" \] "');
|
|
|
|
|
|
SELECT json_valid('" \^ "');
|
|
|
|
|
|
SELECT json_valid('" \_ "');
|
|
|
|
|
|
SELECT json_valid('" \` "');
|
|
|
|
|
|
SELECT json_valid('" \a "');
|
|
|
|
|
|
SELECT json_valid('" \b "');
|
|
|
|
|
|
SELECT json_valid('" \c "');
|
|
|
|
|
|
SELECT json_valid('" \d "');
|
|
|
|
|
|
SELECT json_valid('" \e "');
|
|
|
|
|
|
SELECT json_valid('" \f "');
|
|
|
|
|
|
SELECT json_valid('" \g "');
|
|
|
|
|
|
SELECT json_valid('" \h "');
|
|
|
|
|
|
SELECT json_valid('" \i "');
|
|
|
|
|
|
SELECT json_valid('" \j "');
|
|
|
|
|
|
SELECT json_valid('" \k "');
|
|
|
|
|
|
SELECT json_valid('" \l "');
|
|
|
|
|
|
SELECT json_valid('" \m "');
|
|
|
|
|
|
SELECT json_valid('" \n "');
|
|
|
|
|
|
SELECT json_valid('" \o "');
|
|
|
|
|
|
SELECT json_valid('" \p "');
|
|
|
|
|
|
SELECT json_valid('" \q "');
|
|
|
|
|
|
SELECT json_valid('" \r "');
|
|
|
|
|
|
SELECT json_valid('" \s "');
|
|
|
|
|
|
SELECT json_valid('" \t "');
|
|
|
|
|
|
SELECT json_valid('" \u "');
|
|
|
|
|
|
SELECT json_valid('" \ua "');
|
|
|
|
|
|
SELECT json_valid('" \uab "');
|
|
|
|
|
|
SELECT json_valid('" \uabc "');
|
|
|
|
|
|
SELECT json_valid('" \uabcd "');
|
|
|
|
|
|
SELECT json_valid('" \uFEDC "');
|
|
|
|
|
|
SELECT json_valid('" \u1234 "');
|
|
|
|
|
|
SELECT json_valid('" \v "');
|
|
|
|
|
|
SELECT json_valid('" \w "');
|
|
|
|
|
|
SELECT json_valid('" \x "');
|
|
|
|
|
|
SELECT json_valid('" \y "');
|
|
|
|
|
|
SELECT json_valid('" \z "');
|
|
|
|
|
|
SELECT json_valid('" \{ "');
|
|
|
|
|
|
SELECT json_valid('" \| "');
|
|
|
|
|
|
SELECT json_valid('" \
|
|
|
|
SELECT json_valid('" \~ "');
|
|
|
|
|
|
/* Shallow enough to be parsed */
|
|
SELECT json_valid(printf('%.1000c0%.1000c','[',']'));
|
|
|
|
|
|
/* Too deep by one */
|
|
SELECT json_valid(printf('%.1001c0%.1001c','[',']'));
|
|
|
|
|
|
/* Shallow enough to be parsed { */
|
|
SELECT json_valid(replace(printf('%.1000c0%.1000c','[','
|
|
|
|
/* Too deep by one { */
|
|
SELECT json_valid(replace(printf('%.1001c0%.1001c','[','
|
|
|
|
CREATE TABLE t12(x);
|
|
INSERT INTO t12(x) VALUES(
|
|
'{"settings":
|
|
{"layer2":
|
|
{"hapax.legomenon":
|
|
{"forceDisplay":true,
|
|
"transliterate":true,
|
|
"add.footnote":true,
|
|
"summary.report":true
|
|
|
|
SELECT json_remove(x, '$.settings.layer2."dis.legomenon".forceDisplay')
|
|
FROM t12;
|
|
|
|
|
|
SELECT json_extract(x, '$.settings.layer2."tris.legomenon"."summary.report"')
|
|
FROM t12;
|
|
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
DROP TABLE IF EXISTS t2;
|
|
CREATE TABLE t1(id, json);
|
|
INSERT INTO t1(id,json) VALUES(1,'{"items":[3,5]
|
|
|
|
SELECT * FROM t2 CROSS JOIN t1
|
|
WHERE EXISTS(SELECT 1 FROM json_each(t1.json,'$.items') AS Z
|
|
WHERE Z.value==t2.id);
|
|
|
|
|
|
SELECT fullkey FROM json_each('123');
|
|
|
|
|
|
SELECT fullkey FROM json_each('123.56');
|
|
|
|
|
|
SELECT fullkey FROM json_each('"hello"');
|
|
|
|
|
|
SELECT fullkey FROM json_each('null');
|
|
|
|
|
|
SELECT fullkey FROM json_tree('123');
|
|
|
|
|
|
SELECT fullkey FROM json_tree('123.56');
|
|
|
|
|
|
SELECT fullkey FROM json_tree('"hello"');
|
|
|
|
|
|
SELECT fullkey FROM json_tree('null');
|
|
|
|
|
|
SELECT * FROM JSON_EACH('{"a":1, "b":2
|
|
|
|
SELECT xyz.* FROM JSON_EACH('{"a":1, "b":2
|
|
|
|
SELECT * FROM (JSON_EACH('{"a":1, "b":2
|
|
|
|
SELECT xyz.* FROM (JSON_EACH('{"a":1, "b":2
|
|
|
|
SELECT length(json_extract('"abc\uD834\uDD1Exyz"','$'));
|
|
|
|
|
|
SELECT length(json_extract('"\uD834\uDD1E"','$'));
|
|
|
|
|
|
SELECT unicode(json_extract('"\uD834\uDD1E"','$'));
|
|
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
DROP TABLE IF EXISTS t2;
|
|
CREATE TABLE t1(a,b,c);
|
|
CREATE TABLE t2(d);
|
|
SELECT * FROM t1 LEFT JOIN t2 ON (SELECT b FROM json_each ORDER BY 1);
|
|
|
|
|
|
SELECT json_valid('{"":5
|
|
|
|
SELECT json_extract('{"":5
|
|
|
|
SELECT json_extract('[3,{"a":4,"":[5,{"hi":6
|
|
|
|
SELECT json_extract('[3,{"a":4,"":[5,{"hi":6
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
CREATE TABLE t1(x);
|
|
|
|
|
|
COMMIT;
|
|
SELECT * FROM t1;
|
|
|
|
|
|
SELECT json_object('a',2e370,'b',-3e380);
|
|
|
|
|
|
SELECT json_object('a',2e370,'b',-3e380)->>'a';
|
|
|
|
|
|
SELECT json_object('a',2e370,'b',-3e380)->>'b';
|
|
|
|
|
|
SELECT json_valid(NULL);
|
|
|
|
|
|
SELECT json_valid(NULL);
|
|
|
|
|
|
SELECT json_error_position(NULL);
|
|
|
|
|
|
SELECT json(NULL);
|
|
|
|
|
|
SELECT json_array(NULL);
|
|
|
|
|
|
SELECT json_extract(NULL);
|
|
|
|
|
|
SELECT json_insert(NULL,'$',123);
|
|
|
|
|
|
SELECT NULL->0;
|
|
|
|
|
|
SELECT NULL->>0;
|
|
|
|
|
|
SELECT '{a:5
|
|
|
|
SELECT '{a:5
|
|
|
|
SELECT json_patch(NULL,'{a:5
|
|
|
|
SELECT json_patch('{a:5
|
|
|
|
SELECT json_patch(NULL,NULL);
|
|
|
|
|
|
SELECT json_remove(NULL,'$');
|
|
|
|
|
|
SELECT json_remove('{a:5,b:7
|
|
|
|
SELECT json_replace(NULL,'$.a',123);
|
|
|
|
|
|
SELECT json_replace('{a:5,b:7
|
|
|
|
SELECT json_set(NULL,'$.a',123);
|
|
|
|
|
|
SELECT json_set('{a:5,b:7
|
|
|
|
SELECT json_type(NULL);
|
|
|
|
|
|
SELECT json_type('{a:5,b:7
|
|
|
|
SELECT json_quote(NULL);
|
|
|
|
|
|
SELECT count(*) FROM json_each(NULL);
|
|
|
|
|
|
SELECT count(*) FROM json_tree(NULL);
|
|
|
|
|
|
WITH c(x) AS (VALUES(1),(2.0),(NULL),('three'))
|
|
SELECT json_group_array(x) FROM c;
|
|
|
|
|
|
WITH c(x,y) AS (VALUES('a',1),('b',2.0),('c',NULL),(NULL,'three'),('e','four'))
|
|
SELECT json_group_object(x,y) FROM c;
|
|
|
|
|
|
SELECT json_set(
|
|
'{
|
|
|
|
SELECT json_replace(
|
|
'{"a":7,"b":8,"c":9
|
|
|
|
SELECT j, j->>0, j->>1
|
|
FROM (SELECT json_set(json_set('[]','$[#]',0), '$[#]',1) AS j);
|
|
|
|
|
|
SELECT j, j->>0, j->>1
|
|
FROM (SELECT json_set('[]','$[#]',0,'$[#]',1) AS j);
|
|
|