/ Hex Artifact Content
Login

Artifact 7ac6aecd2ab834de2fb81058944a5092f0368f67:


0000: 23 20 32 30 30 36 20 4e 6f 76 65 6d 62 65 72 20  # 2006 November 
0010: 32 33 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  23.#.# The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61  lace of.# a lega
0060: 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69  l notice, here i
0070: 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a  s a blessing:.#.
0080: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20  #    May you do 
0090: 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69  good and not evi
00a0: 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  l..#    May you 
00b0: 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73  find forgiveness
00c0: 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e   for yourself an
00d0: 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73  d forgive others
00e0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73  ..#    May you s
00f0: 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76  hare freely, nev
0100: 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74  er taking more t
0110: 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a  han you give..#.
0120: 23 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 2a 2a 2a 0a 23 20 54 68 69  **********.# Thi
0170: 73 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74  s file implement
0180: 73 20 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73  s regression tes
0190: 74 73 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69  ts for SQLite li
01a0: 62 72 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f  brary.  The.# fo
01b0: 63 75 73 20 6f 66 20 74 68 69 73 20 73 63 72 69  cus of this scri
01c0: 70 74 20 69 73 20 6d 65 61 73 75 72 69 6e 67 20  pt is measuring 
01d0: 65 78 65 63 75 74 69 6e 67 20 73 70 65 65 64 2e  executing speed.
01e0: 0a 23 0a 23 20 24 49 64 3a 20 73 70 65 65 64 31  .#.# $Id: speed1
01f0: 2e 74 65 73 74 2c 76 20 31 2e 37 20 32 30 30 38  .test,v 1.7 2008
0200: 2f 30 37 2f 32 38 20 31 39 3a 33 34 3a 35 34 20  /07/28 19:34:54 
0210: 64 72 68 20 45 78 70 20 24 0a 23 0a 0a 73 71 6c  drh Exp $.#..sql
0220: 69 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a 73 71  ite3_shutdown.sq
0230: 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 73 63 72  lite3_config_scr
0240: 61 74 63 68 20 32 39 30 30 30 20 31 0a 73 71 6c  atch 29000 1.sql
0250: 69 74 65 33 5f 63 6f 6e 66 69 67 5f 6c 6f 6f 6b  ite3_config_look
0260: 61 73 69 64 65 20 31 30 30 30 20 33 30 30 0a 73  aside 1000 300.s
0270: 65 74 20 74 65 73 74 64 69 72 20 5b 66 69 6c 65  et testdir [file
0280: 20 64 69 72 6e 61 6d 65 20 24 61 72 67 76 30 5d   dirname $argv0]
0290: 0a 73 6f 75 72 63 65 20 24 74 65 73 74 64 69 72  .source $testdir
02a0: 2f 74 65 73 74 65 72 2e 74 63 6c 0a 73 70 65 65  /tester.tcl.spee
02b0: 64 5f 74 72 69 61 6c 5f 69 6e 69 74 20 73 70 65  d_trial_init spe
02c0: 65 64 31 0a 0a 23 20 53 65 74 20 61 20 75 6e 69  ed1..# Set a uni
02d0: 66 6f 72 6d 20 72 61 6e 64 6f 6d 20 73 65 65 64  form random seed
02e0: 0a 65 78 70 72 20 73 72 61 6e 64 28 30 29 0a 0a  .expr srand(0)..
02f0: 73 65 74 20 73 71 6c 6f 75 74 20 5b 6f 70 65 6e  set sqlout [open
0300: 20 73 70 65 65 64 31 2e 74 78 74 20 77 5d 0a 70   speed1.txt w].p
0310: 72 6f 63 20 74 72 61 63 65 73 71 6c 20 7b 73 71  roc tracesql {sq
0320: 6c 7d 20 7b 0a 20 20 70 75 74 73 20 24 3a 3a 73  l} {.  puts $::s
0330: 71 6c 6f 75 74 20 24 73 71 6c 5c 3b 0a 7d 0a 23  qlout $sql\;.}.#
0340: 64 62 20 74 72 61 63 65 20 74 72 61 63 65 73 71  db trace tracesq
0350: 6c 0a 0a 23 20 54 68 65 20 6e 75 6d 62 65 72 5f  l..# The number_
0360: 6e 61 6d 65 20 70 72 6f 63 65 64 75 72 65 20 62  name procedure b
0370: 65 6c 6f 77 20 63 6f 6e 76 65 72 74 73 20 69 74  elow converts it
0380: 73 20 61 72 67 6d 65 6e 74 20 28 61 6e 20 69 6e  s argment (an in
0390: 74 65 67 65 72 29 0a 23 20 69 6e 74 6f 20 61 20  teger).# into a 
03a0: 73 74 72 69 6e 67 20 77 68 69 63 68 20 69 73 20  string which is 
03b0: 74 68 65 20 45 6e 67 6c 69 73 68 2d 6c 61 6e 67  the English-lang
03c0: 75 61 67 65 20 6e 61 6d 65 20 66 6f 72 20 74 68  uage name for th
03d0: 61 74 20 6e 75 6d 62 65 72 2e 0a 23 0a 23 20 45  at number..#.# E
03e0: 78 61 6d 70 6c 65 3a 0a 23 0a 23 20 20 20 20 20  xample:.#.#     
03f0: 70 75 74 73 20 5b 6e 75 6d 62 65 72 5f 6e 61 6d  puts [number_nam
0400: 65 20 31 32 33 5d 20 20 20 2d 3e 20 20 22 6f 6e  e 123]   ->  "on
0410: 65 20 68 75 6e 64 72 65 64 20 74 77 65 6e 74 79  e hundred twenty
0420: 20 74 68 72 65 65 22 0a 23 0a 73 65 74 20 6f 6e   three".#.set on
0430: 65 73 20 7b 7a 65 72 6f 20 6f 6e 65 20 74 77 6f  es {zero one two
0440: 20 74 68 72 65 65 20 66 6f 75 72 20 66 69 76 65   three four five
0450: 20 73 69 78 20 73 65 76 65 6e 20 65 69 67 68 74   six seven eight
0460: 20 6e 69 6e 65 0a 20 20 20 20 20 20 20 20 20 20   nine.          
0470: 74 65 6e 20 65 6c 65 76 65 6e 20 74 77 65 6c 76  ten eleven twelv
0480: 65 20 74 68 69 72 74 65 65 6e 20 66 6f 75 72 74  e thirteen fourt
0490: 65 65 6e 20 66 69 66 74 65 65 6e 20 73 69 78 74  een fifteen sixt
04a0: 65 65 6e 20 73 65 76 65 6e 74 65 65 6e 0a 20 20  een seventeen.  
04b0: 20 20 20 20 20 20 20 20 65 69 67 68 74 65 65 6e          eighteen
04c0: 20 6e 69 6e 65 74 65 65 6e 7d 0a 73 65 74 20 74   nineteen}.set t
04d0: 65 6e 73 20 7b 7b 7d 20 74 65 6e 20 74 77 65 6e  ens {{} ten twen
04e0: 74 79 20 74 68 69 72 74 79 20 66 6f 72 74 79 20  ty thirty forty 
04f0: 66 69 66 74 79 20 73 69 78 74 79 20 73 65 76 65  fifty sixty seve
0500: 6e 74 79 20 65 69 67 68 74 79 20 6e 69 6e 65 74  nty eighty ninet
0510: 79 7d 0a 70 72 6f 63 20 6e 75 6d 62 65 72 5f 6e  y}.proc number_n
0520: 61 6d 65 20 7b 6e 7d 20 7b 0a 20 20 69 66 20 7b  ame {n} {.  if {
0530: 24 6e 3e 3d 31 30 30 30 7d 20 7b 0a 20 20 20 20  $n>=1000} {.    
0540: 73 65 74 20 74 78 74 20 22 5b 6e 75 6d 62 65 72  set txt "[number
0550: 5f 6e 61 6d 65 20 5b 65 78 70 72 20 7b 24 6e 2f  _name [expr {$n/
0560: 31 30 30 30 7d 5d 5d 20 74 68 6f 75 73 61 6e 64  1000}]] thousand
0570: 22 0a 20 20 20 20 73 65 74 20 6e 20 5b 65 78 70  ".    set n [exp
0580: 72 20 7b 24 6e 25 31 30 30 30 7d 5d 0a 20 20 7d  r {$n%1000}].  }
0590: 20 65 6c 73 65 20 7b 0a 20 20 20 20 73 65 74 20   else {.    set 
05a0: 74 78 74 20 7b 7d 0a 20 20 7d 0a 20 20 69 66 20  txt {}.  }.  if 
05b0: 7b 24 6e 3e 3d 31 30 30 7d 20 7b 0a 20 20 20 20  {$n>=100} {.    
05c0: 61 70 70 65 6e 64 20 74 78 74 20 22 20 5b 6c 69  append txt " [li
05d0: 6e 64 65 78 20 24 3a 3a 6f 6e 65 73 20 5b 65 78  ndex $::ones [ex
05e0: 70 72 20 7b 24 6e 2f 31 30 30 7d 5d 5d 20 68 75  pr {$n/100}]] hu
05f0: 6e 64 72 65 64 22 0a 20 20 20 20 73 65 74 20 6e  ndred".    set n
0600: 20 5b 65 78 70 72 20 7b 24 6e 25 31 30 30 7d 5d   [expr {$n%100}]
0610: 0a 20 20 7d 0a 20 20 69 66 20 7b 24 6e 3e 3d 32  .  }.  if {$n>=2
0620: 30 7d 20 7b 0a 20 20 20 20 61 70 70 65 6e 64 20  0} {.    append 
0630: 74 78 74 20 22 20 5b 6c 69 6e 64 65 78 20 24 3a  txt " [lindex $:
0640: 3a 74 65 6e 73 20 5b 65 78 70 72 20 7b 24 6e 2f  :tens [expr {$n/
0650: 31 30 7d 5d 5d 22 0a 20 20 20 20 73 65 74 20 6e  10}]]".    set n
0660: 20 5b 65 78 70 72 20 7b 24 6e 25 31 30 7d 5d 0a   [expr {$n%10}].
0670: 20 20 7d 0a 20 20 69 66 20 7b 24 6e 3e 30 7d 20    }.  if {$n>0} 
0680: 7b 0a 20 20 20 20 61 70 70 65 6e 64 20 74 78 74  {.    append txt
0690: 20 22 20 5b 6c 69 6e 64 65 78 20 24 3a 3a 6f 6e   " [lindex $::on
06a0: 65 73 20 24 6e 5d 22 0a 20 20 7d 0a 20 20 73 65  es $n]".  }.  se
06b0: 74 20 74 78 74 20 5b 73 74 72 69 6e 67 20 74 72  t txt [string tr
06c0: 69 6d 20 24 74 78 74 5d 0a 20 20 69 66 20 7b 24  im $txt].  if {$
06d0: 74 78 74 3d 3d 22 22 7d 20 7b 73 65 74 20 74 78  txt==""} {set tx
06e0: 74 20 7a 65 72 6f 7d 0a 20 20 72 65 74 75 72 6e  t zero}.  return
06f0: 20 24 74 78 74 0a 7d 0a 0a 23 20 43 72 65 61 74   $txt.}..# Creat
0700: 65 20 61 20 64 61 74 61 62 61 73 65 20 73 63 68  e a database sch
0710: 65 6d 61 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 73  ema..#.do_test s
0720: 70 65 65 64 31 2d 31 2e 30 20 7b 0a 20 20 65 78  peed1-1.0 {.  ex
0730: 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47  ecsql {.    PRAG
0740: 4d 41 20 70 61 67 65 5f 73 69 7a 65 3d 31 30 32  MA page_size=102
0750: 34 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 63 61  4;.    PRAGMA ca
0760: 63 68 65 5f 73 69 7a 65 3d 38 31 39 32 3b 0a 20  che_size=8192;. 
0770: 20 20 20 50 52 41 47 4d 41 20 6c 6f 63 6b 69 6e     PRAGMA lockin
0780: 67 5f 6d 6f 64 65 3d 45 58 43 4c 55 53 49 56 45  g_mode=EXCLUSIVE
0790: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  ;.    CREATE TAB
07a0: 4c 45 20 74 31 28 61 20 49 4e 54 45 47 45 52 2c  LE t1(a INTEGER,
07b0: 20 62 20 49 4e 54 45 47 45 52 2c 20 63 20 54 45   b INTEGER, c TE
07c0: 58 54 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20  XT);.    CREATE 
07d0: 54 41 42 4c 45 20 74 32 28 61 20 49 4e 54 45 47  TABLE t2(a INTEG
07e0: 45 52 2c 20 62 20 49 4e 54 45 47 45 52 2c 20 63  ER, b INTEGER, c
07f0: 20 54 45 58 54 29 3b 0a 20 20 20 20 43 52 45 41   TEXT);.    CREA
0800: 54 45 20 49 4e 44 45 58 20 69 32 61 20 4f 4e 20  TE INDEX i2a ON 
0810: 74 32 28 61 29 3b 0a 20 20 20 20 43 52 45 41 54  t2(a);.    CREAT
0820: 45 20 49 4e 44 45 58 20 69 32 62 20 4f 4e 20 74  E INDEX i2b ON t
0830: 32 28 62 29 3b 0a 20 20 7d 0a 20 20 65 78 65 63  2(b);.  }.  exec
0840: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
0850: 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69 74   name FROM sqlit
0860: 65 5f 6d 61 73 74 65 72 20 4f 52 44 45 52 20 42  e_master ORDER B
0870: 59 20 31 3b 0a 20 20 7d 0a 7d 20 7b 69 32 61 20  Y 1;.  }.} {i2a 
0880: 69 32 62 20 74 31 20 74 32 7d 0a 0a 0a 23 20 35  i2b t1 t2}...# 5
0890: 30 30 30 30 20 49 4e 53 45 52 54 73 20 6f 6e 20  0000 INSERTs on 
08a0: 61 6e 20 75 6e 69 6e 64 65 78 65 64 20 74 61 62  an unindexed tab
08b0: 6c 65 0a 23 0a 73 65 74 20 73 71 6c 20 7b 7d 0a  le.#.set sql {}.
08c0: 66 6f 72 20 7b 73 65 74 20 69 20 31 7d 20 7b 24  for {set i 1} {$
08d0: 69 3c 3d 35 30 30 30 30 7d 20 7b 69 6e 63 72 20  i<=50000} {incr 
08e0: 69 7d 20 7b 0a 20 20 73 65 74 20 72 20 5b 65 78  i} {.  set r [ex
08f0: 70 72 20 7b 69 6e 74 28 72 61 6e 64 28 29 2a 35  pr {int(rand()*5
0900: 30 30 30 30 30 29 7d 5d 0a 20 20 61 70 70 65 6e  00000)}].  appen
0910: 64 20 73 71 6c 20 22 49 4e 53 45 52 54 20 49 4e  d sql "INSERT IN
0920: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24 69 2c  TO t1 VALUES($i,
0930: 24 72 2c 27 5b 6e 75 6d 62 65 72 5f 6e 61 6d 65  $r,'[number_name
0940: 20 24 72 5d 27 29 3b 5c 6e 22 0a 7d 0a 64 62 20   $r]');\n".}.db 
0950: 65 76 61 6c 20 42 45 47 49 4e 0a 73 70 65 65 64  eval BEGIN.speed
0960: 5f 74 72 69 61 6c 20 73 70 65 65 64 31 2d 69 6e  _trial speed1-in
0970: 73 65 72 74 31 20 35 30 30 30 30 20 72 6f 77 20  sert1 50000 row 
0980: 24 73 71 6c 0a 64 62 20 65 76 61 6c 20 43 4f 4d  $sql.db eval COM
0990: 4d 49 54 0a 0a 23 20 35 30 30 30 30 20 49 4e 53  MIT..# 50000 INS
09a0: 45 52 54 73 20 6f 6e 20 61 6e 20 69 6e 64 65 78  ERTs on an index
09b0: 65 64 20 74 61 62 6c 65 0a 23 0a 73 65 74 20 73  ed table.#.set s
09c0: 71 6c 20 7b 7d 0a 66 6f 72 20 7b 73 65 74 20 69  ql {}.for {set i
09d0: 20 31 7d 20 7b 24 69 3c 3d 35 30 30 30 30 7d 20   1} {$i<=50000} 
09e0: 7b 69 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74  {incr i} {.  set
09f0: 20 72 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61   r [expr {int(ra
0a00: 6e 64 28 29 2a 35 30 30 30 30 30 29 7d 5d 0a 20  nd()*500000)}]. 
0a10: 20 61 70 70 65 6e 64 20 73 71 6c 20 22 49 4e 53   append sql "INS
0a20: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
0a30: 45 53 28 24 69 2c 24 72 2c 27 5b 6e 75 6d 62 65  ES($i,$r,'[numbe
0a40: 72 5f 6e 61 6d 65 20 24 72 5d 27 29 3b 5c 6e 22  r_name $r]');\n"
0a50: 0a 7d 0a 64 62 20 65 76 61 6c 20 42 45 47 49 4e  .}.db eval BEGIN
0a60: 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65  .speed_trial spe
0a70: 65 64 31 2d 69 6e 73 65 72 74 32 20 35 30 30 30  ed1-insert2 5000
0a80: 30 20 72 6f 77 20 24 73 71 6c 0a 64 62 20 65 76  0 row $sql.db ev
0a90: 61 6c 20 43 4f 4d 4d 49 54 0a 0a 0a 0a 23 20 35  al COMMIT....# 5
0aa0: 30 20 53 45 4c 45 43 54 73 20 6f 6e 20 61 6e 20  0 SELECTs on an 
0ab0: 69 6e 74 65 67 65 72 20 63 6f 6d 70 61 72 69 73  integer comparis
0ac0: 6f 6e 2e 20 20 54 68 65 72 65 20 69 73 20 6e 6f  on.  There is no
0ad0: 20 69 6e 64 65 78 20 73 6f 0a 23 20 61 20 66 75   index so.# a fu
0ae0: 6c 6c 20 74 61 62 6c 65 20 73 63 61 6e 20 69 73  ll table scan is
0af0: 20 72 65 71 75 69 72 65 64 2e 0a 23 0a 73 65 74   required..#.set
0b00: 20 73 71 6c 20 7b 7d 0a 66 6f 72 20 7b 73 65 74   sql {}.for {set
0b10: 20 69 20 30 7d 20 7b 24 69 3c 35 30 7d 20 7b 69   i 0} {$i<50} {i
0b20: 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 6c  ncr i} {.  set l
0b30: 77 72 20 5b 65 78 70 72 20 7b 24 69 2a 31 30 30  wr [expr {$i*100
0b40: 7d 5d 0a 20 20 73 65 74 20 75 70 72 20 5b 65 78  }].  set upr [ex
0b50: 70 72 20 7b 28 24 69 2b 31 30 29 2a 31 30 30 7d  pr {($i+10)*100}
0b60: 5d 0a 20 20 61 70 70 65 6e 64 20 73 71 6c 20 22  ].  append sql "
0b70: 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 2c  SELECT count(*),
0b80: 20 61 76 67 28 62 29 20 46 52 4f 4d 20 74 31 20   avg(b) FROM t1 
0b90: 57 48 45 52 45 20 62 3e 3d 24 6c 77 72 20 41 4e  WHERE b>=$lwr AN
0ba0: 44 20 62 3c 24 75 70 72 3b 22 0a 7d 0a 64 62 20  D b<$upr;".}.db 
0bb0: 65 76 61 6c 20 42 45 47 49 4e 0a 73 70 65 65 64  eval BEGIN.speed
0bc0: 5f 74 72 69 61 6c 20 73 70 65 65 64 31 2d 73 65  _trial speed1-se
0bd0: 6c 65 63 74 31 20 5b 65 78 70 72 20 7b 35 30 2a  lect1 [expr {50*
0be0: 35 30 30 30 30 7d 5d 20 72 6f 77 20 24 73 71 6c  50000}] row $sql
0bf0: 0a 64 62 20 65 76 61 6c 20 43 4f 4d 4d 49 54 0a  .db eval COMMIT.
0c00: 0a 23 20 35 30 20 53 45 4c 45 43 54 73 20 6f 6e  .# 50 SELECTs on
0c10: 20 61 6e 20 4c 49 4b 45 20 63 6f 6d 70 61 72 69   an LIKE compari
0c20: 73 6f 6e 2e 20 20 54 68 65 72 65 20 69 73 20 6e  son.  There is n
0c30: 6f 20 69 6e 64 65 78 20 73 6f 20 61 20 66 75 6c  o index so a ful
0c40: 6c 0a 23 20 74 61 62 6c 65 20 73 63 61 6e 20 69  l.# table scan i
0c50: 73 20 72 65 71 75 69 72 65 64 2e 0a 23 0a 73 65  s required..#.se
0c60: 74 20 73 71 6c 20 7b 7d 0a 66 6f 72 20 7b 73 65  t sql {}.for {se
0c70: 74 20 69 20 30 7d 20 7b 24 69 3c 35 30 7d 20 7b  t i 0} {$i<50} {
0c80: 69 6e 63 72 20 69 7d 20 7b 0a 20 20 61 70 70 65  incr i} {.  appe
0c90: 6e 64 20 73 71 6c 20 5c 0a 20 20 20 20 22 53 45  nd sql \.    "SE
0ca0: 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 2c 20 61  LECT count(*), a
0cb0: 76 67 28 62 29 20 46 52 4f 4d 20 74 31 20 57 48  vg(b) FROM t1 WH
0cc0: 45 52 45 20 63 20 4c 49 4b 45 20 27 25 5b 6e 75  ERE c LIKE '%[nu
0cd0: 6d 62 65 72 5f 6e 61 6d 65 20 24 69 5d 25 27 3b  mber_name $i]%';
0ce0: 22 0a 7d 0a 64 62 20 65 76 61 6c 20 42 45 47 49  ".}.db eval BEGI
0cf0: 4e 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70  N.speed_trial sp
0d00: 65 65 64 31 2d 73 65 6c 65 63 74 32 20 5b 65 78  eed1-select2 [ex
0d10: 70 72 20 7b 35 30 2a 35 30 30 30 30 7d 5d 20 72  pr {50*50000}] r
0d20: 6f 77 20 24 73 71 6c 0a 64 62 20 65 76 61 6c 20  ow $sql.db eval 
0d30: 43 4f 4d 4d 49 54 0a 0a 23 20 43 72 65 61 74 65  COMMIT..# Create
0d40: 20 69 6e 64 69 63 65 73 0a 23 0a 64 62 20 65 76   indices.#.db ev
0d50: 61 6c 20 42 45 47 49 4e 0a 73 70 65 65 64 5f 74  al BEGIN.speed_t
0d60: 72 69 61 6c 20 73 70 65 65 64 31 2d 63 72 65 61  rial speed1-crea
0d70: 74 65 69 64 78 20 31 35 30 30 30 30 20 72 6f 77  teidx 150000 row
0d80: 20 7b 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45   {.  CREATE INDE
0d90: 58 20 69 31 61 20 4f 4e 20 74 31 28 61 29 3b 0a  X i1a ON t1(a);.
0da0: 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 69    CREATE INDEX i
0db0: 31 62 20 4f 4e 20 74 31 28 62 29 3b 0a 20 20 43  1b ON t1(b);.  C
0dc0: 52 45 41 54 45 20 49 4e 44 45 58 20 69 31 63 20  REATE INDEX i1c 
0dd0: 4f 4e 20 74 31 28 63 29 3b 0a 7d 0a 64 62 20 65  ON t1(c);.}.db e
0de0: 76 61 6c 20 43 4f 4d 4d 49 54 0a 0a 23 20 35 30  val COMMIT..# 50
0df0: 30 30 20 53 45 4c 45 43 54 73 20 6f 6e 20 61 6e  00 SELECTs on an
0e00: 20 69 6e 74 65 67 65 72 20 63 6f 6d 70 61 72 69   integer compari
0e10: 73 6f 6e 20 77 68 65 72 65 20 74 68 65 20 69 6e  son where the in
0e20: 74 65 67 65 72 20 69 73 0a 23 20 69 6e 64 65 78  teger is.# index
0e30: 65 64 2e 0a 23 0a 73 65 74 20 73 71 6c 20 7b 7d  ed..#.set sql {}
0e40: 0a 66 6f 72 20 7b 73 65 74 20 69 20 30 7d 20 7b  .for {set i 0} {
0e50: 24 69 3c 35 30 30 30 7d 20 7b 69 6e 63 72 20 69  $i<5000} {incr i
0e60: 7d 20 7b 0a 20 20 73 65 74 20 6c 77 72 20 5b 65  } {.  set lwr [e
0e70: 78 70 72 20 7b 24 69 2a 31 30 30 7d 5d 0a 20 20  xpr {$i*100}].  
0e80: 73 65 74 20 75 70 72 20 5b 65 78 70 72 20 7b 28  set upr [expr {(
0e90: 24 69 2b 31 30 29 2a 31 30 30 7d 5d 0a 20 20 61  $i+10)*100}].  a
0ea0: 70 70 65 6e 64 20 73 71 6c 20 22 53 45 4c 45 43  ppend sql "SELEC
0eb0: 54 20 63 6f 75 6e 74 28 2a 29 2c 20 61 76 67 28  T count(*), avg(
0ec0: 62 29 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45  b) FROM t1 WHERE
0ed0: 20 62 3e 3d 24 6c 77 72 20 41 4e 44 20 62 3c 24   b>=$lwr AND b<$
0ee0: 75 70 72 3b 22 0a 7d 0a 64 62 20 65 76 61 6c 20  upr;".}.db eval 
0ef0: 42 45 47 49 4e 0a 73 70 65 65 64 5f 74 72 69 61  BEGIN.speed_tria
0f00: 6c 20 73 70 65 65 64 31 2d 73 65 6c 65 63 74 33  l speed1-select3
0f10: 20 35 30 30 30 20 73 74 6d 74 20 24 73 71 6c 0a   5000 stmt $sql.
0f20: 64 62 20 65 76 61 6c 20 43 4f 4d 4d 49 54 0a 0a  db eval COMMIT..
0f30: 23 20 31 30 30 30 30 30 20 72 61 6e 64 6f 6d 20  # 100000 random 
0f40: 53 45 4c 45 43 54 73 20 61 67 61 69 6e 73 74 20  SELECTs against 
0f50: 72 6f 77 69 64 2e 0a 23 0a 73 65 74 20 73 71 6c  rowid..#.set sql
0f60: 20 7b 7d 0a 66 6f 72 20 7b 73 65 74 20 69 20 31   {}.for {set i 1
0f70: 7d 20 7b 24 69 3c 3d 31 30 30 30 30 30 7d 20 7b  } {$i<=100000} {
0f80: 69 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20  incr i} {.  set 
0f90: 69 64 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61  id [expr {int(ra
0fa0: 6e 64 28 29 2a 35 30 30 30 30 29 2b 31 7d 5d 0a  nd()*50000)+1}].
0fb0: 20 20 61 70 70 65 6e 64 20 73 71 6c 20 22 53 45    append sql "SE
0fc0: 4c 45 43 54 20 63 20 46 52 4f 4d 20 74 31 20 57  LECT c FROM t1 W
0fd0: 48 45 52 45 20 72 6f 77 69 64 3d 24 69 64 3b 22  HERE rowid=$id;"
0fe0: 0a 7d 0a 64 62 20 65 76 61 6c 20 42 45 47 49 4e  .}.db eval BEGIN
0ff0: 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65  .speed_trial spe
1000: 65 64 31 2d 73 65 6c 65 63 74 34 20 31 30 30 30  ed1-select4 1000
1010: 30 30 20 72 6f 77 20 24 73 71 6c 0a 64 62 20 65  00 row $sql.db e
1020: 76 61 6c 20 43 4f 4d 4d 49 54 0a 0a 23 20 31 30  val COMMIT..# 10
1030: 30 30 30 30 20 72 61 6e 64 6f 6d 20 53 45 4c 45  0000 random SELE
1040: 43 54 73 20 61 67 61 69 6e 73 74 20 61 20 75 6e  CTs against a un
1050: 69 71 75 65 20 69 6e 64 65 78 65 64 20 63 6f 6c  ique indexed col
1060: 75 6d 6e 2e 0a 23 0a 73 65 74 20 73 71 6c 20 7b  umn..#.set sql {
1070: 7d 0a 66 6f 72 20 7b 73 65 74 20 69 20 31 7d 20  }.for {set i 1} 
1080: 7b 24 69 3c 3d 31 30 30 30 30 30 7d 20 7b 69 6e  {$i<=100000} {in
1090: 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 69 64  cr i} {.  set id
10a0: 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61 6e 64   [expr {int(rand
10b0: 28 29 2a 35 30 30 30 30 29 2b 31 7d 5d 0a 20 20  ()*50000)+1}].  
10c0: 61 70 70 65 6e 64 20 73 71 6c 20 22 53 45 4c 45  append sql "SELE
10d0: 43 54 20 63 20 46 52 4f 4d 20 74 31 20 57 48 45  CT c FROM t1 WHE
10e0: 52 45 20 61 3d 24 69 64 3b 22 0a 7d 0a 64 62 20  RE a=$id;".}.db 
10f0: 65 76 61 6c 20 42 45 47 49 4e 0a 73 70 65 65 64  eval BEGIN.speed
1100: 5f 74 72 69 61 6c 20 73 70 65 65 64 31 2d 73 65  _trial speed1-se
1110: 6c 65 63 74 35 20 31 30 30 30 30 30 20 72 6f 77  lect5 100000 row
1120: 20 24 73 71 6c 0a 64 62 20 65 76 61 6c 20 43 4f   $sql.db eval CO
1130: 4d 4d 49 54 0a 0a 23 20 35 30 30 30 30 20 72 61  MMIT..# 50000 ra
1140: 6e 64 6f 6d 20 53 45 4c 45 43 54 73 20 61 67 61  ndom SELECTs aga
1150: 69 6e 73 74 20 61 6e 20 69 6e 64 65 78 65 64 20  inst an indexed 
1160: 63 6f 6c 75 6d 6e 20 74 65 78 74 20 63 6f 6c 75  column text colu
1170: 6d 6e 0a 23 0a 73 65 74 20 73 71 6c 20 7b 7d 0a  mn.#.set sql {}.
1180: 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43 54 20  db eval {SELECT 
1190: 63 20 46 52 4f 4d 20 74 31 20 4f 52 44 45 52 20  c FROM t1 ORDER 
11a0: 42 59 20 72 61 6e 64 6f 6d 28 29 20 4c 49 4d 49  BY random() LIMI
11b0: 54 20 35 30 30 30 30 7d 20 7b 0a 20 20 61 70 70  T 50000} {.  app
11c0: 65 6e 64 20 73 71 6c 20 22 53 45 4c 45 43 54 20  end sql "SELECT 
11d0: 63 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20  c FROM t1 WHERE 
11e0: 63 3d 27 24 63 27 3b 22 0a 7d 0a 64 62 20 65 76  c='$c';".}.db ev
11f0: 61 6c 20 42 45 47 49 4e 0a 73 70 65 65 64 5f 74  al BEGIN.speed_t
1200: 72 69 61 6c 20 73 70 65 65 64 31 2d 73 65 6c 65  rial speed1-sele
1210: 63 74 36 20 35 30 30 30 30 20 72 6f 77 20 24 73  ct6 50000 row $s
1220: 71 6c 0a 64 62 20 65 76 61 6c 20 43 4f 4d 4d 49  ql.db eval COMMI
1230: 54 0a 0a 0a 23 20 56 61 63 75 75 6d 0a 73 70 65  T...# Vacuum.spe
1240: 65 64 5f 74 72 69 61 6c 20 73 70 65 65 64 31 2d  ed_trial speed1-
1250: 76 61 63 75 75 6d 20 31 30 30 30 30 30 20 72 6f  vacuum 100000 ro
1260: 77 20 56 41 43 55 55 4d 0a 0a 23 20 35 30 30 30  w VACUUM..# 5000
1270: 20 75 70 64 61 74 65 73 20 6f 66 20 72 61 6e 67   updates of rang
1280: 65 73 20 77 68 65 72 65 20 74 68 65 20 66 69 65  es where the fie
1290: 6c 64 20 62 65 69 6e 67 20 63 6f 6d 70 61 72 65  ld being compare
12a0: 64 20 69 73 20 69 6e 64 65 78 65 64 2e 0a 23 0a  d is indexed..#.
12b0: 73 65 74 20 73 71 6c 20 7b 7d 0a 66 6f 72 20 7b  set sql {}.for {
12c0: 73 65 74 20 69 20 30 7d 20 7b 24 69 3c 35 30 30  set i 0} {$i<500
12d0: 30 7d 20 7b 69 6e 63 72 20 69 7d 20 7b 0a 20 20  0} {incr i} {.  
12e0: 73 65 74 20 6c 77 72 20 5b 65 78 70 72 20 7b 24  set lwr [expr {$
12f0: 69 2a 32 7d 5d 0a 20 20 73 65 74 20 75 70 72 20  i*2}].  set upr 
1300: 5b 65 78 70 72 20 7b 28 24 69 2b 31 29 2a 32 7d  [expr {($i+1)*2}
1310: 5d 0a 20 20 61 70 70 65 6e 64 20 73 71 6c 20 22  ].  append sql "
1320: 55 50 44 41 54 45 20 74 31 20 53 45 54 20 62 3d  UPDATE t1 SET b=
1330: 62 2a 32 20 57 48 45 52 45 20 61 3e 3d 24 6c 77  b*2 WHERE a>=$lw
1340: 72 20 41 4e 44 20 61 3c 24 75 70 72 3b 22 0a 7d  r AND a<$upr;".}
1350: 0a 64 62 20 65 76 61 6c 20 42 45 47 49 4e 0a 73  .db eval BEGIN.s
1360: 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65 65 64  peed_trial speed
1370: 31 2d 75 70 64 61 74 65 31 20 35 30 30 30 20 73  1-update1 5000 s
1380: 74 6d 74 20 24 73 71 6c 0a 64 62 20 65 76 61 6c  tmt $sql.db eval
1390: 20 43 4f 4d 4d 49 54 0a 0a 23 20 35 30 30 30 30   COMMIT..# 50000
13a0: 20 73 69 6e 67 6c 65 2d 72 6f 77 20 75 70 64 61   single-row upda
13b0: 74 65 73 2e 20 20 41 6e 20 69 6e 64 65 78 20 69  tes.  An index i
13c0: 73 20 75 73 65 64 20 74 6f 20 66 69 6e 64 20 74  s used to find t
13d0: 68 65 20 72 6f 77 20 71 75 69 63 6b 6c 79 2e 0a  he row quickly..
13e0: 23 0a 73 65 74 20 73 71 6c 20 7b 7d 0a 66 6f 72  #.set sql {}.for
13f0: 20 7b 73 65 74 20 69 20 30 7d 20 7b 24 69 3c 35   {set i 0} {$i<5
1400: 30 30 30 30 7d 20 7b 69 6e 63 72 20 69 7d 20 7b  0000} {incr i} {
1410: 0a 20 20 73 65 74 20 72 20 5b 65 78 70 72 20 7b  .  set r [expr {
1420: 69 6e 74 28 72 61 6e 64 28 29 2a 35 30 30 30 30  int(rand()*50000
1430: 30 29 7d 5d 0a 20 20 61 70 70 65 6e 64 20 73 71  0)}].  append sq
1440: 6c 20 22 55 50 44 41 54 45 20 74 31 20 53 45 54  l "UPDATE t1 SET
1450: 20 62 3d 24 72 20 57 48 45 52 45 20 61 3d 24 69   b=$r WHERE a=$i
1460: 3b 22 0a 7d 0a 64 62 20 65 76 61 6c 20 42 45 47  ;".}.db eval BEG
1470: 49 4e 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73  IN.speed_trial s
1480: 70 65 65 64 31 2d 75 70 64 61 74 65 32 20 35 30  peed1-update2 50
1490: 30 30 30 20 72 6f 77 20 24 73 71 6c 0a 64 62 20  000 row $sql.db 
14a0: 65 76 61 6c 20 43 4f 4d 4d 49 54 0a 0a 23 20 31  eval COMMIT..# 1
14b0: 20 62 69 67 20 74 65 78 74 20 75 70 64 61 74 65   big text update
14c0: 20 74 68 61 74 20 74 6f 75 63 68 65 73 20 65 76   that touches ev
14d0: 65 72 79 20 72 6f 77 20 69 6e 20 74 68 65 20 74  ery row in the t
14e0: 61 62 6c 65 2e 0a 23 0a 73 70 65 65 64 5f 74 72  able..#.speed_tr
14f0: 69 61 6c 20 73 70 65 65 64 31 2d 75 70 64 61 74  ial speed1-updat
1500: 65 33 20 35 30 30 30 30 20 72 6f 77 20 7b 0a 20  e3 50000 row {. 
1510: 20 55 50 44 41 54 45 20 74 31 20 53 45 54 20 63   UPDATE t1 SET c
1520: 3d 61 3b 0a 7d 0a 0a 23 20 4d 61 6e 79 20 69 6e  =a;.}..# Many in
1530: 64 69 76 69 64 75 61 6c 20 74 65 78 74 20 75 70  dividual text up
1540: 64 61 74 65 73 2e 20 20 45 61 63 68 20 72 6f 77  dates.  Each row
1550: 20 69 6e 20 74 68 65 20 74 61 62 6c 65 20 69 73   in the table is
1560: 0a 23 20 74 6f 75 63 68 65 64 20 74 68 72 6f 75  .# touched throu
1570: 67 68 20 61 6e 20 69 6e 64 65 78 2e 0a 23 0a 73  gh an index..#.s
1580: 65 74 20 73 71 6c 20 7b 7d 0a 66 6f 72 20 7b 73  et sql {}.for {s
1590: 65 74 20 69 20 31 7d 20 7b 24 69 3c 3d 35 30 30  et i 1} {$i<=500
15a0: 30 30 7d 20 7b 69 6e 63 72 20 69 7d 20 7b 0a 20  00} {incr i} {. 
15b0: 20 73 65 74 20 72 20 5b 65 78 70 72 20 7b 69 6e   set r [expr {in
15c0: 74 28 72 61 6e 64 28 29 2a 35 30 30 30 30 30 29  t(rand()*500000)
15d0: 7d 5d 0a 20 20 61 70 70 65 6e 64 20 73 71 6c 20  }].  append sql 
15e0: 22 55 50 44 41 54 45 20 74 31 20 53 45 54 20 63  "UPDATE t1 SET c
15f0: 3d 27 5b 6e 75 6d 62 65 72 5f 6e 61 6d 65 20 24  ='[number_name $
1600: 72 5d 27 20 57 48 45 52 45 20 61 3d 24 69 3b 22  r]' WHERE a=$i;"
1610: 0a 7d 0a 64 62 20 65 76 61 6c 20 42 45 47 49 4e  .}.db eval BEGIN
1620: 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65  .speed_trial spe
1630: 65 64 31 2d 75 70 64 61 74 65 34 20 35 30 30 30  ed1-update4 5000
1640: 30 20 72 6f 77 20 24 73 71 6c 0a 64 62 20 65 76  0 row $sql.db ev
1650: 61 6c 20 43 4f 4d 4d 49 54 0a 0a 23 20 44 65 6c  al COMMIT..# Del
1660: 65 74 65 20 61 6c 6c 20 63 6f 6e 74 65 6e 74 20  ete all content 
1670: 69 6e 20 61 20 74 61 62 6c 65 2e 0a 23 0a 73 70  in a table..#.sp
1680: 65 65 64 5f 74 72 69 61 6c 20 73 70 65 65 64 31  eed_trial speed1
1690: 2d 64 65 6c 65 74 65 31 20 35 30 30 30 30 20 72  -delete1 50000 r
16a0: 6f 77 20 7b 44 45 4c 45 54 45 20 46 52 4f 4d 20  ow {DELETE FROM 
16b0: 74 31 7d 0a 0a 23 20 43 6f 70 79 20 6f 6e 65 20  t1}..# Copy one 
16c0: 74 61 62 6c 65 20 69 6e 74 6f 20 61 6e 6f 74 68  table into anoth
16d0: 65 72 0a 23 0a 73 70 65 65 64 5f 74 72 69 61 6c  er.#.speed_trial
16e0: 20 73 70 65 65 64 31 2d 63 6f 70 79 31 20 35 30   speed1-copy1 50
16f0: 30 30 30 20 72 6f 77 20 7b 49 4e 53 45 52 54 20  000 row {INSERT 
1700: 49 4e 54 4f 20 74 31 20 53 45 4c 45 43 54 20 2a  INTO t1 SELECT *
1710: 20 46 52 4f 4d 20 74 32 7d 0a 0a 23 20 44 65 6c   FROM t2}..# Del
1720: 65 74 65 20 61 6c 6c 20 63 6f 6e 74 65 6e 74 20  ete all content 
1730: 69 6e 20 61 20 74 61 62 6c 65 2c 20 6f 6e 65 20  in a table, one 
1740: 72 6f 77 20 61 74 20 61 20 74 69 6d 65 2e 0a 23  row at a time..#
1750: 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65  .speed_trial spe
1760: 65 64 31 2d 64 65 6c 65 74 65 32 20 35 30 30 30  ed1-delete2 5000
1770: 30 20 72 6f 77 20 7b 44 45 4c 45 54 45 20 46 52  0 row {DELETE FR
1780: 4f 4d 20 74 31 20 57 48 45 52 45 20 31 7d 0a 0a  OM t1 WHERE 1}..
1790: 23 20 52 65 66 69 6c 6c 20 74 68 65 20 74 61 62  # Refill the tab
17a0: 6c 65 20 79 65 74 20 61 67 61 69 6e 0a 23 0a 73  le yet again.#.s
17b0: 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65 65 64  peed_trial speed
17c0: 31 2d 63 6f 70 79 32 20 35 30 30 30 30 20 72 6f  1-copy2 50000 ro
17d0: 77 20 7b 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  w {INSERT INTO t
17e0: 31 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  1 SELECT * FROM 
17f0: 74 32 7d 0a 0a 23 20 44 72 6f 70 20 74 68 65 20  t2}..# Drop the 
1800: 74 61 62 6c 65 20 61 6e 64 20 72 65 63 72 65 61  table and recrea
1810: 74 65 20 69 74 20 77 69 74 68 6f 75 74 20 69 74  te it without it
1820: 73 20 69 6e 64 69 63 65 73 2e 0a 23 0a 64 62 20  s indices..#.db 
1830: 65 76 61 6c 20 42 45 47 49 4e 0a 73 70 65 65 64  eval BEGIN.speed
1840: 5f 74 72 69 61 6c 20 73 70 65 65 64 31 2d 64 72  _trial speed1-dr
1850: 6f 70 31 20 35 30 30 30 30 20 72 6f 77 20 7b 0a  op1 50000 row {.
1860: 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 74 31     DROP TABLE t1
1870: 3b 0a 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  ;.   CREATE TABL
1880: 45 20 74 31 28 61 20 49 4e 54 45 47 45 52 2c 20  E t1(a INTEGER, 
1890: 62 20 49 4e 54 45 47 45 52 2c 20 63 20 54 45 58  b INTEGER, c TEX
18a0: 54 29 3b 0a 7d 0a 64 62 20 65 76 61 6c 20 43 4f  T);.}.db eval CO
18b0: 4d 4d 49 54 0a 0a 23 20 52 65 66 69 6c 6c 20 74  MMIT..# Refill t
18c0: 68 65 20 74 61 62 6c 65 20 79 65 74 20 61 67 61  he table yet aga
18d0: 69 6e 2e 20 20 54 68 69 73 20 63 6f 70 79 20 73  in.  This copy s
18e0: 68 6f 75 6c 64 20 62 65 20 66 61 73 74 65 72 20  hould be faster 
18f0: 62 65 63 61 75 73 65 0a 23 20 74 68 65 72 65 20  because.# there 
1900: 61 72 65 20 6e 6f 20 69 6e 64 69 63 65 73 20 74  are no indices t
1910: 6f 20 64 65 61 6c 20 77 69 74 68 2e 0a 23 0a 73  o deal with..#.s
1920: 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65 65 64  peed_trial speed
1930: 31 2d 63 6f 70 79 33 20 35 30 30 30 30 20 72 6f  1-copy3 50000 ro
1940: 77 20 7b 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  w {INSERT INTO t
1950: 31 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  1 SELECT * FROM 
1960: 74 32 7d 0a 0a 23 20 53 65 6c 65 63 74 20 32 30  t2}..# Select 20
1970: 30 30 30 20 72 6f 77 73 20 66 72 6f 6d 20 74 68  000 rows from th
1980: 65 20 74 61 62 6c 65 20 61 74 20 72 61 6e 64 6f  e table at rando
1990: 6d 2e 0a 23 0a 73 70 65 65 64 5f 74 72 69 61 6c  m..#.speed_trial
19a0: 20 73 70 65 65 64 31 2d 72 61 6e 64 6f 6d 31 20   speed1-random1 
19b0: 35 30 30 30 30 20 72 6f 77 20 7b 0a 20 20 53 45  50000 row {.  SE
19c0: 4c 45 43 54 20 72 6f 77 69 64 20 46 52 4f 4d 20  LECT rowid FROM 
19d0: 74 31 20 4f 52 44 45 52 20 42 59 20 72 61 6e 64  t1 ORDER BY rand
19e0: 6f 6d 28 29 20 4c 49 4d 49 54 20 32 30 30 30 30  om() LIMIT 20000
19f0: 0a 7d 0a 0a 23 20 44 65 6c 65 74 65 20 32 30 30  .}..# Delete 200
1a00: 30 30 20 72 61 6e 64 6f 6d 20 72 6f 77 73 20 66  00 random rows f
1a10: 72 6f 6d 20 74 68 65 20 74 61 62 6c 65 2e 0a 23  rom the table..#
1a20: 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70 65  .speed_trial spe
1a30: 65 64 31 2d 72 61 6e 64 6f 6d 2d 64 65 6c 31 20  ed1-random-del1 
1a40: 32 30 30 30 30 20 72 6f 77 20 7b 0a 20 20 44 45  20000 row {.  DE
1a50: 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57 48 45  LETE FROM t1 WHE
1a60: 52 45 20 72 6f 77 69 64 20 49 4e 0a 20 20 20 20  RE rowid IN.    
1a70: 28 53 45 4c 45 43 54 20 72 6f 77 69 64 20 46 52  (SELECT rowid FR
1a80: 4f 4d 20 74 31 20 4f 52 44 45 52 20 42 59 20 72  OM t1 ORDER BY r
1a90: 61 6e 64 6f 6d 28 29 20 4c 49 4d 49 54 20 32 30  andom() LIMIT 20
1aa0: 30 30 30 29 0a 7d 0a 64 6f 5f 74 65 73 74 20 73  000).}.do_test s
1ab0: 70 65 65 64 31 2d 31 2e 31 20 7b 0a 20 20 64 62  peed1-1.1 {.  db
1ac0: 20 6f 6e 65 20 7b 53 45 4c 45 43 54 20 63 6f 75   one {SELECT cou
1ad0: 6e 74 28 2a 29 20 46 52 4f 4d 20 74 31 7d 0a 7d  nt(*) FROM t1}.}
1ae0: 20 33 30 30 30 30 0a 0a 20 20 20 20 0a 23 20 44   30000..    .# D
1af0: 65 6c 65 74 65 20 32 30 30 30 30 20 6d 6f 72 65  elete 20000 more
1b00: 20 72 6f 77 73 20 61 74 20 72 61 6e 64 6f 6d 20   rows at random 
1b10: 66 72 6f 6d 20 74 68 65 20 74 61 62 6c 65 2e 0a  from the table..
1b20: 23 0a 73 70 65 65 64 5f 74 72 69 61 6c 20 73 70  #.speed_trial sp
1b30: 65 65 64 31 2d 72 61 6e 64 6f 6d 2d 64 65 6c 32  eed1-random-del2
1b40: 20 32 30 30 30 30 20 72 6f 77 20 7b 0a 20 20 44   20000 row {.  D
1b50: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20 57 48  ELETE FROM t1 WH
1b60: 45 52 45 20 72 6f 77 69 64 20 49 4e 0a 20 20 20  ERE rowid IN.   
1b70: 20 28 53 45 4c 45 43 54 20 72 6f 77 69 64 20 46   (SELECT rowid F
1b80: 52 4f 4d 20 74 31 20 4f 52 44 45 52 20 42 59 20  ROM t1 ORDER BY 
1b90: 72 61 6e 64 6f 6d 28 29 20 4c 49 4d 49 54 20 32  random() LIMIT 2
1ba0: 30 30 30 30 29 0a 7d 0a 64 6f 5f 74 65 73 74 20  0000).}.do_test 
1bb0: 73 70 65 65 64 31 2d 31 2e 32 20 7b 0a 20 20 64  speed1-1.2 {.  d
1bc0: 62 20 6f 6e 65 20 7b 53 45 4c 45 43 54 20 63 6f  b one {SELECT co
1bd0: 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 31 7d 0a  unt(*) FROM t1}.
1be0: 7d 20 31 30 30 30 30 0a 73 70 65 65 64 5f 74 72  } 10000.speed_tr
1bf0: 69 61 6c 5f 73 75 6d 6d 61 72 79 20 73 70 65 65  ial_summary spee
1c00: 64 31 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a  d1..finish_test.