/ Hex Artifact Content
Login

Artifact ee2149167303ba8e95af97873c575c3e0fab58ff:


0000: 23 21 2f 75 73 72 2f 62 69 6e 2f 74 63 6c 73 68  #!/usr/bin/tclsh
0010: 0a 23 0a 23 20 52 75 6e 20 74 68 69 73 20 73 63  .#.# Run this sc
0020: 72 69 70 74 20 75 73 69 6e 67 20 54 43 4c 53 48  ript using TCLSH
0030: 20 74 6f 20 64 6f 20 61 20 73 70 65 65 64 20 63   to do a speed c
0040: 6f 6d 70 61 72 69 73 6f 6e 20 62 65 74 77 65 65  omparison betwee
0050: 6e 0a 23 20 76 61 72 69 6f 75 73 20 76 65 72 73  n.# various vers
0060: 69 6f 6e 73 20 6f 66 20 53 51 4c 69 74 65 20 61  ions of SQLite a
0070: 6e 64 20 50 6f 73 74 67 72 65 53 51 4c 20 61 6e  nd PostgreSQL an
0080: 64 20 4d 79 53 51 4c 0a 23 0a 0a 23 20 52 75 6e  d MySQL.#..# Run
0090: 20 61 20 74 65 73 74 0a 23 0a 73 65 74 20 63 6e   a test.#.set cn
00a0: 74 20 31 0a 70 72 6f 63 20 72 75 6e 74 65 73 74  t 1.proc runtest
00b0: 20 7b 74 69 74 6c 65 7d 20 7b 0a 20 20 67 6c 6f   {title} {.  glo
00c0: 62 61 6c 20 63 6e 74 0a 20 20 73 65 74 20 73 71  bal cnt.  set sq
00d0: 6c 66 69 6c 65 20 74 65 73 74 24 63 6e 74 2e 73  lfile test$cnt.s
00e0: 71 6c 0a 20 20 70 75 74 73 20 22 3c 68 32 3e 54  ql.  puts "<h2>T
00f0: 65 73 74 20 24 63 6e 74 3a 20 24 74 69 74 6c 65  est $cnt: $title
0100: 3c 2f 68 32 3e 22 0a 20 20 69 6e 63 72 20 63 6e  </h2>".  incr cn
0110: 74 0a 20 20 73 65 74 20 66 64 20 5b 6f 70 65 6e  t.  set fd [open
0120: 20 24 73 71 6c 66 69 6c 65 20 72 5d 0a 20 20 73   $sqlfile r].  s
0130: 65 74 20 73 71 6c 20 5b 73 74 72 69 6e 67 20 74  et sql [string t
0140: 72 69 6d 20 5b 72 65 61 64 20 24 66 64 20 5b 66  rim [read $fd [f
0150: 69 6c 65 20 73 69 7a 65 20 24 73 71 6c 66 69 6c  ile size $sqlfil
0160: 65 5d 5d 5d 0a 20 20 63 6c 6f 73 65 20 24 66 64  e]]].  close $fd
0170: 0a 20 20 73 65 74 20 73 78 20 5b 73 70 6c 69 74  .  set sx [split
0180: 20 24 73 71 6c 20 5c 6e 5d 0a 20 20 73 65 74 20   $sql \n].  set 
0190: 6e 20 5b 6c 6c 65 6e 67 74 68 20 24 73 78 5d 0a  n [llength $sx].
01a0: 20 20 69 66 20 7b 24 6e 3e 38 7d 20 7b 0a 20 20    if {$n>8} {.  
01b0: 20 20 73 65 74 20 73 71 6c 20 7b 7d 0a 20 20 20    set sql {}.   
01c0: 20 66 6f 72 20 7b 73 65 74 20 69 20 30 7d 20 7b   for {set i 0} {
01d0: 24 69 3c 33 7d 20 7b 69 6e 63 72 20 69 7d 20 7b  $i<3} {incr i} {
01e0: 61 70 70 65 6e 64 20 73 71 6c 20 5b 6c 69 6e 64  append sql [lind
01f0: 65 78 20 24 73 78 20 24 69 5d 3c 62 72 3e 5c 6e  ex $sx $i]<br>\n
0200: 7d 0a 20 20 20 20 61 70 70 65 6e 64 20 73 71 6c  }.    append sql
0210: 20 20 22 3c 69 3e 2e 2e 2e 20 5b 65 78 70 72 20    "<i>... [expr 
0220: 7b 24 6e 2d 36 7d 5d 20 6c 69 6e 65 73 20 6f 6d  {$n-6}] lines om
0230: 69 74 74 65 64 3c 2f 69 3e 3c 62 72 3e 5c 6e 22  itted</i><br>\n"
0240: 0a 20 20 20 20 66 6f 72 20 7b 73 65 74 20 69 20  .    for {set i 
0250: 5b 65 78 70 72 20 7b 24 6e 2d 33 7d 5d 7d 20 7b  [expr {$n-3}]} {
0260: 24 69 3c 24 6e 7d 20 7b 69 6e 63 72 20 69 7d 20  $i<$n} {incr i} 
0270: 7b 0a 20 20 20 20 20 20 61 70 70 65 6e 64 20 73  {.      append s
0280: 71 6c 20 5b 6c 69 6e 64 65 78 20 24 73 78 20 24  ql [lindex $sx $
0290: 69 5d 3c 62 72 3e 5c 6e 0a 20 20 20 20 7d 0a 20  i]<br>\n.    }. 
02a0: 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20 72 65   } else {.    re
02b0: 67 73 75 62 20 2d 61 6c 6c 20 5c 6e 20 5b 73 74  gsub -all \n [st
02c0: 72 69 6e 67 20 74 72 69 6d 20 24 73 71 6c 5d 20  ring trim $sql] 
02d0: 3c 62 72 3e 20 73 71 6c 0a 20 20 7d 0a 20 20 70  <br> sql.  }.  p
02e0: 75 74 73 20 22 3c 62 6c 6f 63 6b 71 75 6f 74 65  uts "<blockquote
02f0: 3e 22 0a 20 20 70 75 74 73 20 22 24 73 71 6c 22  >".  puts "$sql"
0300: 0a 20 20 70 75 74 73 20 22 3c 2f 62 6c 6f 63 6b  .  puts "</block
0310: 71 75 6f 74 65 3e 3c 74 61 62 6c 65 20 62 6f 72  quote><table bor
0320: 64 65 72 3d 30 20 63 65 6c 6c 70 61 64 64 69 6e  der=0 cellpaddin
0330: 67 3d 30 20 63 65 6c 6c 73 70 61 63 69 6e 67 3d  g=0 cellspacing=
0340: 30 3e 22 0a 20 20 73 65 74 20 66 6f 72 6d 61 74  0>".  set format
0350: 20 7b 3c 74 72 3e 3c 74 64 3e 25 73 3c 2f 74 64   {<tr><td>%s</td
0360: 3e 3c 74 64 20 61 6c 69 67 6e 3d 22 72 69 67 68  ><td align="righ
0370: 74 22 3e 26 6e 62 73 70 3b 26 6e 62 73 70 3b 26  t">&nbsp;&nbsp;&
0380: 6e 62 73 70 3b 25 2e 33 66 3c 2f 74 64 3e 3c 2f  nbsp;%.3f</td></
0390: 74 72 3e 7d 0a 20 20 73 65 74 20 64 65 6c 61 79  tr>}.  set delay
03a0: 20 31 30 30 30 0a 20 20 65 78 65 63 20 73 79 6e   1000.  exec syn
03b0: 63 3b 20 61 66 74 65 72 20 24 64 65 6c 61 79 3b  c; after $delay;
03c0: 0a 20 20 73 65 74 20 74 20 5b 74 69 6d 65 20 22  .  set t [time "
03d0: 65 78 65 63 20 70 73 71 6c 20 64 72 68 20 3c 24  exec psql drh <$
03e0: 73 71 6c 66 69 6c 65 22 20 31 5d 0a 20 20 73 65  sqlfile" 1].  se
03f0: 74 20 74 20 5b 65 78 70 72 20 7b 5b 6c 69 6e 64  t t [expr {[lind
0400: 65 78 20 24 74 20 30 5d 2f 31 30 30 30 30 30 30  ex $t 0]/1000000
0410: 2e 30 7d 5d 0a 20 20 70 75 74 73 20 5b 66 6f 72  .0}].  puts [for
0420: 6d 61 74 20 24 66 6f 72 6d 61 74 20 50 6f 73 74  mat $format Post
0430: 67 72 65 53 51 4c 3a 20 24 74 5d 0a 20 20 65 78  greSQL: $t].  ex
0440: 65 63 20 73 79 6e 63 3b 20 61 66 74 65 72 20 24  ec sync; after $
0450: 64 65 6c 61 79 3b 0a 20 20 73 65 74 20 74 20 5b  delay;.  set t [
0460: 74 69 6d 65 20 22 65 78 65 63 20 6d 79 73 71 6c  time "exec mysql
0470: 20 2d 66 20 64 72 68 20 3c 24 73 71 6c 66 69 6c   -f drh <$sqlfil
0480: 65 22 20 31 5d 0a 20 20 73 65 74 20 74 20 5b 65  e" 1].  set t [e
0490: 78 70 72 20 7b 5b 6c 69 6e 64 65 78 20 24 74 20  xpr {[lindex $t 
04a0: 30 5d 2f 31 30 30 30 30 30 30 2e 30 7d 5d 0a 20  0]/1000000.0}]. 
04b0: 20 70 75 74 73 20 5b 66 6f 72 6d 61 74 20 24 66   puts [format $f
04c0: 6f 72 6d 61 74 20 4d 79 53 51 4c 3a 20 24 74 5d  ormat MySQL: $t]
04d0: 0a 23 20 20 73 65 74 20 74 20 5b 74 69 6d 65 20  .#  set t [time 
04e0: 22 65 78 65 63 20 2e 2f 73 71 6c 69 74 65 32 33  "exec ./sqlite23
04f0: 32 20 73 32 33 32 2e 64 62 20 3c 24 73 71 6c 66  2 s232.db <$sqlf
0500: 69 6c 65 22 20 31 5d 0a 23 20 20 73 65 74 20 74  ile" 1].#  set t
0510: 20 5b 65 78 70 72 20 7b 5b 6c 69 6e 64 65 78 20   [expr {[lindex 
0520: 24 74 20 30 5d 2f 31 30 30 30 30 30 30 2e 30 7d  $t 0]/1000000.0}
0530: 5d 0a 23 20 20 70 75 74 73 20 5b 66 6f 72 6d 61  ].#  puts [forma
0540: 74 20 24 66 6f 72 6d 61 74 20 7b 53 51 4c 69 74  t $format {SQLit
0550: 65 20 32 2e 33 2e 32 3a 7d 20 24 74 5d 0a 23 20  e 2.3.2:} $t].# 
0560: 20 73 65 74 20 74 20 5b 74 69 6d 65 20 22 65 78   set t [time "ex
0570: 65 63 20 2e 2f 73 71 6c 69 74 65 2d 31 30 30 20  ec ./sqlite-100 
0580: 73 31 30 30 2e 64 62 20 3c 24 73 71 6c 66 69 6c  s100.db <$sqlfil
0590: 65 22 20 31 5d 0a 23 20 20 73 65 74 20 74 20 5b  e" 1].#  set t [
05a0: 65 78 70 72 20 7b 5b 6c 69 6e 64 65 78 20 24 74  expr {[lindex $t
05b0: 20 30 5d 2f 31 30 30 30 30 30 30 2e 30 7d 5d 0a   0]/1000000.0}].
05c0: 23 20 20 70 75 74 73 20 5b 66 6f 72 6d 61 74 20  #  puts [format 
05d0: 24 66 6f 72 6d 61 74 20 7b 53 51 4c 69 74 65 20  $format {SQLite 
05e0: 32 2e 34 20 28 63 61 63 68 65 3d 31 30 30 29 3a  2.4 (cache=100):
05f0: 7d 20 24 74 5d 0a 20 20 65 78 65 63 20 73 79 6e  } $t].  exec syn
0600: 63 3b 20 61 66 74 65 72 20 24 64 65 6c 61 79 3b  c; after $delay;
0610: 0a 20 20 73 65 74 20 74 20 5b 74 69 6d 65 20 22  .  set t [time "
0620: 65 78 65 63 20 2e 2f 73 71 6c 69 74 65 32 34 30  exec ./sqlite240
0630: 20 73 32 6b 2e 64 62 20 3c 24 73 71 6c 66 69 6c   s2k.db <$sqlfil
0640: 65 22 20 31 5d 0a 20 20 73 65 74 20 74 20 5b 65  e" 1].  set t [e
0650: 78 70 72 20 7b 5b 6c 69 6e 64 65 78 20 24 74 20  xpr {[lindex $t 
0660: 30 5d 2f 31 30 30 30 30 30 30 2e 30 7d 5d 0a 20  0]/1000000.0}]. 
0670: 20 70 75 74 73 20 5b 66 6f 72 6d 61 74 20 24 66   puts [format $f
0680: 6f 72 6d 61 74 20 7b 53 51 4c 69 74 65 20 32 2e  ormat {SQLite 2.
0690: 34 3a 7d 20 24 74 5d 0a 20 20 65 78 65 63 20 73  4:} $t].  exec s
06a0: 79 6e 63 3b 20 61 66 74 65 72 20 24 64 65 6c 61  ync; after $dela
06b0: 79 3b 0a 20 20 73 65 74 20 74 20 5b 74 69 6d 65  y;.  set t [time
06c0: 20 22 65 78 65 63 20 2e 2f 73 71 6c 69 74 65 32   "exec ./sqlite2
06d0: 34 30 20 73 6e 73 2e 64 62 20 3c 24 73 71 6c 66  40 sns.db <$sqlf
06e0: 69 6c 65 22 20 31 5d 0a 20 20 73 65 74 20 74 20  ile" 1].  set t 
06f0: 5b 65 78 70 72 20 7b 5b 6c 69 6e 64 65 78 20 24  [expr {[lindex $
0700: 74 20 30 5d 2f 31 30 30 30 30 30 30 2e 30 7d 5d  t 0]/1000000.0}]
0710: 0a 20 20 70 75 74 73 20 5b 66 6f 72 6d 61 74 20  .  puts [format 
0720: 24 66 6f 72 6d 61 74 20 7b 53 51 4c 69 74 65 20  $format {SQLite 
0730: 32 2e 34 20 28 6e 6f 73 79 6e 63 29 3a 7d 20 24  2.4 (nosync):} $
0740: 74 5d 0a 23 20 20 73 65 74 20 74 20 5b 74 69 6d  t].#  set t [tim
0750: 65 20 22 65 78 65 63 20 2e 2f 73 71 6c 69 74 65  e "exec ./sqlite
0760: 2d 74 31 20 73 74 31 2e 64 62 20 3c 24 73 71 6c  -t1 st1.db <$sql
0770: 66 69 6c 65 22 20 31 5d 0a 23 20 20 73 65 74 20  file" 1].#  set 
0780: 74 20 5b 65 78 70 72 20 7b 5b 6c 69 6e 64 65 78  t [expr {[lindex
0790: 20 24 74 20 30 5d 2f 31 30 30 30 30 30 30 2e 30   $t 0]/1000000.0
07a0: 7d 5d 0a 23 20 20 70 75 74 73 20 5b 66 6f 72 6d  }].#  puts [form
07b0: 61 74 20 24 66 6f 72 6d 61 74 20 7b 53 51 4c 69  at $format {SQLi
07c0: 74 65 20 32 2e 34 20 28 74 65 73 74 29 3a 7d 20  te 2.4 (test):} 
07d0: 24 74 5d 0a 20 20 70 75 74 73 20 22 3c 2f 74 61  $t].  puts "</ta
07e0: 62 6c 65 3e 22 0a 7d 0a 0a 23 20 49 6e 69 74 69  ble>".}..# Initi
07f0: 61 6c 69 7a 65 20 74 68 65 20 65 6e 76 69 72 6f  alize the enviro
0800: 6e 6d 65 6e 74 0a 23 0a 65 78 70 72 20 73 72 61  nment.#.expr sra
0810: 6e 64 28 31 29 0a 63 61 74 63 68 20 7b 65 78 65  nd(1).catch {exe
0820: 63 20 2f 62 69 6e 2f 73 68 20 2d 63 20 7b 72 6d  c /bin/sh -c {rm
0830: 20 2d 66 20 73 2a 2e 64 62 7d 7d 0a 73 65 74 20   -f s*.db}}.set 
0840: 66 64 20 5b 6f 70 65 6e 20 63 6c 65 61 72 2e 73  fd [open clear.s
0850: 71 6c 20 77 5d 0a 70 75 74 73 20 24 66 64 20 7b  ql w].puts $fd {
0860: 0a 20 20 64 72 6f 70 20 74 61 62 6c 65 20 74 31  .  drop table t1
0870: 3b 0a 20 20 64 72 6f 70 20 74 61 62 6c 65 20 74  ;.  drop table t
0880: 32 3b 0a 7d 0a 63 6c 6f 73 65 20 24 66 64 0a 63  2;.}.close $fd.c
0890: 61 74 63 68 20 7b 65 78 65 63 20 70 73 71 6c 20  atch {exec psql 
08a0: 64 72 68 20 3c 63 6c 65 61 72 2e 73 71 6c 7d 0a  drh <clear.sql}.
08b0: 63 61 74 63 68 20 7b 65 78 65 63 20 6d 79 73 71  catch {exec mysq
08c0: 6c 20 64 72 68 20 3c 63 6c 65 61 72 2e 73 71 6c  l drh <clear.sql
08d0: 7d 0a 73 65 74 20 66 64 20 5b 6f 70 65 6e 20 32  }.set fd [open 2
08e0: 6b 69 6e 69 74 2e 73 71 6c 20 77 5d 0a 70 75 74  kinit.sql w].put
08f0: 73 20 24 66 64 20 7b 0a 20 20 50 52 41 47 4d 41  s $fd {.  PRAGMA
0900: 20 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73   default_cache_s
0910: 69 7a 65 3d 32 30 30 30 3b 0a 20 20 50 52 41 47  ize=2000;.  PRAG
0920: 4d 41 20 64 65 66 61 75 6c 74 5f 73 79 6e 63 68  MA default_synch
0930: 72 6f 6e 6f 75 73 3d 6f 6e 3b 0a 7d 0a 63 6c 6f  ronous=on;.}.clo
0940: 73 65 20 24 66 64 0a 65 78 65 63 20 2e 2f 73 71  se $fd.exec ./sq
0950: 6c 69 74 65 32 34 30 20 73 32 6b 2e 64 62 20 3c  lite240 s2k.db <
0960: 32 6b 69 6e 69 74 2e 73 71 6c 0a 65 78 65 63 20  2kinit.sql.exec 
0970: 2e 2f 73 71 6c 69 74 65 2d 74 31 20 73 74 31 2e  ./sqlite-t1 st1.
0980: 64 62 20 3c 32 6b 69 6e 69 74 2e 73 71 6c 0a 73  db <2kinit.sql.s
0990: 65 74 20 66 64 20 5b 6f 70 65 6e 20 6e 6f 73 79  et fd [open nosy
09a0: 6e 63 2d 69 6e 69 74 2e 73 71 6c 20 77 5d 0a 70  nc-init.sql w].p
09b0: 75 74 73 20 24 66 64 20 7b 0a 20 20 50 52 41 47  uts $fd {.  PRAG
09c0: 4d 41 20 64 65 66 61 75 6c 74 5f 63 61 63 68 65  MA default_cache
09d0: 5f 73 69 7a 65 3d 32 30 30 30 3b 0a 20 20 50 52  _size=2000;.  PR
09e0: 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 73 79 6e  AGMA default_syn
09f0: 63 68 72 6f 6e 6f 75 73 3d 6f 66 66 3b 0a 7d 0a  chronous=off;.}.
0a00: 63 6c 6f 73 65 20 24 66 64 0a 65 78 65 63 20 2e  close $fd.exec .
0a10: 2f 73 71 6c 69 74 65 32 34 30 20 73 6e 73 2e 64  /sqlite240 sns.d
0a20: 62 20 3c 6e 6f 73 79 6e 63 2d 69 6e 69 74 2e 73  b <nosync-init.s
0a30: 71 6c 0a 73 65 74 20 6f 6e 65 73 20 7b 7a 65 72  ql.set ones {zer
0a40: 6f 20 6f 6e 65 20 74 77 6f 20 74 68 72 65 65 20  o one two three 
0a50: 66 6f 75 72 20 66 69 76 65 20 73 69 78 20 73 65  four five six se
0a60: 76 65 6e 20 65 69 67 68 74 20 6e 69 6e 65 0a 20  ven eight nine. 
0a70: 20 20 20 20 20 20 20 20 20 74 65 6e 20 65 6c 65           ten ele
0a80: 76 65 6e 20 74 77 65 6c 76 65 20 74 68 69 72 74  ven twelve thirt
0a90: 65 65 6e 20 66 6f 75 72 74 65 65 6e 20 66 69 66  een fourteen fif
0aa0: 74 65 65 6e 20 73 69 78 74 65 65 6e 20 73 65 76  teen sixteen sev
0ab0: 65 6e 74 65 65 6e 0a 20 20 20 20 20 20 20 20 20  enteen.         
0ac0: 20 65 69 67 68 74 65 65 6e 20 6e 69 6e 65 74 65   eighteen ninete
0ad0: 65 6e 7d 0a 73 65 74 20 74 65 6e 73 20 7b 7b 7d  en}.set tens {{}
0ae0: 20 74 65 6e 20 74 77 65 6e 74 79 20 74 68 69 72   ten twenty thir
0af0: 74 79 20 66 6f 72 74 79 20 66 69 66 74 79 20 73  ty forty fifty s
0b00: 69 78 74 79 20 73 65 76 65 6e 74 79 20 65 69 67  ixty seventy eig
0b10: 68 74 79 20 6e 69 6e 65 74 79 7d 0a 70 72 6f 63  hty ninety}.proc
0b20: 20 6e 75 6d 62 65 72 5f 6e 61 6d 65 20 7b 6e 7d   number_name {n}
0b30: 20 7b 0a 20 20 69 66 20 7b 24 6e 3e 3d 31 30 30   {.  if {$n>=100
0b40: 30 7d 20 7b 0a 20 20 20 20 73 65 74 20 74 78 74  0} {.    set txt
0b50: 20 22 5b 6e 75 6d 62 65 72 5f 6e 61 6d 65 20 5b   "[number_name [
0b60: 65 78 70 72 20 7b 24 6e 2f 31 30 30 30 7d 5d 5d  expr {$n/1000}]]
0b70: 20 74 68 6f 75 73 61 6e 64 22 0a 20 20 20 20 73   thousand".    s
0b80: 65 74 20 6e 20 5b 65 78 70 72 20 7b 24 6e 25 31  et n [expr {$n%1
0b90: 30 30 30 7d 5d 0a 20 20 7d 20 65 6c 73 65 20 7b  000}].  } else {
0ba0: 0a 20 20 20 20 73 65 74 20 74 78 74 20 7b 7d 0a  .    set txt {}.
0bb0: 20 20 7d 0a 20 20 69 66 20 7b 24 6e 3e 3d 31 30    }.  if {$n>=10
0bc0: 30 7d 20 7b 0a 20 20 20 20 61 70 70 65 6e 64 20  0} {.    append 
0bd0: 74 78 74 20 22 20 5b 6c 69 6e 64 65 78 20 24 3a  txt " [lindex $:
0be0: 3a 6f 6e 65 73 20 5b 65 78 70 72 20 7b 24 6e 2f  :ones [expr {$n/
0bf0: 31 30 30 7d 5d 5d 20 68 75 6e 64 72 65 64 22 0a  100}]] hundred".
0c00: 20 20 20 20 73 65 74 20 6e 20 5b 65 78 70 72 20      set n [expr 
0c10: 7b 24 6e 25 31 30 30 7d 5d 0a 20 20 7d 0a 20 20  {$n%100}].  }.  
0c20: 69 66 20 7b 24 6e 3e 3d 32 30 7d 20 7b 0a 20 20  if {$n>=20} {.  
0c30: 20 20 61 70 70 65 6e 64 20 74 78 74 20 22 20 5b    append txt " [
0c40: 6c 69 6e 64 65 78 20 24 3a 3a 74 65 6e 73 20 5b  lindex $::tens [
0c50: 65 78 70 72 20 7b 24 6e 2f 31 30 7d 5d 5d 22 0a  expr {$n/10}]]".
0c60: 20 20 20 20 73 65 74 20 6e 20 5b 65 78 70 72 20      set n [expr 
0c70: 7b 24 6e 25 31 30 7d 5d 0a 20 20 7d 0a 20 20 69  {$n%10}].  }.  i
0c80: 66 20 7b 24 6e 3e 30 7d 20 7b 0a 20 20 20 20 61  f {$n>0} {.    a
0c90: 70 70 65 6e 64 20 74 78 74 20 22 20 5b 6c 69 6e  ppend txt " [lin
0ca0: 64 65 78 20 24 3a 3a 6f 6e 65 73 20 24 6e 5d 22  dex $::ones $n]"
0cb0: 0a 20 20 7d 0a 20 20 73 65 74 20 74 78 74 20 5b  .  }.  set txt [
0cc0: 73 74 72 69 6e 67 20 74 72 69 6d 20 24 74 78 74  string trim $txt
0cd0: 5d 0a 20 20 69 66 20 7b 24 74 78 74 3d 3d 22 22  ].  if {$txt==""
0ce0: 7d 20 7b 73 65 74 20 74 78 74 20 7a 65 72 6f 7d  } {set txt zero}
0cf0: 0a 20 20 72 65 74 75 72 6e 20 24 74 78 74 0a 7d  .  return $txt.}
0d00: 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65 6e 20  ...set fd [open 
0d10: 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77 5d 0a  test$cnt.sql w].
0d20: 70 75 74 73 20 24 66 64 20 22 42 45 47 49 4e 3b  puts $fd "BEGIN;
0d30: 22 0a 70 75 74 73 20 24 66 64 20 22 43 52 45 41  ".puts $fd "CREA
0d40: 54 45 20 54 41 42 4c 45 20 74 31 28 61 20 49 4e  TE TABLE t1(a IN
0d50: 54 45 47 45 52 2c 20 62 20 49 4e 54 45 47 45 52  TEGER, b INTEGER
0d60: 2c 20 63 20 56 41 52 43 48 41 52 28 31 30 30 29  , c VARCHAR(100)
0d70: 29 3b 22 0a 66 6f 72 20 7b 73 65 74 20 69 20 31  );".for {set i 1
0d80: 7d 20 7b 24 69 3c 3d 32 35 30 30 30 7d 20 7b 69  } {$i<=25000} {i
0d90: 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 72  ncr i} {.  set r
0da0: 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61 6e 64   [expr {int(rand
0db0: 28 29 2a 35 30 30 30 30 30 29 7d 5d 0a 20 20 70  ()*500000)}].  p
0dc0: 75 74 73 20 24 66 64 20 22 49 4e 53 45 52 54 20  uts $fd "INSERT 
0dd0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24  INTO t1 VALUES($
0de0: 69 2c 24 72 2c 27 5b 6e 75 6d 62 65 72 5f 6e 61  i,$r,'[number_na
0df0: 6d 65 20 24 72 5d 27 29 3b 22 0a 7d 0a 70 75 74  me $r]');".}.put
0e00: 73 20 24 66 64 20 22 43 4f 4d 4d 49 54 3b 22 0a  s $fd "COMMIT;".
0e10: 63 6c 6f 73 65 20 24 66 64 0a 72 75 6e 74 65 73  close $fd.runtes
0e20: 74 20 7b 32 35 30 30 30 20 49 4e 53 45 52 54 73  t {25000 INSERTs
0e30: 20 69 6e 20 61 20 74 72 61 6e 73 61 63 74 69 6f   in a transactio
0e40: 6e 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  n}...set fd [ope
0e50: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
0e60: 5d 0a 70 75 74 73 20 24 66 64 20 22 44 45 4c 45  ].puts $fd "DELE
0e70: 54 45 20 46 52 4f 4d 20 74 31 3b 22 0a 63 6c 6f  TE FROM t1;".clo
0e80: 73 65 20 24 66 64 0a 72 75 6e 74 65 73 74 20 7b  se $fd.runtest {
0e90: 44 45 4c 45 54 45 20 65 76 65 72 79 74 68 69 6e  DELETE everythin
0ea0: 67 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  g}...set fd [ope
0eb0: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
0ec0: 5d 0a 70 75 74 73 20 24 66 64 20 22 42 45 47 49  ].puts $fd "BEGI
0ed0: 4e 3b 22 0a 66 6f 72 20 7b 73 65 74 20 69 20 31  N;".for {set i 1
0ee0: 7d 20 7b 24 69 3c 3d 32 35 30 30 30 7d 20 7b 69  } {$i<=25000} {i
0ef0: 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 72  ncr i} {.  set r
0f00: 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61 6e 64   [expr {int(rand
0f10: 28 29 2a 35 30 30 30 30 30 29 7d 5d 0a 20 20 70  ()*500000)}].  p
0f20: 75 74 73 20 24 66 64 20 22 49 4e 53 45 52 54 20  uts $fd "INSERT 
0f30: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24  INTO t1 VALUES($
0f40: 69 2c 24 72 2c 27 5b 6e 75 6d 62 65 72 5f 6e 61  i,$r,'[number_na
0f50: 6d 65 20 24 72 5d 27 29 3b 22 0a 7d 0a 70 75 74  me $r]');".}.put
0f60: 73 20 24 66 64 20 22 43 4f 4d 4d 49 54 3b 22 0a  s $fd "COMMIT;".
0f70: 63 6c 6f 73 65 20 24 66 64 0a 72 75 6e 74 65 73  close $fd.runtes
0f80: 74 20 7b 32 35 30 30 30 20 49 4e 53 45 52 54 73  t {25000 INSERTs
0f90: 20 69 6e 20 61 20 74 72 61 6e 73 61 63 74 69 6f   in a transactio
0fa0: 6e 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  n}...set fd [ope
0fb0: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
0fc0: 5d 0a 70 75 74 73 20 24 66 64 20 22 44 45 4c 45  ].puts $fd "DELE
0fd0: 54 45 20 46 52 4f 4d 20 74 31 3b 22 0a 63 6c 6f  TE FROM t1;".clo
0fe0: 73 65 20 24 66 64 0a 72 75 6e 74 65 73 74 20 7b  se $fd.runtest {
0ff0: 44 45 4c 45 54 45 20 65 76 65 72 79 74 68 69 6e  DELETE everythin
1000: 67 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  g}...set fd [ope
1010: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
1020: 5d 0a 70 75 74 73 20 24 66 64 20 22 42 45 47 49  ].puts $fd "BEGI
1030: 4e 3b 22 0a 66 6f 72 20 7b 73 65 74 20 69 20 31  N;".for {set i 1
1040: 7d 20 7b 24 69 3c 3d 32 35 30 30 30 7d 20 7b 69  } {$i<=25000} {i
1050: 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 72  ncr i} {.  set r
1060: 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61 6e 64   [expr {int(rand
1070: 28 29 2a 35 30 30 30 30 30 29 7d 5d 0a 20 20 70  ()*500000)}].  p
1080: 75 74 73 20 24 66 64 20 22 49 4e 53 45 52 54 20  uts $fd "INSERT 
1090: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24  INTO t1 VALUES($
10a0: 69 2c 24 72 2c 27 5b 6e 75 6d 62 65 72 5f 6e 61  i,$r,'[number_na
10b0: 6d 65 20 24 72 5d 27 29 3b 22 0a 7d 0a 70 75 74  me $r]');".}.put
10c0: 73 20 24 66 64 20 22 43 4f 4d 4d 49 54 3b 22 0a  s $fd "COMMIT;".
10d0: 63 6c 6f 73 65 20 24 66 64 0a 72 75 6e 74 65 73  close $fd.runtes
10e0: 74 20 7b 32 35 30 30 30 20 49 4e 53 45 52 54 73  t {25000 INSERTs
10f0: 20 69 6e 20 61 20 74 72 61 6e 73 61 63 74 69 6f   in a transactio
1100: 6e 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  n}...set fd [ope
1110: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
1120: 5d 0a 70 75 74 73 20 24 66 64 20 22 44 45 4c 45  ].puts $fd "DELE
1130: 54 45 20 46 52 4f 4d 20 74 31 3b 22 0a 63 6c 6f  TE FROM t1;".clo
1140: 73 65 20 24 66 64 0a 72 75 6e 74 65 73 74 20 7b  se $fd.runtest {
1150: 44 45 4c 45 54 45 20 65 76 65 72 79 74 68 69 6e  DELETE everythin
1160: 67 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  g}...set fd [ope
1170: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
1180: 5d 0a 70 75 74 73 20 24 66 64 20 22 42 45 47 49  ].puts $fd "BEGI
1190: 4e 3b 22 0a 66 6f 72 20 7b 73 65 74 20 69 20 31  N;".for {set i 1
11a0: 7d 20 7b 24 69 3c 3d 32 35 30 30 30 7d 20 7b 69  } {$i<=25000} {i
11b0: 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 72  ncr i} {.  set r
11c0: 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61 6e 64   [expr {int(rand
11d0: 28 29 2a 35 30 30 30 30 30 29 7d 5d 0a 20 20 70  ()*500000)}].  p
11e0: 75 74 73 20 24 66 64 20 22 49 4e 53 45 52 54 20  uts $fd "INSERT 
11f0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24  INTO t1 VALUES($
1200: 69 2c 24 72 2c 27 5b 6e 75 6d 62 65 72 5f 6e 61  i,$r,'[number_na
1210: 6d 65 20 24 72 5d 27 29 3b 22 0a 7d 0a 70 75 74  me $r]');".}.put
1220: 73 20 24 66 64 20 22 43 4f 4d 4d 49 54 3b 22 0a  s $fd "COMMIT;".
1230: 63 6c 6f 73 65 20 24 66 64 0a 72 75 6e 74 65 73  close $fd.runtes
1240: 74 20 7b 32 35 30 30 30 20 49 4e 53 45 52 54 73  t {25000 INSERTs
1250: 20 69 6e 20 61 20 74 72 61 6e 73 61 63 74 69 6f   in a transactio
1260: 6e 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  n}...set fd [ope
1270: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
1280: 5d 0a 70 75 74 73 20 24 66 64 20 22 44 45 4c 45  ].puts $fd "DELE
1290: 54 45 20 46 52 4f 4d 20 74 31 3b 22 0a 63 6c 6f  TE FROM t1;".clo
12a0: 73 65 20 24 66 64 0a 72 75 6e 74 65 73 74 20 7b  se $fd.runtest {
12b0: 44 45 4c 45 54 45 20 65 76 65 72 79 74 68 69 6e  DELETE everythin
12c0: 67 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  g}...set fd [ope
12d0: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
12e0: 5d 0a 70 75 74 73 20 24 66 64 20 22 42 45 47 49  ].puts $fd "BEGI
12f0: 4e 3b 22 0a 66 6f 72 20 7b 73 65 74 20 69 20 31  N;".for {set i 1
1300: 7d 20 7b 24 69 3c 3d 32 35 30 30 30 7d 20 7b 69  } {$i<=25000} {i
1310: 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74 20 72  ncr i} {.  set r
1320: 20 5b 65 78 70 72 20 7b 69 6e 74 28 72 61 6e 64   [expr {int(rand
1330: 28 29 2a 35 30 30 30 30 30 29 7d 5d 0a 20 20 70  ()*500000)}].  p
1340: 75 74 73 20 24 66 64 20 22 49 4e 53 45 52 54 20  uts $fd "INSERT 
1350: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24  INTO t1 VALUES($
1360: 69 2c 24 72 2c 27 5b 6e 75 6d 62 65 72 5f 6e 61  i,$r,'[number_na
1370: 6d 65 20 24 72 5d 27 29 3b 22 0a 7d 0a 70 75 74  me $r]');".}.put
1380: 73 20 24 66 64 20 22 43 4f 4d 4d 49 54 3b 22 0a  s $fd "COMMIT;".
1390: 63 6c 6f 73 65 20 24 66 64 0a 72 75 6e 74 65 73  close $fd.runtes
13a0: 74 20 7b 32 35 30 30 30 20 49 4e 53 45 52 54 73  t {25000 INSERTs
13b0: 20 69 6e 20 61 20 74 72 61 6e 73 61 63 74 69 6f   in a transactio
13c0: 6e 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  n}...set fd [ope
13d0: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
13e0: 5d 0a 70 75 74 73 20 24 66 64 20 22 44 45 4c 45  ].puts $fd "DELE
13f0: 54 45 20 46 52 4f 4d 20 74 31 3b 22 0a 63 6c 6f  TE FROM t1;".clo
1400: 73 65 20 24 66 64 0a 72 75 6e 74 65 73 74 20 7b  se $fd.runtest {
1410: 44 45 4c 45 54 45 20 65 76 65 72 79 74 68 69 6e  DELETE everythin
1420: 67 7d 0a 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65  g}...set fd [ope
1430: 6e 20 74 65 73 74 24 63 6e 74 2e 73 71 6c 20 77  n test$cnt.sql w
1440: 5d 0a 70 75 74 73 20 24 66 64 20 7b 44 52 4f 50  ].puts $fd {DROP
1450: 20 54 41 42 4c 45 20 74 31 3b 7d 0a 63 6c 6f 73   TABLE t1;}.clos
1460: 65 20 24 66 64 0a 72 75 6e 74 65 73 74 20 7b 44  e $fd.runtest {D
1470: 52 4f 50 20 54 41 42 4c 45 7d 0a                 ROP TABLE}.