/ Hex Artifact Content
Login

Artifact 1ba0e2ee25dcd1d55ec770803b19832cffaecbf0b15d376807759ebeed3669b0:


0000: 23 20 32 30 31 34 20 4e 6f 76 65 6d 62 65 72 20  # 2014 November 
0010: 31 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72  1.#.# The author
0020: 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72   disclaims copyr
0030: 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75  ight to this sou
0040: 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c  rce code.  In pl
0050: 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c  ace of.# a legal
0060: 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69 73   notice, here is
0070: 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23   a blessing:.#.#
0080: 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20 67      May you do g
0090: 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c  ood and not evil
00a0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 66  ..#    May you f
00b0: 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73 20  ind forgiveness 
00c0: 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e 64  for yourself and
00d0: 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73 2e   forgive others.
00e0: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73 68  .#    May you sh
00f0: 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76 65  are freely, neve
0100: 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68  r taking more th
0110: 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23  an you give..#.#
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 0a 23 0a 0a 73 65 74 20 74  *******.#..set t
0170: 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64 69 72  estdir [file dir
0180: 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73 6f 75  name $argv0].sou
0190: 72 63 65 20 24 74 65 73 74 64 69 72 2f 74 65 73  rce $testdir/tes
01a0: 74 65 72 2e 74 63 6c 0a 73 65 74 20 74 65 73 74  ter.tcl.set test
01b0: 70 72 65 66 69 78 20 73 63 61 6e 73 74 61 74 75  prefix scanstatu
01c0: 73 0a 0a 69 66 63 61 70 61 62 6c 65 20 21 73 63  s..ifcapable !sc
01d0: 61 6e 73 74 61 74 75 73 20 7b 0a 20 20 66 69 6e  anstatus {.  fin
01e0: 69 73 68 5f 74 65 73 74 0a 20 20 72 65 74 75 72  ish_test.  retur
01f0: 6e 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f  n.}..do_execsql_
0200: 74 65 73 74 20 31 2e 30 20 7b 0a 20 20 43 52 45  test 1.0 {.  CRE
0210: 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20  ATE TABLE t1(a, 
0220: 62 29 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42  b);.  CREATE TAB
0230: 4c 45 20 74 32 28 78 2c 20 79 29 3b 0a 20 20 49  LE t2(x, y);.  I
0240: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
0250: 4c 55 45 53 28 31 2c 20 32 29 3b 0a 20 20 49 4e  LUES(1, 2);.  IN
0260: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
0270: 55 45 53 28 33 2c 20 34 29 3b 0a 20 20 49 4e 53  UES(3, 4);.  INS
0280: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
0290: 45 53 28 27 61 27 2c 20 27 62 27 29 3b 0a 20 20  ES('a', 'b');.  
02a0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
02b0: 41 4c 55 45 53 28 27 63 27 2c 20 27 64 27 29 3b  ALUES('c', 'd');
02c0: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  .  INSERT INTO t
02d0: 32 20 56 41 4c 55 45 53 28 27 65 27 2c 20 27 66  2 VALUES('e', 'f
02e0: 27 29 3b 0a 7d 0a 0a 70 72 6f 63 20 64 6f 5f 73  ');.}..proc do_s
02f0: 63 61 6e 73 74 61 74 75 73 5f 74 65 73 74 20 7b  canstatus_test {
0300: 74 6e 20 72 65 73 7d 20 7b 0a 20 20 73 65 74 20  tn res} {.  set 
0310: 73 74 6d 74 20 5b 64 62 20 76 65 72 73 69 6f 6e  stmt [db version
0320: 20 2d 6c 61 73 74 2d 73 74 6d 74 2d 70 74 72 5d   -last-stmt-ptr]
0330: 0a 20 20 73 65 74 20 69 64 78 20 30 0a 20 20 73  .  set idx 0.  s
0340: 65 74 20 72 65 74 20 5b 6c 69 73 74 5d 0a 20 20  et ret [list].  
0350: 77 68 69 6c 65 20 7b 31 7d 20 7b 0a 20 20 20 20  while {1} {.    
0360: 73 65 74 20 72 20 5b 73 71 6c 69 74 65 33 5f 73  set r [sqlite3_s
0370: 74 6d 74 5f 73 63 61 6e 73 74 61 74 75 73 20 24  tmt_scanstatus $
0380: 73 74 6d 74 20 24 69 64 78 5d 0a 20 20 20 20 69  stmt $idx].    i
0390: 66 20 7b 5b 6c 6c 65 6e 67 74 68 20 24 72 5d 3d  f {[llength $r]=
03a0: 3d 30 7d 20 62 72 65 61 6b 0a 20 20 20 20 6c 61  =0} break.    la
03b0: 70 70 65 6e 64 20 72 65 74 20 7b 2a 7d 24 72 0a  ppend ret {*}$r.
03c0: 20 20 20 20 69 6e 63 72 20 69 64 78 0a 20 20 7d      incr idx.  }
03d0: 0a 0a 20 20 75 70 6c 65 76 65 6c 20 5b 6c 69 73  ..  uplevel [lis
03e0: 74 20 64 6f 5f 74 65 73 74 20 24 74 6e 20 5b 6c  t do_test $tn [l
03f0: 69 73 74 20 73 65 74 20 7b 7d 20 24 72 65 74 5d  ist set {} $ret]
0400: 20 5b 6c 69 73 74 20 7b 2a 7d 24 72 65 73 5d 5d   [list {*}$res]]
0410: 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74  .}..do_execsql_t
0420: 65 73 74 20 31 2e 31 20 7b 20 53 45 4c 45 43 54  est 1.1 { SELECT
0430: 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74   count(*) FROM t
0440: 31 2c 20 74 32 3b 20 7d 20 36 0a 64 6f 5f 73 63  1, t2; } 6.do_sc
0450: 61 6e 73 74 61 74 75 73 5f 74 65 73 74 20 31 2e  anstatus_test 1.
0460: 32 20 7b 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56  2 {.  nLoop 1 nV
0470: 69 73 69 74 20 32 20 6e 45 73 74 20 31 30 34 38  isit 2 nEst 1048
0480: 35 37 36 2e 30 20 7a 4e 61 6d 65 20 74 31 20 7a  576.0 zName t1 z
0490: 45 78 70 6c 61 69 6e 20 7b 53 43 41 4e 20 54 41  Explain {SCAN TA
04a0: 42 4c 45 20 74 31 7d 0a 20 20 6e 4c 6f 6f 70 20  BLE t1}.  nLoop 
04b0: 32 20 6e 56 69 73 69 74 20 36 20 6e 45 73 74 20  2 nVisit 6 nEst 
04c0: 31 30 34 38 35 37 36 2e 30 20 7a 4e 61 6d 65 20  1048576.0 zName 
04d0: 74 32 20 7a 45 78 70 6c 61 69 6e 20 7b 53 43 41  t2 zExplain {SCA
04e0: 4e 20 54 41 42 4c 45 20 74 32 7d 0a 7d 0a 0a 64  N TABLE t2}.}..d
04f0: 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 31  o_execsql_test 1
0500: 2e 33 20 7b 0a 20 20 41 4e 41 4c 59 5a 45 3b 0a  .3 {.  ANALYZE;.
0510: 20 20 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a    SELECT count(*
0520: 29 20 46 52 4f 4d 20 74 31 2c 20 74 32 3b 0a 7d  ) FROM t1, t2;.}
0530: 20 36 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73   6.do_scanstatus
0540: 5f 74 65 73 74 20 31 2e 34 20 7b 0a 20 20 6e 4c  _test 1.4 {.  nL
0550: 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 32 20 6e  oop 1 nVisit 2 n
0560: 45 73 74 20 32 2e 30 20 7a 4e 61 6d 65 20 74 31  Est 2.0 zName t1
0570: 20 7a 45 78 70 6c 61 69 6e 20 7b 53 43 41 4e 20   zExplain {SCAN 
0580: 54 41 42 4c 45 20 74 31 7d 0a 20 20 6e 4c 6f 6f  TABLE t1}.  nLoo
0590: 70 20 32 20 6e 56 69 73 69 74 20 36 20 6e 45 73  p 2 nVisit 6 nEs
05a0: 74 20 33 2e 30 20 7a 4e 61 6d 65 20 74 32 20 7a  t 3.0 zName t2 z
05b0: 45 78 70 6c 61 69 6e 20 7b 53 43 41 4e 20 54 41  Explain {SCAN TA
05c0: 42 4c 45 20 74 32 7d 0a 7d 0a 0a 64 6f 5f 65 78  BLE t2}.}..do_ex
05d0: 65 63 73 71 6c 5f 74 65 73 74 20 31 2e 35 20 7b  ecsql_test 1.5 {
05e0: 20 41 4e 41 4c 59 5a 45 20 7d 0a 64 6f 5f 65 78   ANALYZE }.do_ex
05f0: 65 63 73 71 6c 5f 74 65 73 74 20 31 2e 36 20 7b  ecsql_test 1.6 {
0600: 0a 20 20 53 45 4c 45 43 54 20 63 6f 75 6e 74 28  .  SELECT count(
0610: 2a 29 20 46 52 4f 4d 20 74 31 2c 20 74 32 20 57  *) FROM t1, t2 W
0620: 48 45 52 45 20 74 32 2e 72 6f 77 69 64 3e 31 3b  HERE t2.rowid>1;
0630: 0a 7d 20 34 0a 64 6f 5f 73 63 61 6e 73 74 61 74  .} 4.do_scanstat
0640: 75 73 5f 74 65 73 74 20 31 2e 37 20 7b 0a 20 20  us_test 1.7 {.  
0650: 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 32  nLoop 1 nVisit 2
0660: 20 6e 45 73 74 20 32 2e 30 20 7a 4e 61 6d 65 20   nEst 2.0 zName 
0670: 74 32 20 7a 45 78 70 6c 61 69 6e 20 0a 20 20 7b  t2 zExplain .  {
0680: 53 45 41 52 43 48 20 54 41 42 4c 45 20 74 32 20  SEARCH TABLE t2 
0690: 55 53 49 4e 47 20 49 4e 54 45 47 45 52 20 50 52  USING INTEGER PR
06a0: 49 4d 41 52 59 20 4b 45 59 20 28 72 6f 77 69 64  IMARY KEY (rowid
06b0: 3e 3f 29 7d 0a 20 20 6e 4c 6f 6f 70 20 32 20 6e  >?)}.  nLoop 2 n
06c0: 56 69 73 69 74 20 34 20 6e 45 73 74 20 32 2e 30  Visit 4 nEst 2.0
06d0: 20 7a 4e 61 6d 65 20 74 31 20 7a 45 78 70 6c 61   zName t1 zExpla
06e0: 69 6e 20 7b 53 43 41 4e 20 54 41 42 4c 45 20 74  in {SCAN TABLE t
06f0: 31 7d 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c  1}.}..do_execsql
0700: 5f 74 65 73 74 20 31 2e 38 20 7b 0a 20 20 53 45  _test 1.8 {.  SE
0710: 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52  LECT count(*) FR
0720: 4f 4d 20 74 31 2c 20 74 32 20 57 48 45 52 45 20  OM t1, t2 WHERE 
0730: 74 32 2e 72 6f 77 69 64 3e 31 3b 0a 7d 20 34 0a  t2.rowid>1;.} 4.
0740: 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f 74  .do_scanstatus_t
0750: 65 73 74 20 31 2e 39 20 7b 0a 20 20 6e 4c 6f 6f  est 1.9 {.  nLoo
0760: 70 20 32 20 6e 56 69 73 69 74 20 34 20 6e 45 73  p 2 nVisit 4 nEs
0770: 74 20 32 2e 30 20 7a 4e 61 6d 65 20 74 32 20 7a  t 2.0 zName t2 z
0780: 45 78 70 6c 61 69 6e 20 0a 20 20 7b 53 45 41 52  Explain .  {SEAR
0790: 43 48 20 54 41 42 4c 45 20 74 32 20 55 53 49 4e  CH TABLE t2 USIN
07a0: 47 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52  G INTEGER PRIMAR
07b0: 59 20 4b 45 59 20 28 72 6f 77 69 64 3e 3f 29 7d  Y KEY (rowid>?)}
07c0: 0a 20 20 6e 4c 6f 6f 70 20 34 20 6e 56 69 73 69  .  nLoop 4 nVisi
07d0: 74 20 38 20 6e 45 73 74 20 32 2e 30 20 7a 4e 61  t 8 nEst 2.0 zNa
07e0: 6d 65 20 74 31 20 7a 45 78 70 6c 61 69 6e 20 7b  me t1 zExplain {
07f0: 53 43 41 4e 20 54 41 42 4c 45 20 74 31 7d 0a 7d  SCAN TABLE t1}.}
0800: 0a 0a 64 6f 5f 74 65 73 74 20 31 2e 39 20 7b 0a  ..do_test 1.9 {.
0810: 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 5f 73    sqlite3_stmt_s
0820: 63 61 6e 73 74 61 74 75 73 5f 72 65 73 65 74 20  canstatus_reset 
0830: 5b 64 62 20 76 65 72 73 69 6f 6e 20 2d 6c 61 73  [db version -las
0840: 74 2d 73 74 6d 74 2d 70 74 72 5d 0a 7d 20 7b 7d  t-stmt-ptr].} {}
0850: 0a 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f  ..do_scanstatus_
0860: 74 65 73 74 20 31 2e 31 30 20 7b 0a 20 20 6e 4c  test 1.10 {.  nL
0870: 6f 6f 70 20 30 20 6e 56 69 73 69 74 20 30 20 6e  oop 0 nVisit 0 n
0880: 45 73 74 20 32 2e 30 20 7a 4e 61 6d 65 20 74 32  Est 2.0 zName t2
0890: 20 7a 45 78 70 6c 61 69 6e 20 0a 20 20 7b 53 45   zExplain .  {SE
08a0: 41 52 43 48 20 54 41 42 4c 45 20 74 32 20 55 53  ARCH TABLE t2 US
08b0: 49 4e 47 20 49 4e 54 45 47 45 52 20 50 52 49 4d  ING INTEGER PRIM
08c0: 41 52 59 20 4b 45 59 20 28 72 6f 77 69 64 3e 3f  ARY KEY (rowid>?
08d0: 29 7d 0a 20 20 6e 4c 6f 6f 70 20 30 20 6e 56 69  )}.  nLoop 0 nVi
08e0: 73 69 74 20 30 20 6e 45 73 74 20 32 2e 30 20 7a  sit 0 nEst 2.0 z
08f0: 4e 61 6d 65 20 74 31 20 7a 45 78 70 6c 61 69 6e  Name t1 zExplain
0900: 20 7b 53 43 41 4e 20 54 41 42 4c 45 20 74 31 7d   {SCAN TABLE t1}
0910: 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .}..#-----------
0920: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0930: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0940: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0950: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
0960: 20 54 72 79 20 61 20 66 65 77 20 64 69 66 66 65   Try a few diffe
0970: 72 65 6e 74 20 74 79 70 65 73 20 6f 66 20 73 63  rent types of sc
0980: 61 6e 73 2e 0a 23 0a 72 65 73 65 74 5f 64 62 0a  ans..#.reset_db.
0990: 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
09a0: 32 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20 54  2.1 {.  CREATE T
09b0: 41 42 4c 45 20 78 31 28 69 20 49 4e 54 45 47 45  ABLE x1(i INTEGE
09c0: 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 6a  R PRIMARY KEY, j
09d0: 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  );.  INSERT INTO
09e0: 20 78 31 20 56 41 4c 55 45 53 28 31 2c 20 27 6f   x1 VALUES(1, 'o
09f0: 6e 65 27 29 3b 0a 20 20 49 4e 53 45 52 54 20 49  ne');.  INSERT I
0a00: 4e 54 4f 20 78 31 20 56 41 4c 55 45 53 28 32 2c  NTO x1 VALUES(2,
0a10: 20 27 74 77 6f 27 29 3b 0a 20 20 49 4e 53 45 52   'two');.  INSER
0a20: 54 20 49 4e 54 4f 20 78 31 20 56 41 4c 55 45 53  T INTO x1 VALUES
0a30: 28 33 2c 20 27 74 68 72 65 65 27 29 3b 0a 20 20  (3, 'three');.  
0a40: 49 4e 53 45 52 54 20 49 4e 54 4f 20 78 31 20 56  INSERT INTO x1 V
0a50: 41 4c 55 45 53 28 34 2c 20 27 66 6f 75 72 27 29  ALUES(4, 'four')
0a60: 3b 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45 58  ;.  CREATE INDEX
0a70: 20 78 31 6a 20 4f 4e 20 78 31 28 6a 29 3b 0a 0a   x1j ON x1(j);..
0a80: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0a90: 78 31 20 57 48 45 52 45 20 69 3d 32 3b 0a 7d 20  x1 WHERE i=2;.} 
0aa0: 7b 32 20 74 77 6f 7d 0a 0a 64 6f 5f 73 63 61 6e  {2 two}..do_scan
0ab0: 73 74 61 74 75 73 5f 74 65 73 74 20 32 2e 32 20  status_test 2.2 
0ac0: 7b 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73  {.  nLoop 1 nVis
0ad0: 69 74 20 31 20 6e 45 73 74 20 31 2e 30 20 7a 4e  it 1 nEst 1.0 zN
0ae0: 61 6d 65 20 78 31 20 0a 20 20 7a 45 78 70 6c 61  ame x1 .  zExpla
0af0: 69 6e 20 7b 53 45 41 52 43 48 20 54 41 42 4c 45  in {SEARCH TABLE
0b00: 20 78 31 20 55 53 49 4e 47 20 49 4e 54 45 47 45   x1 USING INTEGE
0b10: 52 20 50 52 49 4d 41 52 59 20 4b 45 59 20 28 72  R PRIMARY KEY (r
0b20: 6f 77 69 64 3d 3f 29 7d 0a 7d 0a 0a 64 6f 5f 65  owid=?)}.}..do_e
0b30: 78 65 63 73 71 6c 5f 74 65 73 74 20 32 2e 33 2e  xecsql_test 2.3.
0b40: 31 20 7b 0a 20 20 53 45 4c 45 43 54 20 2a 20 46  1 {.  SELECT * F
0b50: 52 4f 4d 20 78 31 20 57 48 45 52 45 20 6a 3d 27  ROM x1 WHERE j='
0b60: 74 77 6f 27 0a 7d 20 7b 32 20 74 77 6f 7d 0a 64  two'.} {2 two}.d
0b70: 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f 74 65 73  o_scanstatus_tes
0b80: 74 20 32 2e 33 2e 32 20 7b 0a 20 20 6e 4c 6f 6f  t 2.3.2 {.  nLoo
0b90: 70 20 31 20 6e 56 69 73 69 74 20 31 20 6e 45 73  p 1 nVisit 1 nEs
0ba0: 74 20 31 30 2e 30 20 7a 4e 61 6d 65 20 78 31 6a  t 10.0 zName x1j
0bb0: 20 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b 53 45   .  zExplain {SE
0bc0: 41 52 43 48 20 54 41 42 4c 45 20 78 31 20 55 53  ARCH TABLE x1 US
0bd0: 49 4e 47 20 43 4f 56 45 52 49 4e 47 20 49 4e 44  ING COVERING IND
0be0: 45 58 20 78 31 6a 20 28 6a 3d 3f 29 7d 0a 7d 0a  EX x1j (j=?)}.}.
0bf0: 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74  .do_execsql_test
0c00: 20 32 2e 34 2e 31 20 7b 0a 20 20 53 45 4c 45 43   2.4.1 {.  SELEC
0c10: 54 20 2a 20 46 52 4f 4d 20 78 31 20 57 48 45 52  T * FROM x1 WHER
0c20: 45 20 6a 3c 27 74 77 6f 27 0a 7d 20 7b 34 20 66  E j<'two'.} {4 f
0c30: 6f 75 72 20 31 20 6f 6e 65 20 33 20 74 68 72 65  our 1 one 3 thre
0c40: 65 7d 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73  e}.do_scanstatus
0c50: 5f 74 65 73 74 20 32 2e 34 2e 32 20 7b 0a 20 20  _test 2.4.2 {.  
0c60: 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 33  nLoop 1 nVisit 3
0c70: 20 6e 45 73 74 20 32 36 32 31 34 34 2e 30 20 7a   nEst 262144.0 z
0c80: 4e 61 6d 65 20 78 31 6a 20 0a 20 20 7a 45 78 70  Name x1j .  zExp
0c90: 6c 61 69 6e 20 7b 53 45 41 52 43 48 20 54 41 42  lain {SEARCH TAB
0ca0: 4c 45 20 78 31 20 55 53 49 4e 47 20 43 4f 56 45  LE x1 USING COVE
0cb0: 52 49 4e 47 20 49 4e 44 45 58 20 78 31 6a 20 28  RING INDEX x1j (
0cc0: 6a 3c 3f 29 7d 0a 7d 0a 0a 64 6f 5f 65 78 65 63  j<?)}.}..do_exec
0cd0: 73 71 6c 5f 74 65 73 74 20 32 2e 35 2e 31 20 7b  sql_test 2.5.1 {
0ce0: 0a 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  .  SELECT * FROM
0cf0: 20 78 31 20 57 48 45 52 45 20 6a 3e 3d 27 74 77   x1 WHERE j>='tw
0d00: 6f 27 0a 7d 20 7b 32 20 74 77 6f 7d 0a 64 6f 5f  o'.} {2 two}.do_
0d10: 73 63 61 6e 73 74 61 74 75 73 5f 74 65 73 74 20  scanstatus_test 
0d20: 32 2e 35 2e 32 20 7b 0a 20 20 6e 4c 6f 6f 70 20  2.5.2 {.  nLoop 
0d30: 31 20 6e 56 69 73 69 74 20 31 20 6e 45 73 74 20  1 nVisit 1 nEst 
0d40: 32 36 32 31 34 34 2e 30 20 7a 4e 61 6d 65 20 78  262144.0 zName x
0d50: 31 6a 20 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b  1j .  zExplain {
0d60: 53 45 41 52 43 48 20 54 41 42 4c 45 20 78 31 20  SEARCH TABLE x1 
0d70: 55 53 49 4e 47 20 43 4f 56 45 52 49 4e 47 20 49  USING COVERING I
0d80: 4e 44 45 58 20 78 31 6a 20 28 6a 3e 3f 29 7d 0a  NDEX x1j (j>?)}.
0d90: 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  }..do_execsql_te
0da0: 73 74 20 32 2e 36 2e 31 20 7b 0a 20 20 53 45 4c  st 2.6.1 {.  SEL
0db0: 45 43 54 20 2a 20 46 52 4f 4d 20 78 31 20 57 48  ECT * FROM x1 WH
0dc0: 45 52 45 20 6a 20 42 45 54 57 45 45 4e 20 27 74  ERE j BETWEEN 't
0dd0: 68 72 65 65 27 20 41 4e 44 20 27 74 77 6f 27 0a  hree' AND 'two'.
0de0: 7d 20 7b 33 20 74 68 72 65 65 20 32 20 74 77 6f  } {3 three 2 two
0df0: 7d 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f  }.do_scanstatus_
0e00: 74 65 73 74 20 32 2e 36 2e 32 20 7b 0a 20 20 6e  test 2.6.2 {.  n
0e10: 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 32 20  Loop 1 nVisit 2 
0e20: 6e 45 73 74 20 31 36 33 38 34 2e 30 20 7a 4e 61  nEst 16384.0 zNa
0e30: 6d 65 20 78 31 6a 20 0a 20 20 7a 45 78 70 6c 61  me x1j .  zExpla
0e40: 69 6e 20 7b 53 45 41 52 43 48 20 54 41 42 4c 45  in {SEARCH TABLE
0e50: 20 78 31 20 55 53 49 4e 47 20 43 4f 56 45 52 49   x1 USING COVERI
0e60: 4e 47 20 49 4e 44 45 58 20 78 31 6a 20 28 6a 3e  NG INDEX x1j (j>
0e70: 3f 20 41 4e 44 20 6a 3c 3f 29 7d 0a 7d 0a 0a 64  ? AND j<?)}.}..d
0e80: 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 32  o_execsql_test 2
0e90: 2e 37 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20  .7.1 {.  CREATE 
0ea0: 54 41 42 4c 45 20 78 32 28 69 20 49 4e 54 45 47  TABLE x2(i INTEG
0eb0: 45 52 2c 20 6a 2c 20 6b 29 3b 0a 20 20 49 4e 53  ER, j, k);.  INS
0ec0: 45 52 54 20 49 4e 54 4f 20 78 32 20 53 45 4c 45  ERT INTO x2 SELE
0ed0: 43 54 20 69 2c 20 6a 2c 20 69 20 7c 7c 20 27 20  CT i, j, i || ' 
0ee0: 27 20 7c 7c 20 6a 20 46 52 4f 4d 20 78 31 3b 0a  ' || j FROM x1;.
0ef0: 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 78    CREATE INDEX x
0f00: 32 6a 20 4f 4e 20 78 32 28 6a 29 3b 0a 20 20 43  2j ON x2(j);.  C
0f10: 52 45 41 54 45 20 49 4e 44 45 58 20 78 32 69 6a  REATE INDEX x2ij
0f20: 20 4f 4e 20 78 32 28 69 2c 20 6a 29 3b 0a 20 20   ON x2(i, j);.  
0f30: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 78 32  SELECT * FROM x2
0f40: 20 57 48 45 52 45 20 6a 20 42 45 54 57 45 45 4e   WHERE j BETWEEN
0f50: 20 27 74 68 72 65 65 27 20 41 4e 44 20 27 74 77   'three' AND 'tw
0f60: 6f 27 0a 7d 20 7b 33 20 74 68 72 65 65 20 7b 33  o'.} {3 three {3
0f70: 20 74 68 72 65 65 7d 20 32 20 74 77 6f 20 7b 32   three} 2 two {2
0f80: 20 74 77 6f 7d 7d 0a 0a 64 6f 5f 73 63 61 6e 73   two}}..do_scans
0f90: 74 61 74 75 73 5f 74 65 73 74 20 32 2e 37 2e 32  tatus_test 2.7.2
0fa0: 20 7b 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56 69   {.  nLoop 1 nVi
0fb0: 73 69 74 20 32 20 6e 45 73 74 20 31 36 33 38 34  sit 2 nEst 16384
0fc0: 2e 30 20 7a 4e 61 6d 65 20 78 32 6a 20 0a 20 20  .0 zName x2j .  
0fd0: 7a 45 78 70 6c 61 69 6e 20 7b 53 45 41 52 43 48  zExplain {SEARCH
0fe0: 20 54 41 42 4c 45 20 78 32 20 55 53 49 4e 47 20   TABLE x2 USING 
0ff0: 49 4e 44 45 58 20 78 32 6a 20 28 6a 3e 3f 20 41  INDEX x2j (j>? A
1000: 4e 44 20 6a 3c 3f 29 7d 0a 7d 0a 0a 64 6f 5f 65  ND j<?)}.}..do_e
1010: 78 65 63 73 71 6c 5f 74 65 73 74 20 32 2e 38 2e  xecsql_test 2.8.
1020: 31 20 7b 0a 20 20 53 45 4c 45 43 54 20 2a 20 46  1 {.  SELECT * F
1030: 52 4f 4d 20 78 32 20 57 48 45 52 45 20 69 3d 31  ROM x2 WHERE i=1
1040: 20 41 4e 44 20 6a 3d 27 74 77 6f 27 0a 7d 0a 64   AND j='two'.}.d
1050: 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f 74 65 73  o_scanstatus_tes
1060: 74 20 32 2e 38 2e 32 20 7b 0a 20 20 6e 4c 6f 6f  t 2.8.2 {.  nLoo
1070: 70 20 31 20 6e 56 69 73 69 74 20 30 20 6e 45 73  p 1 nVisit 0 nEs
1080: 74 20 38 2e 30 20 7a 4e 61 6d 65 20 78 32 69 6a  t 8.0 zName x2ij
1090: 20 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b 53 45   .  zExplain {SE
10a0: 41 52 43 48 20 54 41 42 4c 45 20 78 32 20 55 53  ARCH TABLE x2 US
10b0: 49 4e 47 20 49 4e 44 45 58 20 78 32 69 6a 20 28  ING INDEX x2ij (
10c0: 69 3d 3f 20 41 4e 44 20 6a 3d 3f 29 7d 0a 7d 0a  i=? AND j=?)}.}.
10d0: 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74  .do_execsql_test
10e0: 20 32 2e 39 2e 31 20 7b 0a 20 20 53 45 4c 45 43   2.9.1 {.  SELEC
10f0: 54 20 2a 20 46 52 4f 4d 20 78 32 20 57 48 45 52  T * FROM x2 WHER
1100: 45 20 69 3d 35 20 41 4e 44 20 6a 3d 27 74 77 6f  E i=5 AND j='two
1110: 27 0a 7d 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75  '.}.do_scanstatu
1120: 73 5f 74 65 73 74 20 32 2e 39 2e 32 20 7b 0a 20  s_test 2.9.2 {. 
1130: 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74 20   nLoop 1 nVisit 
1140: 30 20 6e 45 73 74 20 38 2e 30 20 7a 4e 61 6d 65  0 nEst 8.0 zName
1150: 20 78 32 69 6a 20 0a 20 20 7a 45 78 70 6c 61 69   x2ij .  zExplai
1160: 6e 20 7b 53 45 41 52 43 48 20 54 41 42 4c 45 20  n {SEARCH TABLE 
1170: 78 32 20 55 53 49 4e 47 20 49 4e 44 45 58 20 78  x2 USING INDEX x
1180: 32 69 6a 20 28 69 3d 3f 20 41 4e 44 20 6a 3d 3f  2ij (i=? AND j=?
1190: 29 7d 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c  )}.}..do_execsql
11a0: 5f 74 65 73 74 20 32 2e 31 30 2e 31 20 7b 0a 20  _test 2.10.1 {. 
11b0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 78   SELECT * FROM x
11c0: 32 20 57 48 45 52 45 20 69 3d 33 20 41 4e 44 20  2 WHERE i=3 AND 
11d0: 6a 3d 27 74 68 72 65 65 27 0a 7d 20 7b 33 20 74  j='three'.} {3 t
11e0: 68 72 65 65 20 7b 33 20 74 68 72 65 65 7d 7d 0a  hree {3 three}}.
11f0: 64 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f 74 65  do_scanstatus_te
1200: 73 74 20 32 2e 31 30 2e 32 20 7b 0a 20 20 6e 4c  st 2.10.2 {.  nL
1210: 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 31 20 6e  oop 1 nVisit 1 n
1220: 45 73 74 20 38 2e 30 20 7a 4e 61 6d 65 20 78 32  Est 8.0 zName x2
1230: 69 6a 20 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b  ij .  zExplain {
1240: 53 45 41 52 43 48 20 54 41 42 4c 45 20 78 32 20  SEARCH TABLE x2 
1250: 55 53 49 4e 47 20 49 4e 44 45 58 20 78 32 69 6a  USING INDEX x2ij
1260: 20 28 69 3d 3f 20 41 4e 44 20 6a 3d 3f 29 7d 0a   (i=? AND j=?)}.
1270: 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }..#------------
1280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1290: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
12b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
12c0: 54 72 79 20 77 69 74 68 20 71 75 65 72 69 65 73  Try with queries
12d0: 20 74 68 61 74 20 75 73 65 20 74 68 65 20 4f 52   that use the OR
12e0: 20 6f 70 74 69 6d 69 7a 61 74 69 6f 6e 2e 0a 23   optimization..#
12f0: 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74  .do_execsql_test
1300: 20 33 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20   3.1 {.  CREATE 
1310: 54 41 42 4c 45 20 61 31 28 61 2c 20 62 2c 20 63  TABLE a1(a, b, c
1320: 2c 20 64 29 3b 0a 20 20 43 52 45 41 54 45 20 49  , d);.  CREATE I
1330: 4e 44 45 58 20 61 31 61 20 4f 4e 20 61 31 28 61  NDEX a1a ON a1(a
1340: 29 3b 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45  );.  CREATE INDE
1350: 58 20 61 31 62 63 20 4f 4e 20 61 31 28 62 2c 20  X a1bc ON a1(b, 
1360: 63 29 3b 0a 0a 20 20 57 49 54 48 20 64 28 78 29  c);..  WITH d(x)
1370: 20 41 53 20 28 53 45 4c 45 43 54 20 31 20 55 4e   AS (SELECT 1 UN
1380: 49 4f 4e 20 41 4c 4c 20 53 45 4c 45 43 54 20 78  ION ALL SELECT x
1390: 2b 31 20 41 53 20 6e 20 46 52 4f 4d 20 64 20 57  +1 AS n FROM d W
13a0: 48 45 52 45 20 6e 3c 3d 31 30 30 29 0a 20 20 49  HERE n<=100).  I
13b0: 4e 53 45 52 54 20 49 4e 54 4f 20 61 31 20 53 45  NSERT INTO a1 SE
13c0: 4c 45 43 54 20 78 2c 20 78 2c 20 78 2c 20 78 20  LECT x, x, x, x 
13d0: 46 52 4f 4d 20 64 3b 0a 7d 0a 0a 64 6f 5f 65 78  FROM d;.}..do_ex
13e0: 65 63 73 71 6c 5f 74 65 73 74 20 33 2e 32 2e 31  ecsql_test 3.2.1
13f0: 20 7b 0a 20 20 53 45 4c 45 43 54 20 64 20 46 52   {.  SELECT d FR
1400: 4f 4d 20 61 31 20 57 48 45 52 45 20 28 61 3d 34  OM a1 WHERE (a=4
1410: 20 4f 52 20 62 3d 31 33 29 0a 7d 20 7b 34 20 31   OR b=13).} {4 1
1420: 33 7d 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73  3}.do_scanstatus
1430: 5f 74 65 73 74 20 33 2e 32 2e 32 20 7b 0a 20 20  _test 3.2.2 {.  
1440: 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 31  nLoop 1 nVisit 1
1450: 20 6e 45 73 74 20 31 30 2e 30 20 7a 4e 61 6d 65   nEst 10.0 zName
1460: 20 61 31 61 20 0a 20 20 7a 45 78 70 6c 61 69 6e   a1a .  zExplain
1470: 20 7b 53 45 41 52 43 48 20 54 41 42 4c 45 20 61   {SEARCH TABLE a
1480: 31 20 55 53 49 4e 47 20 49 4e 44 45 58 20 61 31  1 USING INDEX a1
1490: 61 20 28 61 3d 3f 29 7d 0a 20 20 6e 4c 6f 6f 70  a (a=?)}.  nLoop
14a0: 20 31 20 6e 56 69 73 69 74 20 31 20 6e 45 73 74   1 nVisit 1 nEst
14b0: 20 31 30 2e 30 20 7a 4e 61 6d 65 20 61 31 62 63   10.0 zName a1bc
14c0: 20 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b 53 45   .  zExplain {SE
14d0: 41 52 43 48 20 54 41 42 4c 45 20 61 31 20 55 53  ARCH TABLE a1 US
14e0: 49 4e 47 20 49 4e 44 45 58 20 61 31 62 63 20 28  ING INDEX a1bc (
14f0: 62 3d 3f 29 7d 0a 7d 0a 0a 64 6f 5f 65 78 65 63  b=?)}.}..do_exec
1500: 73 71 6c 5f 74 65 73 74 20 33 2e 32 2e 31 20 7b  sql_test 3.2.1 {
1510: 0a 20 20 53 45 4c 45 43 54 20 63 6f 75 6e 74 28  .  SELECT count(
1520: 2a 29 20 46 52 4f 4d 20 61 31 20 57 48 45 52 45  *) FROM a1 WHERE
1530: 20 28 61 20 42 45 54 57 45 45 4e 20 34 20 41 4e   (a BETWEEN 4 AN
1540: 44 20 31 32 29 20 4f 52 20 28 62 20 42 45 54 57  D 12) OR (b BETW
1550: 45 45 4e 20 34 30 20 41 4e 44 20 36 30 29 0a 7d  EEN 40 AND 60).}
1560: 20 7b 33 30 7d 0a 64 6f 5f 73 63 61 6e 73 74 61   {30}.do_scansta
1570: 74 75 73 5f 74 65 73 74 20 33 2e 32 2e 32 20 7b  tus_test 3.2.2 {
1580: 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69  .  nLoop 1 nVisi
1590: 74 20 39 20 6e 45 73 74 20 31 36 33 38 34 2e 30  t 9 nEst 16384.0
15a0: 20 7a 4e 61 6d 65 20 61 31 61 20 0a 20 20 7a 45   zName a1a .  zE
15b0: 78 70 6c 61 69 6e 20 7b 53 45 41 52 43 48 20 54  xplain {SEARCH T
15c0: 41 42 4c 45 20 61 31 20 55 53 49 4e 47 20 49 4e  ABLE a1 USING IN
15d0: 44 45 58 20 61 31 61 20 28 61 3e 3f 20 41 4e 44  DEX a1a (a>? AND
15e0: 20 61 3c 3f 29 7d 0a 20 20 6e 4c 6f 6f 70 20 31   a<?)}.  nLoop 1
15f0: 20 6e 56 69 73 69 74 20 32 31 20 6e 45 73 74 20   nVisit 21 nEst 
1600: 31 36 33 38 34 2e 30 20 7a 4e 61 6d 65 20 61 31  16384.0 zName a1
1610: 62 63 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b 53  bc.  zExplain {S
1620: 45 41 52 43 48 20 54 41 42 4c 45 20 61 31 20 55  EARCH TABLE a1 U
1630: 53 49 4e 47 20 49 4e 44 45 58 20 61 31 62 63 20  SING INDEX a1bc 
1640: 28 62 3e 3f 20 41 4e 44 20 62 3c 3f 29 7d 0a 7d  (b>? AND b<?)}.}
1650: 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73  ..do_execsql_tes
1660: 74 20 33 2e 33 2e 31 20 7b 0a 20 20 53 45 4c 45  t 3.3.1 {.  SELE
1670: 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d  CT count(*) FROM
1680: 20 61 31 20 41 53 20 78 2c 20 61 31 20 41 53 20   a1 AS x, a1 AS 
1690: 79 20 0a 20 20 57 48 45 52 45 20 28 78 2e 61 20  y .  WHERE (x.a 
16a0: 42 45 54 57 45 45 4e 20 34 20 41 4e 44 20 31 32  BETWEEN 4 AND 12
16b0: 29 20 41 4e 44 20 28 79 2e 62 20 42 45 54 57 45  ) AND (y.b BETWE
16c0: 45 4e 20 31 20 41 4e 44 20 31 30 29 0a 7d 20 7b  EN 1 AND 10).} {
16d0: 39 30 7d 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75  90}.do_scanstatu
16e0: 73 5f 74 65 73 74 20 33 2e 32 2e 32 20 7b 0a 20  s_test 3.2.2 {. 
16f0: 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74 20   nLoop 1 nVisit 
1700: 31 30 20 6e 45 73 74 20 31 36 33 38 34 2e 30 20  10 nEst 16384.0 
1710: 7a 4e 61 6d 65 20 61 31 62 63 20 0a 20 20 7a 45  zName a1bc .  zE
1720: 78 70 6c 61 69 6e 20 7b 53 45 41 52 43 48 20 54  xplain {SEARCH T
1730: 41 42 4c 45 20 61 31 20 41 53 20 79 20 55 53 49  ABLE a1 AS y USI
1740: 4e 47 20 43 4f 56 45 52 49 4e 47 20 49 4e 44 45  NG COVERING INDE
1750: 58 20 61 31 62 63 20 28 62 3e 3f 20 41 4e 44 20  X a1bc (b>? AND 
1760: 62 3c 3f 29 7d 0a 20 20 6e 4c 6f 6f 70 20 31 30  b<?)}.  nLoop 10
1770: 20 6e 56 69 73 69 74 20 39 30 20 6e 45 73 74 20   nVisit 90 nEst 
1780: 31 36 33 38 34 2e 30 20 7a 4e 61 6d 65 20 61 31  16384.0 zName a1
1790: 61 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b 53 45  a.  zExplain {SE
17a0: 41 52 43 48 20 54 41 42 4c 45 20 61 31 20 41 53  ARCH TABLE a1 AS
17b0: 20 78 20 55 53 49 4e 47 20 43 4f 56 45 52 49 4e   x USING COVERIN
17c0: 47 20 49 4e 44 45 58 20 61 31 61 20 28 61 3e 3f  G INDEX a1a (a>?
17d0: 20 41 4e 44 20 61 3c 3f 29 7d 0a 7d 0a 0a 64 6f   AND a<?)}.}..do
17e0: 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 33 2e  _execsql_test 3.
17f0: 34 2e 31 20 7b 0a 20 20 53 45 4c 45 43 54 20 63  4.1 {.  SELECT c
1800: 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 61 31 20  ount(*) FROM a1 
1810: 57 48 45 52 45 20 61 20 49 4e 20 28 31 2c 20 35  WHERE a IN (1, 5
1820: 2c 20 31 30 2c 20 31 35 29 3b 0a 7d 20 7b 34 7d  , 10, 15);.} {4}
1830: 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f 74  .do_scanstatus_t
1840: 65 73 74 20 33 2e 34 2e 32 20 7b 0a 20 20 6e 4c  est 3.4.2 {.  nL
1850: 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 34 20 6e  oop 1 nVisit 4 n
1860: 45 73 74 20 34 30 2e 30 20 7a 4e 61 6d 65 20 61  Est 40.0 zName a
1870: 31 61 20 0a 20 20 7a 45 78 70 6c 61 69 6e 20 7b  1a .  zExplain {
1880: 53 45 41 52 43 48 20 54 41 42 4c 45 20 61 31 20  SEARCH TABLE a1 
1890: 55 53 49 4e 47 20 43 4f 56 45 52 49 4e 47 20 49  USING COVERING I
18a0: 4e 44 45 58 20 61 31 61 20 28 61 3d 3f 29 7d 0a  NDEX a1a (a=?)}.
18b0: 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  }..do_execsql_te
18c0: 73 74 20 33 2e 34 2e 31 20 7b 0a 20 20 53 45 4c  st 3.4.1 {.  SEL
18d0: 45 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f  ECT count(*) FRO
18e0: 4d 20 61 31 20 57 48 45 52 45 20 72 6f 77 69 64  M a1 WHERE rowid
18f0: 20 49 4e 20 28 31 2c 20 35 2c 20 31 30 2c 20 31   IN (1, 5, 10, 1
1900: 35 29 3b 0a 7d 20 7b 34 7d 0a 64 6f 5f 73 63 61  5);.} {4}.do_sca
1910: 6e 73 74 61 74 75 73 5f 74 65 73 74 20 33 2e 34  nstatus_test 3.4
1920: 2e 32 20 7b 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e  .2 {.  nLoop 1 n
1930: 56 69 73 69 74 20 34 20 6e 45 73 74 20 34 2e 30  Visit 4 nEst 4.0
1940: 20 7a 4e 61 6d 65 20 61 31 0a 20 20 7a 45 78 70   zName a1.  zExp
1950: 6c 61 69 6e 20 7b 53 45 41 52 43 48 20 54 41 42  lain {SEARCH TAB
1960: 4c 45 20 61 31 20 55 53 49 4e 47 20 49 4e 54 45  LE a1 USING INTE
1970: 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 20  GER PRIMARY KEY 
1980: 28 72 6f 77 69 64 3d 3f 29 7d 0a 7d 0a 0a 23 2d  (rowid=?)}.}..#-
1990: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
19a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
19b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
19c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
19d0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 65 73 74 20  --------.# Test 
19e0: 74 68 61 74 20 73 63 61 6e 73 74 61 74 75 73 28  that scanstatus(
19f0: 29 20 64 61 74 61 20 69 73 20 6e 6f 74 20 61 76  ) data is not av
1a00: 61 69 6c 61 62 6c 65 20 66 6f 72 20 73 65 61 72  ailable for sear
1a10: 63 68 65 73 20 70 65 72 66 6f 72 6d 65 64 0a 23  ches performed.#
1a20: 20 62 79 20 74 72 69 67 67 65 72 73 2e 0a 23 0a   by triggers..#.
1a30: 23 20 49 74 20 69 73 20 61 76 61 69 6c 61 62 6c  # It is availabl
1a40: 65 20 66 6f 72 20 73 65 61 72 63 68 65 73 20 70  e for searches p
1a50: 65 72 66 6f 72 6d 65 64 20 61 73 20 70 61 72 74  erformed as part
1a60: 20 6f 66 20 46 4b 20 70 72 6f 63 65 73 73 69 6e   of FK processin
1a70: 67 2c 20 62 75 74 20 0a 23 20 6e 6f 74 20 46 4b  g, but .# not FK
1a80: 20 61 63 74 69 6f 6e 20 70 72 6f 63 65 73 73 69   action processi
1a90: 6e 67 2e 0a 23 0a 64 6f 5f 65 78 65 63 73 71 6c  ng..#.do_execsql
1aa0: 5f 74 65 73 74 20 34 2e 30 20 7b 0a 20 20 43 52  _test 4.0 {.  CR
1ab0: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c  EATE TABLE t1(a,
1ac0: 20 62 2c 20 63 29 3b 0a 20 20 43 52 45 41 54 45   b, c);.  CREATE
1ad0: 20 54 41 42 4c 45 20 74 32 28 78 20 50 52 49 4d   TABLE t2(x PRIM
1ae0: 41 52 59 20 4b 45 59 2c 20 79 2c 20 7a 29 3b 0a  ARY KEY, y, z);.
1af0: 20 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52    CREATE TRIGGER
1b00: 20 74 72 31 20 41 46 54 45 52 20 49 4e 53 45 52   tr1 AFTER INSER
1b10: 54 20 4f 4e 20 74 31 20 42 45 47 49 4e 0a 20 20  T ON t1 BEGIN.  
1b20: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1b30: 74 32 20 57 48 45 52 45 20 78 20 42 45 54 57 45  t2 WHERE x BETWE
1b40: 45 4e 20 32 30 20 41 4e 44 20 34 30 3b 0a 20 20  EN 20 AND 40;.  
1b50: 45 4e 44 3b 0a 20 20 57 49 54 48 20 64 28 78 29  END;.  WITH d(x)
1b60: 20 41 53 20 28 53 45 4c 45 43 54 20 31 20 55 4e   AS (SELECT 1 UN
1b70: 49 4f 4e 20 41 4c 4c 20 53 45 4c 45 43 54 20 78  ION ALL SELECT x
1b80: 2b 31 20 41 53 20 6e 20 46 52 4f 4d 20 64 20 57  +1 AS n FROM d W
1b90: 48 45 52 45 20 6e 3c 3d 31 30 30 29 0a 20 20 49  HERE n<=100).  I
1ba0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 53 45  NSERT INTO t2 SE
1bb0: 4c 45 43 54 20 78 2c 20 78 2a 32 2c 20 78 2a 33  LECT x, x*2, x*3
1bc0: 20 46 52 4f 4d 20 64 3b 0a 7d 0a 0a 64 6f 5f 65   FROM d;.}..do_e
1bd0: 78 65 63 73 71 6c 5f 74 65 73 74 20 20 20 20 34  xecsql_test    4
1be0: 2e 31 2e 31 20 7b 20 49 4e 53 45 52 54 20 49 4e  .1.1 { INSERT IN
1bf0: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c 20  TO t1 VALUES(1, 
1c00: 32 2c 20 33 29 3b 20 7d 0a 64 6f 5f 73 63 61 6e  2, 3); }.do_scan
1c10: 73 74 61 74 75 73 5f 74 65 73 74 20 34 2e 31 2e  status_test 4.1.
1c20: 32 20 7b 20 7d 0a 0a 64 6f 5f 65 78 65 63 73 71  2 { }..do_execsq
1c30: 6c 5f 74 65 73 74 20 34 2e 32 20 7b 0a 20 20 43  l_test 4.2 {.  C
1c40: 52 45 41 54 45 20 54 41 42 4c 45 20 70 31 28 78  REATE TABLE p1(x
1c50: 20 50 52 49 4d 41 52 59 20 4b 45 59 29 3b 0a 20   PRIMARY KEY);. 
1c60: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 31 20   INSERT INTO p1 
1c70: 56 41 4c 55 45 53 28 31 29 2c 20 28 32 29 2c 20  VALUES(1), (2), 
1c80: 28 33 29 2c 20 28 34 29 3b 0a 20 20 43 52 45 41  (3), (4);.  CREA
1c90: 54 45 20 54 41 42 4c 45 20 63 31 28 79 20 52 45  TE TABLE c1(y RE
1ca0: 46 45 52 45 4e 43 45 53 20 70 31 29 3b 0a 20 20  FERENCES p1);.  
1cb0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 31 20 56  INSERT INTO c1 V
1cc0: 41 4c 55 45 53 28 31 29 2c 20 28 32 29 2c 20 28  ALUES(1), (2), (
1cd0: 33 29 3b 0a 20 20 50 52 41 47 4d 41 20 66 6f 72  3);.  PRAGMA for
1ce0: 65 69 67 6e 5f 6b 65 79 73 3d 6f 6e 3b 0a 7d 0a  eign_keys=on;.}.
1cf0: 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
1d00: 20 20 20 34 2e 32 2e 31 20 7b 20 44 45 4c 45 54     4.2.1 { DELET
1d10: 45 20 46 52 4f 4d 20 70 31 20 57 48 45 52 45 20  E FROM p1 WHERE 
1d20: 78 3d 34 20 7d 0a 64 6f 5f 73 63 61 6e 73 74 61  x=4 }.do_scansta
1d30: 74 75 73 5f 74 65 73 74 20 34 2e 32 2e 32 20 7b  tus_test 4.2.2 {
1d40: 20 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73   .  nLoop 1 nVis
1d50: 69 74 20 31 20 6e 45 73 74 20 31 2e 30 20 7a 4e  it 1 nEst 1.0 zN
1d60: 61 6d 65 20 73 71 6c 69 74 65 5f 61 75 74 6f 69  ame sqlite_autoi
1d70: 6e 64 65 78 5f 70 31 5f 31 20 0a 20 20 7a 45 78  ndex_p1_1 .  zEx
1d80: 70 6c 61 69 6e 20 7b 53 45 41 52 43 48 20 54 41  plain {SEARCH TA
1d90: 42 4c 45 20 70 31 20 55 53 49 4e 47 20 49 4e 44  BLE p1 USING IND
1da0: 45 58 20 73 71 6c 69 74 65 5f 61 75 74 6f 69 6e  EX sqlite_autoin
1db0: 64 65 78 5f 70 31 5f 31 20 28 78 3d 3f 29 7d 0a  dex_p1_1 (x=?)}.
1dc0: 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69  .  nLoop 1 nVisi
1dd0: 74 20 33 20 6e 45 73 74 20 32 36 32 31 34 34 2e  t 3 nEst 262144.
1de0: 30 20 7a 4e 61 6d 65 20 63 31 20 7a 45 78 70 6c  0 zName c1 zExpl
1df0: 61 69 6e 20 7b 53 43 41 4e 20 54 41 42 4c 45 20  ain {SCAN TABLE 
1e00: 63 31 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d  c1}.}..#--------
1e10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e50: 2d 0a 23 20 46 75 72 74 68 65 72 20 74 65 73 74  -.# Further test
1e60: 73 20 6f 66 20 64 69 66 66 65 72 65 6e 74 20 73  s of different s
1e70: 63 61 6e 20 74 79 70 65 73 2e 0a 23 0a 72 65 73  can types..#.res
1e80: 65 74 5f 64 62 0a 70 72 6f 63 20 74 6f 63 68 61  et_db.proc tocha
1e90: 72 20 7b 69 7d 20 7b 0a 20 20 73 65 74 20 61 6c  r {i} {.  set al
1ea0: 70 68 61 62 65 74 20 7b 61 20 62 20 63 20 64 20  phabet {a b c d 
1eb0: 65 20 66 20 67 20 68 20 69 20 6a 20 6b 20 6c 20  e f g h i j k l 
1ec0: 6d 20 6e 20 6f 20 70 20 71 20 72 20 73 20 74 20  m n o p q r s t 
1ed0: 75 20 76 20 77 20 78 20 79 20 7a 7d 0a 20 20 72  u v w x y z}.  r
1ee0: 65 74 75 72 6e 20 5b 6c 69 6e 64 65 78 20 24 61  eturn [lindex $a
1ef0: 6c 70 68 61 62 65 74 20 5b 65 78 70 72 20 24 69  lphabet [expr $i
1f00: 20 25 20 5b 6c 6c 65 6e 67 74 68 20 24 61 6c 70   % [llength $alp
1f10: 68 61 62 65 74 5d 5d 5d 0a 7d 0a 64 62 20 66 75  habet]]].}.db fu
1f20: 6e 63 20 74 6f 63 68 61 72 20 74 6f 63 68 61 72  nc tochar tochar
1f30: 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74  .do_execsql_test
1f40: 20 35 2e 30 20 7b 0a 20 20 43 52 45 41 54 45 20   5.0 {.  CREATE 
1f50: 54 41 42 4c 45 20 74 31 28 61 20 50 52 49 4d 41  TABLE t1(a PRIMA
1f60: 52 59 20 4b 45 59 2c 20 62 2c 20 63 29 3b 0a 20  RY KEY, b, c);. 
1f70: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
1f80: 56 41 4c 55 45 53 28 30 2c 20 31 2c 20 27 61 27  VALUES(0, 1, 'a'
1f90: 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  );.  INSERT INTO
1fa0: 20 74 31 20 56 41 4c 55 45 53 28 31 2c 20 30 2c   t1 VALUES(1, 0,
1fb0: 20 27 62 27 29 3b 0a 20 20 49 4e 53 45 52 54 20   'b');.  INSERT 
1fc0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 32  INTO t1 VALUES(2
1fd0: 2c 20 31 2c 20 27 63 27 29 3b 0a 20 20 49 4e 53  , 1, 'c');.  INS
1fe0: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
1ff0: 45 53 28 33 2c 20 30 2c 20 27 64 27 29 3b 0a 20  ES(3, 0, 'd');. 
2000: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
2010: 56 41 4c 55 45 53 28 34 2c 20 31 2c 20 27 65 27  VALUES(4, 1, 'e'
2020: 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  );.  INSERT INTO
2030: 20 74 31 20 56 41 4c 55 45 53 28 35 2c 20 30 2c   t1 VALUES(5, 0,
2040: 20 27 61 27 29 3b 0a 20 20 49 4e 53 45 52 54 20   'a');.  INSERT 
2050: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 36  INTO t1 VALUES(6
2060: 2c 20 31 2c 20 27 62 27 29 3b 0a 20 20 49 4e 53  , 1, 'b');.  INS
2070: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
2080: 45 53 28 37 2c 20 30 2c 20 27 63 27 29 3b 0a 20  ES(7, 0, 'c');. 
2090: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
20a0: 56 41 4c 55 45 53 28 38 2c 20 31 2c 20 27 64 27  VALUES(8, 1, 'd'
20b0: 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  );.  INSERT INTO
20c0: 20 74 31 20 56 41 4c 55 45 53 28 39 2c 20 30 2c   t1 VALUES(9, 0,
20d0: 20 27 65 27 29 3b 0a 20 20 43 52 45 41 54 45 20   'e');.  CREATE 
20e0: 49 4e 44 45 58 20 74 31 62 63 20 4f 4e 20 74 31  INDEX t1bc ON t1
20f0: 28 62 2c 20 63 29 3b 0a 0a 20 20 43 52 45 41 54  (b, c);..  CREAT
2100: 45 20 54 41 42 4c 45 20 74 32 28 78 2c 20 79 29  E TABLE t2(x, y)
2110: 3b 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45 58  ;.  CREATE INDEX
2120: 20 74 32 78 79 20 4f 4e 20 74 32 28 78 2c 20 79   t2xy ON t2(x, y
2130: 29 3b 0a 20 20 57 49 54 48 20 64 61 74 61 28 69  );.  WITH data(i
2140: 2c 20 78 2c 20 79 29 20 41 53 20 28 0a 20 20 20  , x, y) AS (.   
2150: 20 53 45 4c 45 43 54 20 30 2c 20 30 2c 20 74 6f   SELECT 0, 0, to
2160: 63 68 61 72 28 30 29 20 0a 20 20 20 20 55 4e 49  char(0) .    UNI
2170: 4f 4e 20 41 4c 4c 0a 20 20 20 20 53 45 4c 45 43  ON ALL.    SELEC
2180: 54 20 69 2b 31 2c 20 28 69 2b 31 29 25 32 2c 20  T i+1, (i+1)%2, 
2190: 74 6f 63 68 61 72 28 69 2b 31 29 20 46 52 4f 4d  tochar(i+1) FROM
21a0: 20 64 61 74 61 20 57 48 45 52 45 20 69 3c 35 30   data WHERE i<50
21b0: 30 0a 20 20 29 20 49 4e 53 45 52 54 20 49 4e 54  0.  ) INSERT INT
21c0: 4f 20 74 32 20 53 45 4c 45 43 54 20 78 2c 20 79  O t2 SELECT x, y
21d0: 20 46 52 4f 4d 20 64 61 74 61 3b 0a 0a 20 20 43   FROM data;..  C
21e0: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 78  REATE TABLE t3(x
21f0: 2c 20 79 29 3b 0a 20 20 49 4e 53 45 52 54 20 49  , y);.  INSERT I
2200: 4e 54 4f 20 74 33 20 53 45 4c 45 43 54 20 2a 20  NTO t3 SELECT * 
2210: 46 52 4f 4d 20 74 32 3b 0a 0a 20 20 41 4e 41 4c  FROM t2;..  ANAL
2220: 59 5a 45 3b 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73  YZE;.}..do_execs
2230: 71 6c 5f 74 65 73 74 20 35 2e 31 2e 31 20 7b 0a  ql_test 5.1.1 {.
2240: 20 20 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a    SELECT count(*
2250: 29 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20  ) FROM t1 WHERE 
2260: 61 20 49 4e 20 28 53 45 4c 45 43 54 20 62 20 46  a IN (SELECT b F
2270: 52 4f 4d 20 74 31 20 41 53 20 69 69 29 0a 7d 20  ROM t1 AS ii).} 
2280: 7b 32 7d 0a 64 6f 5f 73 63 61 6e 73 74 61 74 75  {2}.do_scanstatu
2290: 73 5f 74 65 73 74 20 35 2e 31 2e 32 20 7b 20 0a  s_test 5.1.2 { .
22a0: 20 20 6e 4c 6f 6f 70 20 31 20 6e 56 69 73 69 74    nLoop 1 nVisit
22b0: 20 31 30 20 6e 45 73 74 20 31 30 2e 30 20 7a 4e   10 nEst 10.0 zN
22c0: 61 6d 65 20 74 31 62 63 20 0a 20 20 7a 45 78 70  ame t1bc .  zExp
22d0: 6c 61 69 6e 20 7b 53 43 41 4e 20 54 41 42 4c 45  lain {SCAN TABLE
22e0: 20 74 31 20 41 53 20 69 69 20 55 53 49 4e 47 20   t1 AS ii USING 
22f0: 43 4f 56 45 52 49 4e 47 20 49 4e 44 45 58 20 74  COVERING INDEX t
2300: 31 62 63 7d 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e  1bc}.  nLoop 1 n
2310: 56 69 73 69 74 20 32 20 6e 45 73 74 20 38 2e 30  Visit 2 nEst 8.0
2320: 20 7a 4e 61 6d 65 20 73 71 6c 69 74 65 5f 61 75   zName sqlite_au
2330: 74 6f 69 6e 64 65 78 5f 74 31 5f 31 0a 20 20 7a  toindex_t1_1.  z
2340: 45 78 70 6c 61 69 6e 20 7b 53 45 41 52 43 48 20  Explain {SEARCH 
2350: 54 41 42 4c 45 20 74 31 20 55 53 49 4e 47 20 43  TABLE t1 USING C
2360: 4f 56 45 52 49 4e 47 20 49 4e 44 45 58 20 73 71  OVERING INDEX sq
2370: 6c 69 74 65 5f 61 75 74 6f 69 6e 64 65 78 5f 74  lite_autoindex_t
2380: 31 5f 31 20 28 61 3d 3f 29 7d 0a 7d 0a 0a 64 6f  1_1 (a=?)}.}..do
2390: 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 35 2e  _execsql_test 5.
23a0: 32 2e 31 20 7b 0a 20 20 53 45 4c 45 43 54 20 63  2.1 {.  SELECT c
23b0: 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 31 20  ount(*) FROM t1 
23c0: 57 48 45 52 45 20 61 20 49 4e 20 28 30 2c 20 31  WHERE a IN (0, 1
23d0: 29 0a 7d 20 7b 32 7d 0a 64 6f 5f 73 63 61 6e 73  ).} {2}.do_scans
23e0: 74 61 74 75 73 5f 74 65 73 74 20 35 2e 32 2e 32  tatus_test 5.2.2
23f0: 20 7b 20 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e 56   { .  nLoop 1 nV
2400: 69 73 69 74 20 32 20 6e 45 73 74 20 32 2e 30 20  isit 2 nEst 2.0 
2410: 7a 4e 61 6d 65 20 73 71 6c 69 74 65 5f 61 75 74  zName sqlite_aut
2420: 6f 69 6e 64 65 78 5f 74 31 5f 31 0a 20 20 7a 45  oindex_t1_1.  zE
2430: 78 70 6c 61 69 6e 20 7b 53 45 41 52 43 48 20 54  xplain {SEARCH T
2440: 41 42 4c 45 20 74 31 20 55 53 49 4e 47 20 43 4f  ABLE t1 USING CO
2450: 56 45 52 49 4e 47 20 49 4e 44 45 58 20 73 71 6c  VERING INDEX sql
2460: 69 74 65 5f 61 75 74 6f 69 6e 64 65 78 5f 74 31  ite_autoindex_t1
2470: 5f 31 20 28 61 3d 3f 29 7d 0a 7d 0a 0a 64 6f 5f  _1 (a=?)}.}..do_
2480: 65 71 70 5f 74 65 73 74 20 35 2e 33 2e 31 20 7b  eqp_test 5.3.1 {
2490: 0a 20 20 53 45 4c 45 43 54 20 63 6f 75 6e 74 28  .  SELECT count(
24a0: 2a 29 20 46 52 4f 4d 20 74 32 20 57 48 45 52 45  *) FROM t2 WHERE
24b0: 20 79 20 3d 20 27 6a 27 3b 0a 7d 20 7b 30 20 30   y = 'j';.} {0 0
24c0: 20 30 20 7b 53 45 41 52 43 48 20 54 41 42 4c 45   0 {SEARCH TABLE
24d0: 20 74 32 20 55 53 49 4e 47 20 43 4f 56 45 52 49   t2 USING COVERI
24e0: 4e 47 20 49 4e 44 45 58 20 74 32 78 79 20 28 41  NG INDEX t2xy (A
24f0: 4e 59 28 78 29 20 41 4e 44 20 79 3d 3f 29 7d 7d  NY(x) AND y=?)}}
2500: 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74  .do_execsql_test
2510: 20 35 2e 33 2e 32 20 7b 0a 20 20 53 45 4c 45 43   5.3.2 {.  SELEC
2520: 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20  T count(*) FROM 
2530: 74 32 20 57 48 45 52 45 20 79 20 3d 20 27 6a 27  t2 WHERE y = 'j'
2540: 3b 0a 7d 20 7b 31 39 7d 0a 64 6f 5f 73 63 61 6e  ;.} {19}.do_scan
2550: 73 74 61 74 75 73 5f 74 65 73 74 20 35 2e 33 2e  status_test 5.3.
2560: 33 20 7b 20 0a 20 20 6e 4c 6f 6f 70 20 31 20 6e  3 { .  nLoop 1 n
2570: 56 69 73 69 74 20 31 39 20 6e 45 73 74 20 35 36  Visit 19 nEst 56
2580: 2e 30 20 7a 4e 61 6d 65 20 74 32 78 79 20 7a 45  .0 zName t2xy zE
2590: 78 70 6c 61 69 6e 0a 20 20 7b 53 45 41 52 43 48  xplain.  {SEARCH
25a0: 20 54 41 42 4c 45 20 74 32 20 55 53 49 4e 47 20   TABLE t2 USING 
25b0: 43 4f 56 45 52 49 4e 47 20 49 4e 44 45 58 20 74  COVERING INDEX t
25c0: 32 78 79 20 28 41 4e 59 28 78 29 20 41 4e 44 20  2xy (ANY(x) AND 
25d0: 79 3d 3f 29 7d 0a 7d 0a 0a 64 6f 5f 65 71 70 5f  y=?)}.}..do_eqp_
25e0: 74 65 73 74 20 35 2e 34 2e 31 20 7b 0a 20 20 53  test 5.4.1 {.  S
25f0: 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 20 46  ELECT count(*) F
2600: 52 4f 4d 20 74 31 2c 20 74 32 20 57 48 45 52 45  ROM t1, t2 WHERE
2610: 20 79 20 3d 20 63 3b 0a 7d 20 7b 0a 20 20 30 20   y = c;.} {.  0 
2620: 30 20 30 20 7b 53 43 41 4e 20 54 41 42 4c 45 20  0 0 {SCAN TABLE 
2630: 74 31 20 55 53 49 4e 47 20 43 4f 56 45 52 49 4e  t1 USING COVERIN
2640: 47 20 49 4e 44 45 58 20 74 31 62 63 7d 0a 20 20  G INDEX t1bc}.  
2650: 30 20 31 20 31 20 7b 53 45 41 52 43 48 20 54 41  0 1 1 {SEARCH TA
2660: 42 4c 45 20 74 32 20 55 53 49 4e 47 20 43 4f 56  BLE t2 USING COV
2670: 45 52 49 4e 47 20 49 4e 44 45 58 20 74 32 78 79  ERING INDEX t2xy
2680: 20 28 41 4e 59 28 78 29 20 41 4e 44 20 79 3d 3f   (ANY(x) AND y=?
2690: 29 7d 0a 7d 0a 64 6f 5f 65 78 65 63 73 71 6c 5f  )}.}.do_execsql_
26a0: 74 65 73 74 20 35 2e 34 2e 32 20 7b 0a 20 20 53  test 5.4.2 {.  S
26b0: 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 20 46  ELECT count(*) F
26c0: 52 4f 4d 20 74 31 2c 20 74 32 20 57 48 45 52 45  ROM t1, t2 WHERE
26d0: 20 79 20 3d 20 63 3b 0a 7d 20 7b 32 30 30 7d 0a   y = c;.} {200}.
26e0: 64 6f 5f 73 63 61 6e 73 74 61 74 75 73 5f 74 65  do_scanstatus_te
26f0: 73 74 20 35 2e 34 2e 33 20 7b 20 0a 20 20 6e 4c  st 5.4.3 { .  nL
2700: 6f 6f 70 20 31 20 6e 56 69 73 69 74 20 31 30 20  oop 1 nVisit 10 
2710: 6e 45 73 74 20 31 30 2e 30 20 7a 4e 61 6d 65 20  nEst 10.0 zName 
2720: 74 31 62 63 20 0a 20 20 7a 45 78 70 6c 61 69 6e  t1bc .  zExplain
2730: 20 7b 53 43 41 4e 20 54 41 42 4c 45 20 74 31 20   {SCAN TABLE t1 
2740: 55 53 49 4e 47 20 43 4f 56 45 52 49 4e 47 20 49  USING COVERING I
2750: 4e 44 45 58 20 74 31 62 63 7d 0a 20 20 6e 4c 6f  NDEX t1bc}.  nLo
2760: 6f 70 20 31 30 20 6e 56 69 73 69 74 20 32 30 30  op 10 nVisit 200
2770: 20 6e 45 73 74 20 35 36 2e 30 20 7a 4e 61 6d 65   nEst 56.0 zName
2780: 20 74 32 78 79 20 0a 20 20 7a 45 78 70 6c 61 69   t2xy .  zExplai
2790: 6e 20 7b 53 45 41 52 43 48 20 54 41 42 4c 45 20  n {SEARCH TABLE 
27a0: 74 32 20 55 53 49 4e 47 20 43 4f 56 45 52 49 4e  t2 USING COVERIN
27b0: 47 20 49 4e 44 45 58 20 74 32 78 79 20 28 41 4e  G INDEX t2xy (AN
27c0: 59 28 78 29 20 41 4e 44 20 79 3d 3f 29 7d 0a 7d  Y(x) AND y=?)}.}
27d0: 0a 0a 64 6f 5f 65 71 70 5f 74 65 73 74 20 35 2e  ..do_eqp_test 5.
27e0: 35 2e 31 20 7b 0a 20 20 53 45 4c 45 43 54 20 63  5.1 {.  SELECT c
27f0: 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 31 2c  ount(*) FROM t1,
2800: 20 74 33 20 57 48 45 52 45 20 79 20 3d 20 63 3b   t3 WHERE y = c;
2810: 0a 7d 20 7b 0a 20 20 30 20 30 20 31 20 7b 53 43  .} {.  0 0 1 {SC
2820: 41 4e 20 54 41 42 4c 45 20 74 33 7d 20 0a 20 20  AN TABLE t3} .  
2830: 30 20 31 20 30 20 7b 53 45 41 52 43 48 20 54 41  0 1 0 {SEARCH TA
2840: 42 4c 45 20 74 31 20 55 53 49 4e 47 20 41 55 54  BLE t1 USING AUT
2850: 4f 4d 41 54 49 43 20 43 4f 56 45 52 49 4e 47 20  OMATIC COVERING 
2860: 49 4e 44 45 58 20 28 63 3d 3f 29 7d 0a 7d 0a 64  INDEX (c=?)}.}.d
2870: 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 35  o_execsql_test 5
2880: 2e 35 2e 32 20 7b 0a 20 20 53 45 4c 45 43 54 20  .5.2 {.  SELECT 
2890: 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 31  count(*) FROM t1
28a0: 2c 20 74 33 20 57 48 45 52 45 20 79 20 3d 20 63  , t3 WHERE y = c
28b0: 3b 0a 7d 20 7b 32 30 30 7d 0a 64 6f 5f 73 63 61  ;.} {200}.do_sca
28c0: 6e 73 74 61 74 75 73 5f 74 65 73 74 20 35 2e 35  nstatus_test 5.5
28d0: 2e 33 20 7b 20 0a 20 20 6e 4c 6f 6f 70 20 31 20  .3 { .  nLoop 1 
28e0: 6e 56 69 73 69 74 20 35 30 31 20 6e 45 73 74 20  nVisit 501 nEst 
28f0: 34 38 30 2e 30 20 7a 4e 61 6d 65 20 74 33 20 7a  480.0 zName t3 z
2900: 45 78 70 6c 61 69 6e 20 7b 53 43 41 4e 20 54 41  Explain {SCAN TA
2910: 42 4c 45 20 74 33 7d 0a 20 20 6e 4c 6f 6f 70 20  BLE t3}.  nLoop 
2920: 35 30 31 20 6e 56 69 73 69 74 20 32 30 30 20 6e  501 nVisit 200 n
2930: 45 73 74 20 32 30 2e 30 20 7a 4e 61 6d 65 20 61  Est 20.0 zName a
2940: 75 74 6f 2d 69 6e 64 65 78 20 7a 45 78 70 6c 61  uto-index zExpla
2950: 69 6e 0a 20 20 7b 53 45 41 52 43 48 20 54 41 42  in.  {SEARCH TAB
2960: 4c 45 20 74 31 20 55 53 49 4e 47 20 41 55 54 4f  LE t1 USING AUTO
2970: 4d 41 54 49 43 20 43 4f 56 45 52 49 4e 47 20 49  MATIC COVERING I
2980: 4e 44 45 58 20 28 63 3d 3f 29 7d 0a 7d 0a 0a 23  NDEX (c=?)}.}..#
2990: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
29a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
29b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
29c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
29d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 56 69 72 74  ---------.# Virt
29e0: 75 61 6c 20 74 61 62 6c 65 20 73 63 61 6e 73 0a  ual table scans.
29f0: 23 0a 69 66 63 61 70 61 62 6c 65 20 66 74 73 33  #.ifcapable fts3
2a00: 20 7b 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f   {.  do_execsql_
2a10: 74 65 73 74 20 36 2e 30 20 7b 0a 20 20 20 20 43  test 6.0 {.    C
2a20: 52 45 41 54 45 20 56 49 52 54 55 41 4c 20 54 41  REATE VIRTUAL TA
2a30: 42 4c 45 20 66 74 31 20 55 53 49 4e 47 20 66 74  BLE ft1 USING ft
2a40: 73 34 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  s4;.    INSERT I
2a50: 4e 54 4f 20 66 74 31 20 56 41 4c 55 45 53 28 27  NTO ft1 VALUES('
2a60: 61 20 64 20 63 20 66 20 67 20 68 20 65 20 69 20  a d c f g h e i 
2a70: 66 20 63 27 29 3b 0a 20 20 20 20 49 4e 53 45 52  f c');.    INSER
2a80: 54 20 49 4e 54 4f 20 66 74 31 20 56 41 4c 55 45  T INTO ft1 VALUE
2a90: 53 28 27 67 20 63 20 68 20 62 20 67 20 62 20 66  S('g c h b g b f
2aa0: 20 66 20 66 20 67 27 29 3b 0a 20 20 20 20 49 4e   f f g');.    IN
2ab0: 53 45 52 54 20 49 4e 54 4f 20 66 74 31 20 56 41  SERT INTO ft1 VA
2ac0: 4c 55 45 53 28 27 68 20 68 20 63 20 63 20 68 20  LUES('h h c c h 
2ad0: 66 20 61 20 65 20 64 20 64 27 29 3b 0a 20 20 20  f a e d d');.   
2ae0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 66 74 31   INSERT INTO ft1
2af0: 20 56 41 4c 55 45 53 28 27 65 20 6a 20 69 20 6a   VALUES('e j i j
2b00: 20 69 20 65 20 62 20 63 20 66 20 67 27 29 3b 0a   i e b c f g');.
2b10: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
2b20: 66 74 31 20 56 41 4c 55 45 53 28 27 67 20 66 20  ft1 VALUES('g f 
2b30: 62 20 67 20 6a 20 63 20 68 20 61 20 64 20 66 27  b g j c h a d f'
2b40: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
2b50: 54 4f 20 66 74 31 20 56 41 4c 55 45 53 28 27 6a  TO ft1 VALUES('j
2b60: 20 69 20 61 20 65 20 67 20 66 20 61 20 69 20 61   i a e g f a i a
2b70: 20 63 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54   c');.    INSERT
2b80: 20 49 4e 54 4f 20 66 74 31 20 56 41 4c 55 45 53   INTO ft1 VALUES
2b90: 28 27 66 20 64 20 67 20 67 20 6a 20 6a 20 63 20  ('f d g g j j c 
2ba0: 61 20 68 20 67 27 29 3b 0a 20 20 20 20 49 4e 53  a h g');.    INS
2bb0: 45 52 54 20 49 4e 54 4f 20 66 74 31 20 56 41 4c  ERT INTO ft1 VAL
2bc0: 55 45 53 28 27 62 20 64 20 68 20 61 20 64 20 6a  UES('b d h a d j
2bd0: 20 6a 20 6a 20 62 20 69 27 29 3b 0a 20 20 20 20   j j b i');.    
2be0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 66 74 31 20  INSERT INTO ft1 
2bf0: 56 41 4c 55 45 53 28 27 6a 20 65 20 61 20 62 20  VALUES('j e a b 
2c00: 6a 20 65 20 63 20 62 20 63 20 69 27 29 3b 0a 20  j e c b c i');. 
2c10: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 66     INSERT INTO f
2c20: 74 31 20 56 41 4c 55 45 53 28 27 61 20 64 20 65  t1 VALUES('a d e
2c30: 20 66 20 62 20 6a 20 6a 20 63 20 67 20 64 27 29   f b j j c g d')
2c40: 3b 0a 20 20 7d 0a 20 20 64 6f 5f 65 78 65 63 73  ;.  }.  do_execs
2c50: 71 6c 5f 74 65 73 74 20 36 2e 31 2e 31 20 7b 0a  ql_test 6.1.1 {.
2c60: 20 20 20 20 53 45 4c 45 43 54 20 63 6f 75 6e 74      SELECT count
2c70: 28 2a 29 20 46 52 4f 4d 20 66 74 31 20 57 48 45  (*) FROM ft1 WHE
2c80: 52 45 20 66 74 31 20 4d 41 54 43 48 20 27 64 27  RE ft1 MATCH 'd'
2c90: 0a 20 20 7d 20 7b 36 7d 0a 20 20 64 6f 5f 73 63  .  } {6}.  do_sc
2ca0: 61 6e 73 74 61 74 75 73 5f 74 65 73 74 20 36 2e  anstatus_test 6.
2cb0: 31 2e 32 20 7b 20 0a 20 20 20 20 6e 4c 6f 6f 70  1.2 { .    nLoop
2cc0: 20 31 20 6e 56 69 73 69 74 20 36 20 6e 45 73 74   1 nVisit 6 nEst
2cd0: 20 32 34 2e 30 20 7a 4e 61 6d 65 20 66 74 31 20   24.0 zName ft1 
2ce0: 7a 45 78 70 6c 61 69 6e 20 0a 20 20 20 20 7b 53  zExplain .    {S
2cf0: 43 41 4e 20 54 41 42 4c 45 20 66 74 31 20 56 49  CAN TABLE ft1 VI
2d00: 52 54 55 41 4c 20 54 41 42 4c 45 20 49 4e 44 45  RTUAL TABLE INDE
2d10: 58 20 33 3a 7d 0a 20 20 7d 0a 7d 0a 0a 0a 66 69  X 3:}.  }.}...fi
2d20: 6e 69 73 68 5f 74 65 73 74 0a                    nish_test.