3 # The author disclaims copyright to this source code. In place of
4 # a legal notice, here is a blessing:
6 # May you do good and not evil.
7 # May you find forgiveness for yourself and forgive others.
8 # May you share freely, never taking more than you give.
10 #***********************************************************************
12 # Test for queries of the form:
14 # SELECT p, max(q) FROM t1;
16 # Demonstration that the value returned for p is on the same row as
20 set testdir [file dirname $argv0]
21 source $testdir/tester.tcl
22 set testprefix minmax4
32 SELECT p, max(q) FROM t1;
37 SELECT p, min(q) FROM t1;
42 INSERT INTO t1 VALUES(1,2);
43 SELECT p, max(q) FROM t1;
48 SELECT p, min(q) FROM t1;
53 INSERT INTO t1 VALUES(3,4);
54 SELECT p, max(q) FROM t1;
59 SELECT p, min(q) FROM t1;
60 SELECT p FROM (SELECT p, min(q) FROM t1);
65 INSERT INTO t1 VALUES(5,0);
66 SELECT p, max(q) FROM t1;
67 SELECT p FROM (SELECT max(q), p FROM t1);
72 SELECT p, min(q) FROM t1;
77 INSERT INTO t1 VALUES(6,1);
78 SELECT p, max(q) FROM t1;
79 SELECT p FROM (SELECT max(q), p FROM t1);
82 do_test minmax4-1.10 {
84 SELECT p, min(q) FROM t1;
87 do_test minmax4-1.11 {
89 INSERT INTO t1 VALUES(7,NULL);
90 SELECT p, max(q) FROM t1;
93 do_test minmax4-1.12 {
95 SELECT p, min(q) FROM t1;
98 do_test minmax4-1.13 {
100 DELETE FROM t1 WHERE q IS NOT NULL;
101 SELECT p, max(q) FROM t1;
104 do_test minmax4-1.14 {
106 SELECT p, min(q) FROM t1;
110 do_test minmax4-2.1 {
112 CREATE TABLE t2(a,b,c);
113 INSERT INTO t2 VALUES
118 SELECT a, max(b), c FROM t2 GROUP BY a ORDER BY a;
121 do_test minmax4-2.2 {
123 SELECT a, min(b), c FROM t2 GROUP BY a ORDER BY a;
126 do_test minmax4-2.3 {
128 SELECT a, min(b), avg(b), count(b), c FROM t2 GROUP BY a ORDER BY a DESC;
130 } {2 3 3.0 1 5 1 1 1.5 2 4}
131 do_test minmax4-2.4 {
133 SELECT a, min(b), max(b), c FROM t2 GROUP BY a ORDER BY a;
136 do_test minmax4-2.5 {
138 SELECT a, max(b), min(b), c FROM t2 GROUP BY a ORDER BY a;
141 do_test minmax4-2.6 {
143 SELECT a, max(b), b, max(c), c FROM t2 GROUP BY a ORDER BY a;
145 } {1 2 1 4 4 2 3 3 5 5}
146 do_test minmax4-2.7 {
148 SELECT a, min(b), b, min(c), c FROM t2 GROUP BY a ORDER BY a;
150 } {1 1 {} 2 2 2 3 3 5 5}
152 #-------------------------------------------------------------------------
154 1 { CREATE INDEX i1 ON t1(a) }
155 2 { CREATE INDEX i1 ON t1(a DESC) }
159 do_execsql_test 3.$tn.0 {
160 CREATE TABLE t1(a, b);
161 INSERT INTO t1 VALUES(NULL, 1);
164 do_execsql_test 3.$tn.1 {
165 SELECT min(a), b FROM t1;
167 do_execsql_test 3.$tn.2 {
168 SELECT min(a), b FROM t1 WHERE a<50;
170 do_execsql_test 3.$tn.3 {
171 INSERT INTO t1 VALUES(2, 2);
173 do_execsql_test 3.$tn.4 {
174 SELECT min(a), b FROM t1;
176 do_execsql_test 3.$tn.5 {
177 SELECT min(a), b FROM t1 WHERE a<50;
181 #-------------------------------------------------------------------------
183 do_execsql_test 4.0 {
184 CREATE TABLE t0 (c0, c1);
185 CREATE INDEX i0 ON t0(c1, c1 + 1 DESC);
186 INSERT INTO t0(c0) VALUES (1);
188 do_execsql_test 4.1 {
189 SELECT MIN(t0.c1), t0.c0 FROM t0 WHERE t0.c1 ISNULL;
192 #-------------------------------------------------------------------------
194 do_execsql_test 5.0 {
195 CREATE TABLE t1 (a, b);
196 INSERT INTO t1 VALUES(123, NULL);
197 CREATE INDEX i1 ON t1(a, b DESC);
199 do_execsql_test 5.1 {
200 SELECT MIN(a) FROM t1 WHERE a=123;
203 #-------------------------------------------------------------------------
204 # Tests for ticket f8a7060ece.
207 do_execsql_test 6.1.0 {
208 CREATE TABLE t1(a, b, c);
209 INSERT INTO t1 VALUES(NULL, 1, 'x');
210 CREATE INDEX i1 ON t1(a);
212 do_execsql_test 6.1.1 {
213 SELECT min(a), b, c FROM t1 WHERE c='x';
215 do_execsql_test 6.1.2 {
216 INSERT INTO t1 VALUES(1, 2, 'y');
218 do_execsql_test 6.1.3 {
219 SELECT min(a), b, c FROM t1 WHERE c='x';
222 do_execsql_test 6.2.0 {
223 CREATE TABLE t0(c0 UNIQUE, c1);
224 INSERT INTO t0(c1) VALUES (0);
225 INSERT INTO t0(c0) VALUES (0);
226 CREATE VIEW v0(c0, c1) AS
227 SELECT t0.c1, t0.c0 FROM t0 WHERE CAST(t0.rowid AS INT) = 1;
229 do_execsql_test 6.2.1 {
230 SELECT c0, c1 FROM v0;
232 do_execsql_test 6.2.2 {
233 SELECT v0.c0, MIN(v0.c1) FROM v0;