mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-01-19 12:21:50 +00:00
ad79ef48a2
* add tests * add bench
400 lines
10 KiB
Plaintext
400 lines
10 KiB
Plaintext
|
|
SELECT 0 < 2 LIKE 1, (0 < 2) LIKE 1, 0 < (2 LIKE 1)
|
|
|
|
|
|
SELECT 0 LIKE 0 < 2, (0 LIKE 0) < 2, 0 LIKE (0 < 2)
|
|
|
|
|
|
SELECT 2 LIKE 2 == 1, (2 LIKE 2) == 1, 2 LIKE (2 == 1)
|
|
|
|
|
|
SELECT 2 == 2 LIKE 1, (2 == 2) LIKE 1, 2 == (2 LIKE 1)
|
|
|
|
|
|
SELECT 0 < 2 == 1, (0 < 2) == 1, 0 < (2 == 1)
|
|
|
|
|
|
SELECT 0 == 0 < 2, (0 == 0) < 2, 0 == (0 < 2)
|
|
|
|
SELECT - 10
|
|
SELECT + 10
|
|
SELECT ~ 10
|
|
SELECT NOT 10
|
|
SELECT 72%5
|
|
SELECT 72%-5
|
|
SELECT -72%-5
|
|
SELECT -72%5
|
|
SELECT 72.35%5
|
|
SELECT 'ab' IS NOT NULL
|
|
SELECT NULL IS NOT 'ab'
|
|
SELECT 'ab' IS NOT 'ab'
|
|
SELECT NULL != NULL
|
|
SELECT 'ab' != NULL
|
|
SELECT NULL != 'ab'
|
|
SELECT 'ab' != 'ab'
|
|
SELECT 'abcd' < 'bbbb' COLLATE reverse
|
|
SELECT ('abcd' < 'bbbb') COLLATE reverse
|
|
SELECT 'abcd' <= 'bbbb' COLLATE reverse
|
|
SELECT ('abcd' <= 'bbbb') COLLATE reverse
|
|
SELECT 'abcd' > 'bbbb' COLLATE reverse
|
|
SELECT ('abcd' > 'bbbb') COLLATE reverse
|
|
SELECT 'abcd' >= 'bbbb' COLLATE reverse
|
|
SELECT ('abcd' >= 'bbbb') COLLATE reverse
|
|
SELECT 'abcd' = 'ABCD' COLLATE nocase
|
|
SELECT ('abcd' = 'ABCD') COLLATE nocase
|
|
SELECT 'abcd' == 'ABCD' COLLATE nocase
|
|
SELECT ('abcd' == 'ABCD') COLLATE nocase
|
|
SELECT 'abcd' IS 'ABCD' COLLATE nocase
|
|
SELECT ('abcd' IS 'ABCD') COLLATE nocase
|
|
SELECT 'abcd' != 'ABCD' COLLATE nocase
|
|
SELECT ('abcd' != 'ABCD') COLLATE nocase
|
|
SELECT 'abcd' <> 'ABCD' COLLATE nocase
|
|
SELECT ('abcd' <> 'ABCD') COLLATE nocase
|
|
SELECT 'abcd' IS NOT 'ABCD' COLLATE nocase
|
|
SELECT ('abcd' IS NOT 'ABCD') COLLATE nocase
|
|
|
|
SELECT 'bbb' BETWEEN 'AAA' AND 'CCC' COLLATE nocase
|
|
|
|
|
|
SELECT ('bbb' BETWEEN 'AAA' AND 'CCC') COLLATE nocase
|
|
|
|
|
|
CREATE TABLE t24(a COLLATE NOCASE, b);
|
|
INSERT INTO t24 VALUES('aaa', 1);
|
|
INSERT INTO t24 VALUES('bbb', 2);
|
|
INSERT INTO t24 VALUES('ccc', 3);
|
|
|
|
SELECT 'BBB' = a FROM t24
|
|
SELECT a = 'BBB' FROM t24
|
|
SELECT 'BBB' = a COLLATE binary FROM t24
|
|
SELECT a COLLATE binary = 'BBB' FROM t24
|
|
SELECT typeof(5)
|
|
SELECT typeof(5.1)
|
|
SELECT typeof('5.1')
|
|
SELECT typeof(X'ABCD')
|
|
SELECT typeof(NULL)
|
|
SELECT typeof(3.4e-02)
|
|
SELECT typeof(3e+5)
|
|
SELECT 3.4e-02
|
|
SELECT 3e+4
|
|
SELECT 'is not'
|
|
SELECT typeof('is not')
|
|
SELECT 'isn''t'
|
|
SELECT typeof('isn''t')
|
|
SELECT typeof(X'0123456789ABCDEF')
|
|
SELECT typeof(x'0123456789ABCDEF')
|
|
SELECT typeof(X'0123456789abcdef')
|
|
SELECT typeof(x'0123456789abcdef')
|
|
SELECT typeof(X'53514C697465')
|
|
SELECT NULL
|
|
SELECT typeof(NULL)
|
|
SELECT 0, +0, -0
|
|
SELECT 1, +1, -1
|
|
SELECT 2, +2, -2
|
|
|
|
SELECT 1.4, +1.4, -1.4
|
|
|
|
|
|
SELECT 1.5e+5, +1.5e+5, -1.5e+5
|
|
|
|
|
|
SELECT 0.0001, +0.0001, -0.0001
|
|
|
|
SELECT 123
|
|
SELECT 123.4e05
|
|
SELECT 'abcde'
|
|
SELECT X'414243'
|
|
SELECT NULL
|
|
SELECT CURRENT_TIME
|
|
SELECT CURRENT_DATE
|
|
SELECT CURRENT_TIMESTAMP
|
|
SELECT 1 != 0 BETWEEN 0 AND 2
|
|
SELECT (1 != 0) BETWEEN 0 AND 2
|
|
SELECT 1 != (0 BETWEEN 0 AND 2)
|
|
SELECT 1 LIKE 10 BETWEEN 0 AND 2
|
|
SELECT (1 LIKE 10) BETWEEN 0 AND 2
|
|
SELECT 1 LIKE (10 BETWEEN 0 AND 2)
|
|
SELECT 6 BETWEEN 4 AND 8 LIKE 1
|
|
SELECT (6 BETWEEN 4 AND 8) LIKE 1
|
|
SELECT 6 BETWEEN 4 AND (8 LIKE 1)
|
|
SELECT 0 AND 0 BETWEEN 0 AND 1
|
|
SELECT 0 AND (0 BETWEEN 0 AND 1)
|
|
SELECT (0 AND 0) BETWEEN 0 AND 1
|
|
SELECT 0 BETWEEN -1 AND 1 AND 0
|
|
SELECT (0 BETWEEN -1 AND 1) AND 0
|
|
SELECT 0 BETWEEN -1 AND (1 AND 0)
|
|
SELECT 2 < 3 BETWEEN 0 AND 1
|
|
SELECT (2 < 3) BETWEEN 0 AND 1
|
|
SELECT 2 < (3 BETWEEN 0 AND 1)
|
|
SELECT 2 BETWEEN 1 AND 2 < 3
|
|
SELECT 2 BETWEEN 1 AND (2 < 3)
|
|
SELECT (2 BETWEEN 1 AND 2) < 3
|
|
SELECT 'abc%' LIKE 'abcde'
|
|
SELECT 'abcde' LIKE 'abc%'
|
|
SELECT 'abde' LIKE 'ab%de'
|
|
SELECT 'abXde' LIKE 'ab%de'
|
|
SELECT 'abABCde' LIKE 'ab%de'
|
|
SELECT 'abde' LIKE 'ab_de'
|
|
SELECT 'abXde' LIKE 'ab_de'
|
|
SELECT 'abABCde' LIKE 'ab_de'
|
|
SELECT 'abc' LIKE 'aBc'
|
|
SELECT 'aBc' LIKE 'aBc'
|
|
SELECT 'ac' LIKE 'aBc'
|
|
SELECT 'A' LIKE 'a'
|
|
SELECT 'abc__' LIKE 'abcX_' ESCAPE 'X'
|
|
SELECT 'abcX' LIKE 'abcXX' ESCAPE 'X'
|
|
SELECT 'abc5' LIKE 'abcXX' ESCAPE 'X'
|
|
SELECT 'abc' LIKE 'abcXX' ESCAPE 'X'
|
|
SELECT 'abcXX' LIKE 'abcXX' ESCAPE 'X'
|
|
SELECT 'abc' LIKE 'def'
|
|
SELECT 'abc' LIKE 'def' ESCAPE 'X'
|
|
SELECT 'abc%xyz' LIKE 'ABC\%x%' ESCAPE '\'
|
|
SELECT 'abc%xyz' LIKE 'ABC\%X%' ESCAPE '\'
|
|
SELECT 'ABC%xyz' LIKE 'ABC\%x%' ESCAPE '\'
|
|
SELECT 'abc%xyz' LIKE 'ABC\%X%' ESCAPE '\'
|
|
SELECT 'ABC%xyz' LIKE 'ABC\%X%' ESCAPE '\'
|
|
SELECT 'abcxyz' GLOB 'abc%'
|
|
SELECT 'abcxyz' GLOB 'abc*'
|
|
SELECT 'abcxyz' GLOB 'abc___'
|
|
SELECT 'abcxyz' GLOB 'abc???'
|
|
SELECT 'abcxyz' GLOB 'abc*'
|
|
SELECT 'ABCxyz' GLOB 'abc*'
|
|
SELECT 'abcxyz' GLOB 'ABC*'
|
|
SELECT 'abcxyz' NOT GLOB 'ABC*'
|
|
SELECT 'abcxyz' NOT GLOB 'abc*'
|
|
SELECT 'abcxyz' NOT LIKE 'ABC%'
|
|
SELECT 'abcxyz' NOT LIKE 'abc%'
|
|
SELECT 'abdxyz' NOT LIKE 'abc%'
|
|
SELECT 'abcxyz' NOT GLOB NULL
|
|
SELECT 'abcxyz' NOT LIKE NULL
|
|
SELECT NULL NOT GLOB 'abc*'
|
|
SELECT NULL NOT LIKE 'ABC%'
|
|
SELECT 'abc' GLOB 'def'
|
|
SELECT 'X' NOT GLOB 'Y'
|
|
SELECT 'abc' REGEXP 'def'
|
|
SELECT 'X' NOT REGEXP 'Y'
|
|
SELECT 'abc' MATCH 'def'
|
|
SELECT 'X' NOT MATCH 'Y'
|
|
|
|
SELECT CASE WHEN 1 THEN 'true' WHEN 0 THEN 'false' ELSE 'else' END;
|
|
|
|
|
|
SELECT CASE 0 WHEN 1 THEN 'true' WHEN 0 THEN 'false' ELSE 'else' END;
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C' END
|
|
|
|
|
|
SELECT CASE WHEN var('c') THEN 'C'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('a') THEN 'A'
|
|
ELSE 'no result'
|
|
END
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
ELSE 'no result'
|
|
END
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
ELSE 'no result'
|
|
END
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
ELSE 'no result'
|
|
END
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
ELSE 'no result'
|
|
END
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
END
|
|
|
|
|
|
SELECT CASE WHEN NULL THEN 'A' WHEN 1 THEN 'B' END, iif(NULL,8,99);
|
|
|
|
|
|
SELECT CASE WHEN 0 THEN 'A' WHEN NULL THEN 'B' ELSE 'C' END, iif(0,8,99);
|
|
|
|
|
|
SELECT CASE var('a') WHEN 1 THEN 'A' WHEN 2 THEN 'B' WHEN 3 THEN 'C' END
|
|
|
|
|
|
SELECT CASE 23 WHEN 1 THEN 'A' WHEN 23 THEN 'B' WHEN 23 THEN 'C' END
|
|
|
|
|
|
SELECT CASE 1 WHEN 1 THEN 'A' WHEN 23 THEN 'B' WHEN 23 THEN 'C' END
|
|
|
|
|
|
SELECT CASE 24 WHEN 1 THEN 'A' WHEN 23 THEN 'B' WHEN 23 THEN 'C' ELSE 'D' END
|
|
|
|
|
|
SELECT CASE 24 WHEN 1 THEN 'A' WHEN 23 THEN 'B' WHEN 23 THEN 'C' END
|
|
|
|
|
|
SELECT CASE 24 WHEN 1 THEN 'A' WHEN 23 THEN 'B' WHEN 23 THEN 'C' END
|
|
|
|
|
|
CREATE TABLE t1(
|
|
a TEXT COLLATE NOCASE,
|
|
b COLLATE REVERSE,
|
|
c INTEGER,
|
|
d BLOB
|
|
);
|
|
INSERT INTO t1 VALUES('abc', 'cba', 55, 34.5);
|
|
|
|
|
|
SELECT CASE a WHEN 'xyz' THEN 'A' WHEN 'AbC' THEN 'B' END FROM t1
|
|
|
|
|
|
SELECT CASE 'AbC' WHEN 'abc' THEN 'A' WHEN a THEN 'B' END FROM t1
|
|
|
|
|
|
SELECT CASE a WHEN b THEN 'A' ELSE 'B' END FROM t1
|
|
|
|
|
|
SELECT CASE b WHEN a THEN 'A' ELSE 'B' END FROM t1
|
|
|
|
|
|
SELECT CASE 55 WHEN '55' THEN 'A' ELSE 'B' END
|
|
|
|
|
|
SELECT CASE c WHEN '55' THEN 'A' ELSE 'B' END FROM t1
|
|
|
|
|
|
SELECT CASE '34.5' WHEN d THEN 'A' ELSE 'B' END FROM t1
|
|
|
|
|
|
SELECT CASE NULL WHEN NULL THEN 'A' ELSE 'B' END
|
|
|
|
|
|
SELECT CASE NULL WHEN 'abc' THEN 'A' WHEN 'def' THEN 'B' END;
|
|
|
|
|
|
SELECT CASE NULL WHEN 'abc' THEN 'A' WHEN 'def' THEN 'B' ELSE 'C' END;
|
|
|
|
|
|
SELECT CASE WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
END
|
|
|
|
|
|
SELECT CASE '0' WHEN var('a') THEN 'A'
|
|
WHEN var('b') THEN 'B'
|
|
WHEN var('c') THEN 'C'
|
|
END
|
|
|
|
|
|
CREATE TABLE t2(x, w1, r1, w2, r2, r3);
|
|
INSERT INTO t2 VALUES(1, 1, 'R1', 2, 'R2', 'R3');
|
|
INSERT INTO t2 VALUES(2, 1, 'R1', 2, 'R2', 'R3');
|
|
INSERT INTO t2 VALUES(3, 1, 'R1', 2, 'R2', 'R3');
|
|
|
|
|
|
SELECT CASE x WHEN w1 THEN r1 WHEN w2 THEN r2 ELSE r3 END FROM t2
|
|
|
|
|
|
SELECT CASE WHEN x=w1 THEN r1 WHEN x=w2 THEN r2 ELSE r3 END FROM t2
|
|
|
|
|
|
SELECT CASE ceval(x) WHEN w1 THEN r1 WHEN w2 THEN r2 ELSE r3 END FROM t2
|
|
|
|
|
|
SELECT CASE
|
|
WHEN ceval(x)=w1 THEN r1
|
|
WHEN ceval(x)=w2 THEN r2
|
|
ELSE r3 END
|
|
FROM t2
|
|
|
|
|
|
CREATE TABLE t3(a TEXT, b REAL, c INTEGER);
|
|
INSERT INTO t3 VALUES(X'555655', '1.23abc', 4.5);
|
|
SELECT typeof(a), a, typeof(b), b, typeof(c), c FROM t3;
|
|
|
|
|
|
SELECT
|
|
typeof(CAST(X'555655' as TEXT)), CAST(X'555655' as TEXT),
|
|
typeof(CAST('1.23abc' as REAL)), CAST('1.23abc' as REAL),
|
|
typeof(CAST(4.5 as INTEGER)), CAST(4.5 as INTEGER)
|
|
|
|
|
|
WITH t1(x) AS (VALUES
|
|
('9000000000000000001'),
|
|
('9000000000000000001x'),
|
|
('9000000000000000001 '),
|
|
(' 9000000000000000001 '),
|
|
(' 9000000000000000001'),
|
|
(' 9000000000000000001.'),
|
|
('9223372036854775807'),
|
|
('9223372036854775807 '),
|
|
(' 9223372036854775807 '),
|
|
('9223372036854775808'),
|
|
(' 9223372036854775808 '),
|
|
('9223372036854775807.0'),
|
|
('9223372036854775807e+0'),
|
|
('-5.0'),
|
|
('-5e+0'))
|
|
SELECT typeof(CAST(x AS NUMERIC)), CAST(x AS NUMERIC)||'' FROM t1;
|
|
|
|
|
|
CREATE TABLE t1(a, b);
|
|
INSERT INTO t1 VALUES(1, 2);
|
|
INSERT INTO t1 VALUES(NULL, 2);
|
|
INSERT INTO t1 VALUES(1, NULL);
|
|
INSERT INTO t1 VALUES(NULL, NULL);
|
|
|
|
|
|
CREATE TABLE t4(x, y);
|
|
INSERT INTO t4 VALUES(1, 'one');
|
|
INSERT INTO t4 VALUES(2, 'two');
|
|
INSERT INTO t4 VALUES(3, 'three');
|
|
|
|
|
|
SELECT CASE WHEN NULL THEN 'true' ELSE 'false' END, iif(NULL,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN 0.0 THEN 'true' ELSE 'false' END, iif(0.0,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN 0 THEN 'true' ELSE 'false' END, iif(0,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN 'engligh' THEN 'true' ELSE 'false' END, iif('engligh','true','false');
|
|
|
|
|
|
SELECT CASE WHEN '0' THEN 'true' ELSE 'false' END, iif('0','true','false');
|
|
|
|
|
|
SELECT CASE WHEN 1 THEN 'true' ELSE 'false' END, iif(1,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN 1.0 THEN 'true' ELSE 'false' END, iif(1.0,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN 0.1 THEN 'true' ELSE 'false' END, iif(0.1,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN -0.1 THEN 'true' ELSE 'false' END, iif(-0.1,'true','false');
|
|
|
|
|
|
SELECT CASE WHEN '1english' THEN 'true' ELSE 'false' END, iif('1engl','true','false');
|
|
|