mirror of
https://github.com/sqlite/sqlite.git
synced 2024-11-25 08:59:33 +01:00
07d7a8dca9
FossilOrigin-Name: cd5182bd6f5969ba0812275f471224908296960358013327cebbe0c52b820f04
195 lines
5.1 KiB
Plaintext
195 lines
5.1 KiB
Plaintext
# 2020-10-19
|
|
#
|
|
# The author disclaims copyright to this source code. In place of
|
|
# a legal notice, here is a blessing:
|
|
#
|
|
# May you do good and not evil.
|
|
# May you find forgiveness for yourself and forgive others.
|
|
# May you share freely, never taking more than you give.
|
|
#
|
|
#***********************************************************************
|
|
# This file implements regression tests for SQLite library. The
|
|
# focus of this file is recursive common table expressions with
|
|
# multiple recursive terms in the compound select.
|
|
#
|
|
|
|
set testdir [file dirname $argv0]
|
|
source $testdir/tester.tcl
|
|
set ::testprefix with5
|
|
|
|
ifcapable {!cte} {
|
|
finish_test
|
|
return
|
|
}
|
|
|
|
do_execsql_test 100 {
|
|
CREATE TABLE link(aa INT, bb INT);
|
|
CREATE INDEX link_f ON link(aa,bb);
|
|
CREATE INDEX link_t ON link(bb,aa);
|
|
INSERT INTO link(aa,bb) VALUES
|
|
(1,3),
|
|
(5,3),
|
|
(7,1),
|
|
(7,9),
|
|
(9,9),
|
|
(5,11),
|
|
(11,7),
|
|
(2,4),
|
|
(4,6),
|
|
(8,6);
|
|
} {}
|
|
do_execsql_test 110 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1)
|
|
UNION
|
|
SELECT aa FROM closure, link WHERE link.bb=closure.x
|
|
UNION
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 3 5 7 9 11}
|
|
do_execsql_test 111 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1)
|
|
UNION
|
|
SELECT aa FROM link, closure WHERE link.bb=closure.x
|
|
UNION
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 3 5 7 9 11}
|
|
do_execsql_test 112 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1)
|
|
UNION
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
UNION
|
|
SELECT aa FROM link, closure WHERE link.bb=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 3 5 7 9 11}
|
|
do_execsql_test 113 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1),(200),(300),(400)
|
|
INTERSECT
|
|
VALUES(1)
|
|
UNION
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
UNION
|
|
SELECT aa FROM link, closure WHERE link.bb=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 3 5 7 9 11}
|
|
do_execsql_test 114 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1),(200),(300),(400)
|
|
UNION ALL
|
|
VALUES(2)
|
|
UNION
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
UNION
|
|
SELECT aa FROM link, closure WHERE link.bb=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 2 3 4 5 6 7 8 9 11 200 300 400}
|
|
|
|
do_catchsql_test 120 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1),(200),(300),(400)
|
|
UNION ALL
|
|
VALUES(2)
|
|
UNION ALL
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
UNION
|
|
SELECT aa FROM link, closure WHERE link.bb=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 {circular reference: closure}}
|
|
do_catchsql_test 121 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1),(200),(300),(400)
|
|
UNION ALL
|
|
VALUES(2)
|
|
UNION
|
|
SELECT bb FROM closure, link WHERE link.aa=closure.x
|
|
UNION ALL
|
|
SELECT aa FROM link, closure WHERE link.bb=closure.x
|
|
)
|
|
SELECT x FROM closure ORDER BY x;
|
|
} {1 {circular reference: closure}}
|
|
|
|
do_execsql_test 130 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
SELECT 1 AS x
|
|
UNION
|
|
SELECT aa FROM link JOIN closure ON bb=x
|
|
UNION
|
|
SELECT bb FROM link JOIN closure on aa=x
|
|
ORDER BY x LIMIT 4
|
|
)
|
|
SELECT * FROM closure;
|
|
} {1 3 5 7}
|
|
do_execsql_test 131 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
SELECT 1 AS x
|
|
UNION ALL
|
|
SELECT 2
|
|
UNION
|
|
SELECT aa FROM link JOIN closure ON bb=x
|
|
UNION
|
|
SELECT bb FROM link JOIN closure on aa=x
|
|
ORDER BY x LIMIT 4
|
|
)
|
|
SELECT * FROM closure;
|
|
} {1 2 3 4}
|
|
|
|
do_execsql_test 200 {
|
|
CREATE TABLE linkA(aa1,aa2);
|
|
INSERT INTO linkA(aa1,aa2) VALUES(1,3),(5,7),(9,11);
|
|
CREATE TABLE linkB(bb1,bb2);
|
|
INSERT INTO linkB(bb1,bb2) VALUES(7,9),(11,13),(3,5);
|
|
CREATE TABLE linkC(cc1,cc2);
|
|
INSERT INTO linkC(cc1,cc2) VALUES(1,2),(2,4),(6,8);
|
|
CREATE TABLE linkD(dd1,dd2);
|
|
INSERT INTO linkD(dd1,dd2) VALUES(4,6),(100,110);
|
|
} {}
|
|
do_execsql_test 210 {
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1)
|
|
UNION ALL
|
|
SELECT aa2 FROM linkA JOIN closure ON x=aa1
|
|
UNION ALL
|
|
SELECT bb2 FROM linkB JOIN closure ON x=bb1
|
|
UNION ALL
|
|
SELECT cc2 FROM linkC JOIN closure ON x=cc1
|
|
UNION ALL
|
|
SELECT dd2 FROM linkD JOIN closure ON x=dd1
|
|
)
|
|
SELECT x FROM closure ORDER BY +x;
|
|
} {1 2 3 4 5 6 7 8 9 11 13}
|
|
do_execsql_test 220 {
|
|
CREATE TABLE linkA_ipk(aa1 INTEGER PRIMARY KEY,aa2);
|
|
INSERT INTO linkA_ipk(aa1,aa2) SELECT aa1, aa2 FROM linkA;
|
|
CREATE TABLE linkB_ipk(bb1 INTEGER PRIMARY KEY,bb2);
|
|
INSERT INTO linkB_ipk(bb1,bb2) SELECT bb1, bb2 FROM linkB;
|
|
CREATE TABLE linkC_ipk(cc1 INTEGER PRIMARY KEY,cc2);
|
|
INSERT INTO linkC_ipk(cc1,cc2) SELECT cc1, cc2 FROM linkC;
|
|
CREATE TABLE linkD_ipk(dd1 INTEGER PRIMARY KEY,dd2);
|
|
INSERT INTO linkD_ipk(dd1,dd2) SELECT dd1, dd2 FROM linkD;
|
|
WITH RECURSIVE closure(x) AS (
|
|
VALUES(1)
|
|
UNION ALL
|
|
SELECT aa2 FROM linkA_ipk JOIN closure ON x=aa1
|
|
UNION ALL
|
|
SELECT bb2 FROM linkB_ipk JOIN closure ON x=bb1
|
|
UNION ALL
|
|
SELECT cc2 FROM linkC_ipk JOIN closure ON x=cc1
|
|
UNION ALL
|
|
SELECT dd2 FROM linkD_ipk JOIN closure ON x=dd1
|
|
)
|
|
SELECT x FROM closure ORDER BY +x;
|
|
} {1 2 3 4 5 6 7 8 9 11 13}
|
|
|
|
|
|
finish_test
|