7de7602eb7
FossilOrigin-Name: 50add839fd95665bd67a6ae5de8346fd09e83904bbcbad26fad280dff86d9e93
71 lines
2.2 KiB
Plaintext
71 lines
2.2 KiB
Plaintext
# 2018-07-26
|
|
#
|
|
# 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 testing the WHERE-clause constant propagation
|
|
# optimization.
|
|
#
|
|
set testdir [file dirname $argv0]
|
|
source $testdir/tester.tcl
|
|
set ::testprefix whereL
|
|
|
|
do_execsql_test 100 {
|
|
CREATE TABLE t1(a INT PRIMARY KEY, b, c, d, e);
|
|
CREATE TABLE t2(a INT PRIMARY KEY, f, g, h, i);
|
|
CREATE TABLE t3(a INT PRIMARY KEY, j, k, l, m);
|
|
CREATE VIEW v4 AS SELECT * FROM t2 UNION ALL SELECT * FROM t3;
|
|
}
|
|
do_eqp_test 110 {
|
|
SELECT * FROM t1, v4 WHERE t1.a=?1 AND v4.a=t1.a;
|
|
} {
|
|
QUERY PLAN
|
|
|--MATERIALIZE xxxxxx
|
|
| `--COMPOUND QUERY
|
|
| |--LEFT-MOST SUBQUERY
|
|
| | `--SEARCH TABLE t2 USING INDEX sqlite_autoindex_t2_1 (a=?)
|
|
| `--UNION ALL
|
|
| `--SEARCH TABLE t3 USING INDEX sqlite_autoindex_t3_1 (a=?)
|
|
|--SCAN SUBQUERY xxxxxx
|
|
`--SEARCH TABLE t1 USING INDEX sqlite_autoindex_t1_1 (a=?)
|
|
}
|
|
|
|
# The scan of the t1 table goes first since that enables the ORDER BY
|
|
# sort to be omitted. This would not be possible without constant
|
|
# propagation because without it the t1 table would depend on t3.
|
|
#
|
|
do_eqp_test 120 {
|
|
SELECT * FROM t1, t2, t3
|
|
WHERE t1.a=t2.a AND t2.a=t3.j AND t3.j=5
|
|
ORDER BY t1.a;
|
|
} {
|
|
QUERY PLAN
|
|
|--SEARCH TABLE t1 USING INDEX sqlite_autoindex_t1_1 (a=?)
|
|
|--SEARCH TABLE t2 USING INDEX sqlite_autoindex_t2_1 (a=?)
|
|
`--SCAN TABLE t3
|
|
}
|
|
|
|
# Constant propagation in the face of collating sequences:
|
|
#
|
|
do_execsql_test 200 {
|
|
CREATE TABLE c3(x COLLATE binary, y COLLATE nocase, z COLLATE binary);
|
|
CREATE INDEX c3x ON c3(x);
|
|
INSERT INTO c3 VALUES('ABC', 'ABC', 'abc');
|
|
SELECT * FROM c3 WHERE x=y AND y=z AND z='abc';
|
|
} {ABC ABC abc}
|
|
|
|
# If the constants are blindly propagated, as shown in the following
|
|
# query, the wrong answer results:
|
|
#
|
|
do_execsql_test 201 {
|
|
SELECT * FROM c3 WHERE x='abc' AND y='abc' AND z='abc';
|
|
} {}
|
|
|
|
finish_test
|