Fix an incorrect tcl comment that appeared in many fts5 test files.
[sqlite.git] / test / minmax4.test
blob775fee86bec1b1b1b39fc993fbf75cdc81bffea0
1 # 2012 February 02
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 
17 # the maximum q.
20 set testdir [file dirname $argv0]
21 source $testdir/tester.tcl
22 set testprefix minmax4
24 ifcapable !compound {
25   finish_test
26   return
29 do_test minmax4-1.1 {
30   db eval {
31     CREATE TABLE t1(p,q);
32     SELECT p, max(q) FROM t1;
33   }
34 } {{} {}}
35 do_test minmax4-1.2 {
36   db eval {
37     SELECT p, min(q) FROM t1;
38   }
39 } {{} {}}
40 do_test minmax4-1.3 {
41   db eval {
42     INSERT INTO t1 VALUES(1,2);
43     SELECT p, max(q) FROM t1;
44   }
45 } {1 2}
46 do_test minmax4-1.4 {
47   db eval {
48     SELECT p, min(q) FROM t1;
49   }
50 } {1 2}
51 do_test minmax4-1.5 {
52   db eval {
53     INSERT INTO t1 VALUES(3,4);
54     SELECT p, max(q) FROM t1;
55   }
56 } {3 4}
57 do_test minmax4-1.6 {
58   db eval {
59     SELECT p, min(q) FROM t1;
60     SELECT p FROM (SELECT p, min(q) FROM t1);
61   }
62 } {1 2 1}
63 do_test minmax4-1.7 {
64   db eval {
65     INSERT INTO t1 VALUES(5,0);
66     SELECT p, max(q) FROM t1;
67     SELECT p FROM (SELECT max(q), p FROM t1);
68   }
69 } {3 4 3}
70 do_test minmax4-1.8 {
71   db eval {
72     SELECT p, min(q) FROM t1;
73   }
74 } {5 0}
75 do_test minmax4-1.9 {
76   db eval {
77     INSERT INTO t1 VALUES(6,1);
78     SELECT p, max(q) FROM t1;
79     SELECT p FROM (SELECT max(q), p FROM t1);
80   }
81 } {3 4 3}
82 do_test minmax4-1.10 {
83   db eval {
84     SELECT p, min(q) FROM t1;
85   }
86 } {5 0}
87 do_test minmax4-1.11 {
88   db eval {
89     INSERT INTO t1 VALUES(7,NULL);
90     SELECT p, max(q) FROM t1;
91   }
92 } {3 4}
93 do_test minmax4-1.12 {
94   db eval {
95     SELECT p, min(q) FROM t1;
96   }
97 } {5 0}
98 do_test minmax4-1.13 {
99   db eval {
100     DELETE FROM t1 WHERE q IS NOT NULL;
101     SELECT p, max(q) FROM t1;
102   }
103 } {7 {}}
104 do_test minmax4-1.14 {
105   db eval {
106     SELECT p, min(q) FROM t1;
107   }
108 } {7 {}}
110 do_test minmax4-2.1 {
111   db eval {
112     CREATE TABLE t2(a,b,c);
113     INSERT INTO t2 VALUES
114          (1,null,2),
115          (1,2,3),
116          (1,1,4),
117          (2,3,5);
118     SELECT a, max(b), c FROM t2 GROUP BY a ORDER BY a;
119   }
120 } {1 2 3 2 3 5}
121 do_test minmax4-2.2 {
122   db eval {
123     SELECT a, min(b), c FROM t2 GROUP BY a ORDER BY a;
124   }
125 } {1 1 4 2 3 5}
126 do_test minmax4-2.3 {
127   db eval {
128     SELECT a, min(b), avg(b), count(b), c FROM t2 GROUP BY a ORDER BY a DESC;
129   }
130 } {2 3 3.0 1 5 1 1 1.5 2 4}
131 do_test minmax4-2.4 {
132   db eval {
133     SELECT a, min(b), max(b), c FROM t2 GROUP BY a ORDER BY a;
134   }
135 } {1 1 2 3 2 3 3 5}
136 do_test minmax4-2.5 {
137   db eval {
138     SELECT a, max(b), min(b), c FROM t2 GROUP BY a ORDER BY a;
139   }
140 } {1 2 1 4 2 3 3 5}
141 do_test minmax4-2.6 {
142   db eval {
143     SELECT a, max(b), b, max(c), c FROM t2 GROUP BY a ORDER BY a;
144   }
145 } {1 2 1 4 4 2 3 3 5 5}
146 do_test minmax4-2.7 {
147   db eval {
148     SELECT a, min(b), b, min(c), c FROM t2 GROUP BY a ORDER BY a;
149   }
150 } {1 1 {} 2 2 2 3 3 5 5}
152 #-------------------------------------------------------------------------
153 foreach {tn sql} {
154   1 { CREATE INDEX i1 ON t1(a) }
155   2 { CREATE INDEX i1 ON t1(a DESC) }
156   3 { }
157 } {
158   reset_db
159   do_execsql_test 3.$tn.0 {
160     CREATE TABLE t1(a, b);
161     INSERT INTO t1 VALUES(NULL, 1);
162   }
163   execsql $sql
164   do_execsql_test 3.$tn.1 {
165     SELECT min(a), b FROM t1;
166   } {{} 1}
167   do_execsql_test 3.$tn.2 {
168     SELECT min(a), b FROM t1 WHERE a<50;
169   } {{} {}}
170   do_execsql_test 3.$tn.3 {
171     INSERT INTO t1 VALUES(2, 2);
172   }
173   do_execsql_test 3.$tn.4 {
174     SELECT min(a), b FROM t1;
175   } {2 2}
176   do_execsql_test 3.$tn.5 {
177     SELECT min(a), b FROM t1 WHERE a<50;
178   } {2 2}
181 #-------------------------------------------------------------------------
182 reset_db
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; 
190 } {{} 1}
192 #-------------------------------------------------------------------------
193 reset_db
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;
201 } {123}
203 #-------------------------------------------------------------------------
204 # Tests for ticket f8a7060ece.
206 reset_db
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';
214 } {{} 1 x}
215 do_execsql_test 6.1.2 {
216   INSERT INTO t1 VALUES(1,    2, 'y');
217 } {}
218 do_execsql_test 6.1.3 {
219   SELECT min(a), b, c FROM t1 WHERE c='x';
220 } {{} 1 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;
231 } {0 {}}
232 do_execsql_test 6.2.2 {
233   SELECT v0.c0, MIN(v0.c1) FROM v0;
234 } {0 {}}
236 finish_test