mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-01-23 17:46:49 +00:00
ad79ef48a2
* add tests * add bench
243 lines
4.8 KiB
Plaintext
243 lines
4.8 KiB
Plaintext
|
|
CREATE TABLE t1(
|
|
a INTEGER PRIMARY KEY ON CONFLICT REPLACE,
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a INT PRIMARY KEY ON CONFLICT REPLACE,
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a INT PRIMARY KEY ON CONFLICT REPLACE,
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
) WITHOUT ROWID;
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL,
|
|
a INT PRIMARY KEY ON CONFLICT REPLACE
|
|
) WITHOUT ROWID;
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
a INT PRIMARY KEY ON CONFLICT REPLACE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
c UNIQUE ON CONFLICT FAIL,
|
|
a INT PRIMARY KEY ON CONFLICT REPLACE,
|
|
b UNIQUE ON CONFLICT IGNORE
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a UNIQUE ON CONFLICT REPLACE,
|
|
b INTEGER PRIMARY KEY ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a UNIQUE ON CONFLICT REPLACE,
|
|
b INT PRIMARY KEY ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a UNIQUE ON CONFLICT REPLACE,
|
|
b INT PRIMARY KEY ON CONFLICT IGNORE,
|
|
c UNIQUE ON CONFLICT FAIL
|
|
) WITHOUT ROWID;
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a UNIQUE ON CONFLICT REPLACE,
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
c INTEGER PRIMARY KEY ON CONFLICT FAIL
|
|
);
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1(
|
|
a UNIQUE ON CONFLICT REPLACE,
|
|
b UNIQUE ON CONFLICT IGNORE,
|
|
c PRIMARY KEY ON CONFLICT FAIL
|
|
) WITHOUT ROWID;
|
|
INSERT INTO t1(a,b,c) VALUES(1,2,3), (2,3,4);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
INSERT INTO t1(a,b,c) VALUES(3,2,5);
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
SELECT a,b,c FROM t1 ORDER BY a;
|
|
|
|
|
|
CREATE TABLE t2(a INTEGER PRIMARY KEY, b TEXT);
|
|
INSERT INTO t2 VALUES(111, '111');
|
|
|
|
|
|
REPLACE INTO t2 VALUES(NULL, '112'), (111, '111B');
|
|
|
|
|
|
SELECT * FROM t2;
|
|
|
|
|
|
PRAGMA recursive_triggers = true;
|
|
CREATE TABLE t0 (c0 UNIQUE, c1 UNIQUE);
|
|
CREATE TRIGGER tr0 AFTER DELETE ON t0 BEGIN
|
|
DELETE FROM t0;
|
|
END;
|
|
|
|
INSERT INTO t0 VALUES(1, NULL);
|
|
INSERT INTO t0 VALUES(0, NULL);
|
|
|
|
|
|
SELECT * FROM t0
|
|
|
|
|
|
CREATE TABLE t2 (a PRIMARY KEY, b UNIQUE, c UNIQUE) WITHOUT ROWID;
|
|
CREATE TRIGGER tr3 AFTER DELETE ON t2 BEGIN
|
|
DELETE FROM t2;
|
|
END;
|
|
|
|
INSERT INTO t2 VALUES(1, 1, 1);
|
|
INSERT INTO t2 VALUES(2, 2, 2);
|
|
|
|
|
|
SELECT * FROM t2
|
|
|
|
|
|
CREATE TABLE t1(a, b);
|
|
CREATE TABLE log(x);
|
|
CREATE INDEX i1 ON t1(a);
|
|
INSERT INTO t1 VALUES(1, 2);
|
|
|
|
CREATE TRIGGER tb BEFORE UPDATE ON t1 BEGIN
|
|
DELETE FROM t1;
|
|
END;
|
|
CREATE TRIGGER ta AFTER UPDATE ON t1 BEGIN
|
|
INSERT INTO log VALUES('fired!');
|
|
END;
|
|
|
|
UPDATE t1 SET b=3;
|
|
|
|
|
|
SELECT * FROM t1;
|
|
|
|
|
|
SELECT * FROM log;
|
|
|