mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-01-19 12:21:50 +00:00
ad79ef48a2
* add tests * add bench
220 lines
5.1 KiB
Plaintext
220 lines
5.1 KiB
Plaintext
|
|
SELECT json_object('ex','[52,3.14159]');
|
|
|
|
|
|
SELECT json_object('ex',json('[52,3.14159]'));
|
|
|
|
|
|
SELECT json_object('ex',json_array(52,3.14159));
|
|
|
|
|
|
SELECT json(' { "this" : "is", "a": [ "test" ]
|
|
|
|
SELECT json_array(1,2,'3',4);
|
|
|
|
|
|
SELECT json_array('[1,2]');
|
|
|
|
|
|
SELECT json_array(json_array(1,2));
|
|
|
|
|
|
SELECT json_array(1,null,'3','[4,5]','{"six":7.7
|
|
|
|
SELECT json_array(1,null,'3',json('[4,5]'),json('{"six":7.7
|
|
|
|
SELECT json_array_length('[1,2,3,4]');
|
|
|
|
|
|
SELECT json_array_length( json_remove('[1,2,3,4]','$[2]') );
|
|
|
|
|
|
SELECT json_array_length('[1,2,3,4]', '$');
|
|
|
|
|
|
SELECT json_array_length('[1,2,3,4]', '$[2]');
|
|
|
|
|
|
SELECT json_array_length('{"one":[1,2,3]
|
|
|
|
SELECT json_array_length('{"one":[1,2,3]
|
|
|
|
SELECT json_array_length('{"one":[1,2,3]
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5,{"f":7
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5,{"f":7
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5,{"f":7
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5,{"f":7
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5],"f":7
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5,{"f":7
|
|
|
|
SELECT json_extract('{"a":2,"c":[4,5,{"f":7
|
|
|
|
SELECT json_insert('{"a":2,"c":4
|
|
|
|
SELECT json_insert('{"a":2,"c":4
|
|
|
|
SELECT json_replace('{"a":2,"c":4
|
|
|
|
SELECT json_replace('{"a":2,"c":4
|
|
|
|
SELECT json_set('{"a":2,"c":4
|
|
|
|
SELECT json_set('{"a":2,"c":4
|
|
|
|
SELECT json_set('{"a":2,"c":4
|
|
|
|
SELECT json_set('{"a":2,"c":4
|
|
|
|
SELECT json_set('{"a":2,"c":4
|
|
|
|
SELECT json_object('a',2,'c',4);
|
|
|
|
|
|
SELECT json_object('a',2,'c','{e:5
|
|
|
|
SELECT json_object('a',2,'c',json_object('e',5));
|
|
|
|
|
|
SELECT json_remove('[0,1,2,3,4]','$[2]');
|
|
|
|
|
|
SELECT json_remove('[0,1,2,3,4]','$[2]','$[0]');
|
|
|
|
|
|
SELECT json_remove('[0,1,2,3,4]','$[0]','$[2]');
|
|
|
|
|
|
SELECT json_remove('{"x":25,"y":42
|
|
|
|
SELECT json_remove('{"x":25,"y":42
|
|
|
|
SELECT json_remove('{"x":25,"y":42
|
|
|
|
SELECT json_remove('{"x":25,"y":42
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_type('{"a":[2,3.5,true,false,null,"x"]
|
|
|
|
SELECT json_valid(char(123)||'"x":35'||char(125));
|
|
|
|
|
|
SELECT json_valid(char(123)||'"x":35');
|
|
|
|
|
|
CREATE TABLE user(name,phone);
|
|
INSERT INTO user(name,phone) VALUES
|
|
('Alice','["919-555-2345","804-555-3621"]'),
|
|
('Bob','["201-555-8872"]'),
|
|
('Cindy','["704-555-9983"]'),
|
|
('Dave','["336-555-8421","704-555-4321","803-911-4421"]');
|
|
SELECT DISTINCT user.name
|
|
FROM user, json_each(user.phone)
|
|
WHERE json_each.value LIKE '704-%'
|
|
ORDER BY 1;
|
|
|
|
|
|
UPDATE user
|
|
SET phone=json_extract(phone,'$[0]')
|
|
WHERE json_array_length(phone)<2;
|
|
SELECT name, substr(phone,1,5) FROM user ORDER BY name;
|
|
|
|
|
|
SELECT name FROM user WHERE phone LIKE '704-%'
|
|
UNION
|
|
SELECT user.name
|
|
FROM user, json_each(user.phone)
|
|
WHERE json_valid(user.phone)
|
|
AND json_each.value LIKE '704-%';
|
|
|
|
|
|
CREATE TABLE big(json JSON);
|
|
INSERT INTO big(json) VALUES('{
|
|
"id":123,
|
|
"stuff":[1,2,3,4],
|
|
"partlist":[
|
|
{"uuid":"bb108722-572e-11e5-9320-7f3b63a4ca74"
|
|
|
|
SELECT big.rowid, fullkey, value
|
|
FROM big, json_tree(big.json)
|
|
WHERE json_tree.type NOT IN ('object','array')
|
|
ORDER BY +big.rowid, +json_tree.id
|
|
|
|
|
|
SELECT big.rowid, fullkey, atom
|
|
FROM big, json_tree(big.json)
|
|
WHERE atom IS NOT NULL
|
|
ORDER BY +big.rowid, +json_tree.id
|
|
|
|
|
|
SELECT DISTINCT json_extract(big.json,'$.id')
|
|
FROM big, json_tree(big.json,'$.partlist')
|
|
WHERE json_tree.key='uuid'
|
|
AND json_tree.value='6fa5181e-5721-11e5-a04e-57f3d7b32808';
|
|
|
|
|
|
SELECT DISTINCT json_extract(big.json,'$.id')
|
|
FROM big, json_tree(big.json,'$')
|
|
WHERE json_tree.key='uuid'
|
|
AND json_tree.value='6fa5181e-5721-11e5-a04e-57f3d7b32808';
|
|
|
|
|
|
SELECT DISTINCT json_extract(big.json,'$.id')
|
|
FROM big, json_tree(big.json)
|
|
WHERE json_tree.key='uuid'
|
|
AND json_tree.value='6fa5181e-5721-11e5-a04e-57f3d7b32808';
|
|
|
|
SELECT json_valid(char(32) || '"xyz"')
|
|
SELECT json_valid(char(200) || '"xyz"')
|
|
|
|
WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x+1 FROM c WHERE x<0x20)
|
|
SELECT x FROM c WHERE json_valid(printf('{"a":"x%sz"
|
|
|
|
WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x+1 FROM c WHERE x<0x1f)
|
|
SELECT sum(json_valid(json_quote('a'||char(x)||'z'))) FROM c ORDER BY x;
|
|
|
|
|
|
CREATE TABLE t1(id INTEGER PRIMARY KEY, x JSON);
|
|
INSERT INTO t1(id,x) VALUES
|
|
(1, '{"a":null
|
|
|
|
DELETE FROM t1;
|
|
INSERT INTO t1(x) VALUES('[null,123,4.5,"six",[7,8],{"b":9
|
|
|
|
CREATE TABLE t1(a1 DATE, a2 INTEGER PRIMARY KEY, a3 INTEGER, memo TEXT);
|
|
CREATE INDEX t1x1 ON t1(a3, a1, memo->>'y');
|
|
INSERT INTO t1(a2,a1,a3,memo) VALUES (876, '2023-08-03', 5, '{"x":77,"y":4
|
|
|
|
UPDATE t1 SET memo = JSON_REMOVE(memo, '$.y');
|
|
PRAGMA integrity_check;
|
|
SELECT * FROM t1;
|
|
|
|
|
|
UPDATE t1 SET memo = JSON_SET(memo, '$.y', 6)
|
|
WHERE a2 IN (876) AND JSON_TYPE(memo, '$.y') IS NULL;
|
|
PRAGMA integrity_check;
|
|
SELECT * FROM t1;
|
|
|