xref: /sqlite-3.40.0/test/whereI.test (revision 8210233c)
1f97dad88Sdan# 2014-03-31
2f97dad88Sdan#
3f97dad88Sdan# The author disclaims copyright to this source code.  In place of
4f97dad88Sdan# a legal notice, here is a blessing:
5f97dad88Sdan#
6f97dad88Sdan#    May you do good and not evil.
7f97dad88Sdan#    May you find forgiveness for yourself and forgive others.
8f97dad88Sdan#    May you share freely, never taking more than you give.
9f97dad88Sdan#
10f97dad88Sdan#***********************************************************************
11f97dad88Sdan# The focus of this file is testing the OR optimization on WITHOUT ROWID
12f97dad88Sdan# tables.
13f97dad88Sdan#
14f97dad88Sdan
15f97dad88Sdanset testdir [file dirname $argv0]
16f97dad88Sdansource $testdir/tester.tcl
17f97dad88Sdanset ::testprefix whereI
18f97dad88Sdan
19f97dad88Sdando_execsql_test 1.0 {
20f97dad88Sdan  CREATE TABLE t1(a, b, c, PRIMARY KEY(a)) WITHOUT ROWID;
21f97dad88Sdan  INSERT INTO t1 VALUES(1, 'a', 'z');
22f97dad88Sdan  INSERT INTO t1 VALUES(2, 'b', 'y');
23f97dad88Sdan  INSERT INTO t1 VALUES(3, 'c', 'x');
24f97dad88Sdan  INSERT INTO t1 VALUES(4, 'd', 'w');
25f97dad88Sdan  CREATE INDEX i1 ON t1(b);
26f97dad88Sdan  CREATE INDEX i2 ON t1(c);
27f97dad88Sdan}
28f97dad88Sdan
29f97dad88Sdando_eqp_test 1.1 {
30f97dad88Sdan  SELECT a FROM t1 WHERE b='b' OR c='x'
31f97dad88Sdan} {
32b3f0276bSdrh  QUERY PLAN
335d72d924Sdrh  `--MULTI-INDEX OR
34bd462bccSdrh     |--INDEX 1
35*8210233cSdrh     |  `--SEARCH t1 USING INDEX i1 (b=?)
36bd462bccSdrh     `--INDEX 2
37*8210233cSdrh        `--SEARCH t1 USING INDEX i2 (c=?)
38f97dad88Sdan}
39f97dad88Sdan
40f97dad88Sdando_execsql_test 1.2 {
41f97dad88Sdan  SELECT a FROM t1 WHERE b='b' OR c='x'
42f97dad88Sdan} {2 3}
43f97dad88Sdan
44f97dad88Sdando_execsql_test 1.3 {
45f97dad88Sdan  SELECT a FROM t1 WHERE b='a' OR c='z'
46f97dad88Sdan} {1}
47f97dad88Sdan
48f97dad88Sdan#----------------------------------------------------------------------
49f97dad88Sdan# Try that again, this time with non integer PRIMARY KEY values.
50f97dad88Sdan#
51f97dad88Sdando_execsql_test 2.0 {
52f97dad88Sdan  CREATE TABLE t2(a, b, c, PRIMARY KEY(a)) WITHOUT ROWID;
53f97dad88Sdan  INSERT INTO t2 VALUES('i', 'a', 'z');
54f97dad88Sdan  INSERT INTO t2 VALUES('ii', 'b', 'y');
55f97dad88Sdan  INSERT INTO t2 VALUES('iii', 'c', 'x');
56f97dad88Sdan  INSERT INTO t2 VALUES('iv', 'd', 'w');
57f97dad88Sdan  CREATE INDEX i3 ON t2(b);
58f97dad88Sdan  CREATE INDEX i4 ON t2(c);
59f97dad88Sdan}
60f97dad88Sdan
61f97dad88Sdando_eqp_test 2.1 {
62f97dad88Sdan  SELECT a FROM t2 WHERE b='b' OR c='x'
63f97dad88Sdan} {
64b3f0276bSdrh  QUERY PLAN
655d72d924Sdrh  `--MULTI-INDEX OR
66bd462bccSdrh     |--INDEX 1
67*8210233cSdrh     |  `--SEARCH t2 USING INDEX i3 (b=?)
68bd462bccSdrh     `--INDEX 2
69*8210233cSdrh        `--SEARCH t2 USING INDEX i4 (c=?)
70f97dad88Sdan}
71f97dad88Sdan
72f97dad88Sdando_execsql_test 2.2 {
73f97dad88Sdan  SELECT a FROM t2 WHERE b='b' OR c='x'
74f97dad88Sdan} {ii iii}
75f97dad88Sdan
76f97dad88Sdando_execsql_test 2.3 {
77f97dad88Sdan  SELECT a FROM t2 WHERE b='a' OR c='z'
78f97dad88Sdan} {i}
79f97dad88Sdan
80c2070c7dSdan#----------------------------------------------------------------------
81c2070c7dSdan# On a table with a multi-column PK.
82c2070c7dSdan#
83c2070c7dSdando_execsql_test 3.0 {
84c2070c7dSdan  CREATE TABLE t3(a, b, c, d, PRIMARY KEY(c, b)) WITHOUT ROWID;
85f97dad88Sdan
86c2070c7dSdan  INSERT INTO t3 VALUES('f', 1, 1, 'o');
87c2070c7dSdan  INSERT INTO t3 VALUES('o', 2, 1, 't');
88c2070c7dSdan  INSERT INTO t3 VALUES('t', 1, 2, 't');
89c2070c7dSdan  INSERT INTO t3 VALUES('t', 2, 2, 'f');
90c2070c7dSdan
91c2070c7dSdan  CREATE INDEX t3i1 ON t3(d);
92c2070c7dSdan  CREATE INDEX t3i2 ON t3(a);
93c2070c7dSdan
94c2070c7dSdan  SELECT c||'.'||b FROM t3 WHERE a='t' OR d='t'
95c2070c7dSdan} {
96c2070c7dSdan  2.1 2.2 1.2
97c2070c7dSdan}
98c2070c7dSdan
99c2070c7dSdanfinish_test
100