Annotation of embedaddon/sqlite3/test/unordered.test, revision 1.1

1.1     ! misho       1: # 2011 April 9
        !             2: #
        !             3: # The author disclaims copyright to this source code.  In place of
        !             4: # a legal notice, here is a blessing:
        !             5: #
        !             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.
        !             9: #
        !            10: #***********************************************************************
        !            11: # This file implements regression tests for SQLite library.  
        !            12: #
        !            13: 
        !            14: set testdir [file dirname $argv0]
        !            15: source $testdir/tester.tcl
        !            16: 
        !            17: set testprefix unordered
        !            18: 
        !            19: do_execsql_test 1.0 {
        !            20:   CREATE TABLE t1(a, b);
        !            21:   CREATE INDEX i1 ON t1(a);
        !            22:   INSERT INTO t1 VALUES(1, 'xxx');
        !            23:   INSERT INTO t1 SELECT a+1, b FROM t1;
        !            24:   INSERT INTO t1 SELECT a+2, b FROM t1;
        !            25:   INSERT INTO t1 SELECT a+4, b FROM t1;
        !            26:   INSERT INTO t1 SELECT a+8, b FROM t1;
        !            27:   INSERT INTO t1 SELECT a+16, b FROM t1;
        !            28:   INSERT INTO t1 SELECT a+32, b FROM t1;
        !            29:   INSERT INTO t1 SELECT a+64, b FROM t1;
        !            30:   ANALYZE;
        !            31: } {}
        !            32: 
        !            33: foreach idxmode {ordered unordered} {
        !            34:   catchsql { DELETE FROM sqlite_stat2 }
        !            35:   catchsql { DELETE FROM sqlite_stat3 }
        !            36:   if {$idxmode == "unordered"} {
        !            37:     execsql { UPDATE sqlite_stat1 SET stat = stat || ' unordered' }
        !            38:   }
        !            39:   db close
        !            40:   sqlite3 db test.db
        !            41:   foreach {tn sql r(ordered) r(unordered)} {
        !            42:     1   "SELECT * FROM t1 ORDER BY a"
        !            43:         {0 0 0 {SCAN TABLE t1 USING INDEX i1 (~128 rows)}}
        !            44:         {0 0 0 {SCAN TABLE t1 (~128 rows)} 0 0 0 {USE TEMP B-TREE FOR ORDER BY}}
        !            45:     2   "SELECT * FROM t1 WHERE a >?"
        !            46:         {0 0 0 {SEARCH TABLE t1 USING INDEX i1 (a>?) (~32 rows)}}
        !            47:         {0 0 0 {SCAN TABLE t1 (~42 rows)}}
        !            48:     3   "SELECT * FROM t1 WHERE a = ? ORDER BY rowid"
        !            49:         {0 0 0 {SEARCH TABLE t1 USING INDEX i1 (a=?) (~1 rows)}}
        !            50:         {0 0 0 {SEARCH TABLE t1 USING INDEX i1 (a=?) (~1 rows)} 
        !            51:          0 0 0 {USE TEMP B-TREE FOR ORDER BY}}
        !            52:     4   "SELECT max(a) FROM t1"
        !            53:         {0 0 0 {SEARCH TABLE t1 USING COVERING INDEX i1 (~1 rows)}}
        !            54:         {0 0 0 {SEARCH TABLE t1 (~1 rows)}}
        !            55:     5   "SELECT group_concat(b) FROM t1 GROUP BY a"
        !            56:         {0 0 0 {SCAN TABLE t1 USING INDEX i1 (~128 rows)}}
        !            57:         {0 0 0 {SCAN TABLE t1 (~128 rows)} 0 0 0 {USE TEMP B-TREE FOR GROUP BY}}
        !            58: 
        !            59:     6   "SELECT * FROM t1 WHERE a = ?"
        !            60:         {0 0 0 {SEARCH TABLE t1 USING INDEX i1 (a=?) (~1 rows)}}
        !            61:         {0 0 0 {SEARCH TABLE t1 USING INDEX i1 (a=?) (~1 rows)}}
        !            62:     7   "SELECT count(*) FROM t1"
        !            63:         {0 0 0 {SCAN TABLE t1 USING COVERING INDEX i1(~128 rows)}}
        !            64:         {0 0 0 {SCAN TABLE t1 (~128 rows)}}
        !            65:   } {
        !            66:     do_eqp_test 1.$idxmode.$tn $sql $r($idxmode)
        !            67:   }
        !            68: }
        !            69: 
        !            70: finish_test

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>