0
0
mirror of https://github.com/tursodatabase/libsql.git synced 2025-01-09 18:06:02 +00:00
ad hoc ad79ef48a2 libsql wal tests (#1408)
* add tests

* add bench
2024-05-24 13:59:17 +00:00

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;