sqllogictest
Hex Artifact Content
Not logged in

Artifact 68ca9f3aa5c3322397b9e275c6386ff6a2a60cd1:


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 74 6f 20 67 65 6e 65 72 61 74 65  ript to generate
0030: 20 61 20 6c 61 72 67 65 72 20 70 72 6f 74 6f 74   a larger protot
0040: 79 70 65 20 74 65 73 74 20 73 63 72 69 70 74 20  ype test script 
0050: 66 6f 72 0a 23 20 73 71 6c 6c 6f 67 69 63 74 65  for.# sqllogicte
0060: 73 74 2e 0a 23 0a 23 20 54 68 69 73 20 69 73 20  st..#.# This is 
0070: 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 74 65 73  the original tes
0080: 74 20 73 63 72 69 70 74 20 67 65 6e 65 72 61 74  t script generat
0090: 6f 72 2e 20 20 49 74 20 67 65 6e 65 72 61 74 65  or.  It generate
00a0: 73 20 61 20 73 69 6e 67 6c 65 0a 23 20 74 61 62  s a single.# tab
00b0: 6c 65 20 54 31 28 61 2c 62 2c 63 2c 64 2c 65 29  le T1(a,b,c,d,e)
00c0: 20 77 69 74 68 20 61 6c 6c 20 49 4e 54 45 47 45   with all INTEGE
00d0: 52 20 63 6f 6c 75 6d 6e 73 20 61 6e 64 20 33 30  R columns and 30
00e0: 20 72 6f 77 73 20 6f 66 20 6e 6f 6e 2d 4e 55 4c   rows of non-NUL
00f0: 4c 0a 23 20 64 61 74 61 2c 20 74 68 65 6e 20 64  L.# data, then d
0100: 6f 65 73 20 76 61 72 69 6f 75 73 20 71 75 65 72  oes various quer
0110: 69 65 73 20 61 67 61 69 6e 73 74 20 74 68 61 74  ies against that
0120: 20 74 61 62 6c 65 2e 0a 23 0a 65 78 70 72 20 7b   table..#.expr {
0130: 73 72 61 6e 64 28 30 29 7d 0a 0a 23 20 53 63 72  srand(0)}..# Scr
0140: 61 6d 62 6c 65 20 74 68 65 20 24 69 6e 6c 69 73  amble the $inlis
0150: 74 20 69 6e 74 6f 20 61 20 72 61 6e 64 6f 6d 20  t into a random 
0160: 6f 72 64 65 72 2e 0a 23 0a 70 72 6f 63 20 73 63  order..#.proc sc
0170: 72 61 6d 62 6c 65 20 7b 69 6e 6c 69 73 74 7d 20  ramble {inlist} 
0180: 7b 0a 20 20 73 65 74 20 79 20 7b 7d 0a 20 20 66  {.  set y {}.  f
0190: 6f 72 65 61 63 68 20 78 20 24 69 6e 6c 69 73 74  oreach x $inlist
01a0: 20 7b 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 79   {.    lappend y
01b0: 20 5b 6c 69 73 74 20 5b 65 78 70 72 20 7b 72 61   [list [expr {ra
01c0: 6e 64 28 29 7d 5d 20 24 78 5d 0a 20 20 7d 0a 20  nd()}] $x].  }. 
01d0: 20 73 65 74 20 79 20 5b 6c 73 6f 72 74 20 24 79   set y [lsort $y
01e0: 5d 0a 20 20 73 65 74 20 6f 75 74 6c 69 73 74 20  ].  set outlist 
01f0: 7b 7d 0a 20 20 66 6f 72 65 61 63 68 20 78 20 24  {}.  foreach x $
0200: 79 20 7b 0a 20 20 20 20 6c 61 70 70 65 6e 64 20  y {.    lappend 
0210: 6f 75 74 6c 69 73 74 20 5b 6c 69 6e 64 65 78 20  outlist [lindex 
0220: 24 78 20 31 5d 0a 20 20 7d 0a 20 20 72 65 74 75  $x 1].  }.  retu
0230: 72 6e 20 24 6f 75 74 6c 69 73 74 0a 7d 0a 0a 70  rn $outlist.}..p
0240: 75 74 73 20 7b 73 74 61 74 65 6d 65 6e 74 20 6f  uts {statement o
0250: 6b 7d 0a 70 75 74 73 20 7b 43 52 45 41 54 45 20  k}.puts {CREATE 
0260: 54 41 42 4c 45 20 74 31 28 61 20 49 4e 54 45 47  TABLE t1(a INTEG
0270: 45 52 2c 20 62 20 49 4e 54 45 47 45 52 2c 20 63  ER, b INTEGER, c
0280: 20 49 4e 54 45 47 45 52 2c 20 64 20 49 4e 54 45   INTEGER, d INTE
0290: 47 45 52 2c 20 65 20 49 4e 54 45 47 45 52 29 7d  GER, e INTEGER)}
02a0: 0a 70 75 74 73 20 7b 7d 0a 0a 66 6f 72 20 7b 73  .puts {}..for {s
02b0: 65 74 20 69 20 30 7d 20 7b 24 69 3c 33 30 7d 20  et i 0} {$i<30} 
02c0: 7b 69 6e 63 72 20 69 7d 20 7b 0a 20 20 73 65 74  {incr i} {.  set
02d0: 20 62 61 73 65 20 5b 65 78 70 72 20 7b 24 69 2a   base [expr {$i*
02e0: 35 2b 31 30 30 7d 5d 0a 20 20 73 65 74 20 76 61  5+100}].  set va
02f0: 6c 75 65 73 20 7b 7d 0a 20 20 66 6f 72 20 7b 73  lues {}.  for {s
0300: 65 74 20 6a 20 30 7d 20 7b 24 6a 3c 35 7d 20 7b  et j 0} {$j<5} {
0310: 69 6e 63 72 20 6a 7d 20 7b 0a 20 20 20 20 69 66  incr j} {.    if
0320: 20 7b 72 61 6e 64 28 29 3c 30 2e 30 7d 20 7b 0a   {rand()<0.0} {.
0330: 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 76 61        lappend va
0340: 6c 75 65 73 20 4e 55 4c 4c 0a 20 20 20 20 7d 20  lues NULL.    } 
0350: 65 6c 73 65 20 7b 0a 20 20 20 20 20 20 6c 61 70  else {.      lap
0360: 70 65 6e 64 20 76 61 6c 75 65 73 20 5b 65 78 70  pend values [exp
0370: 72 20 7b 24 6a 2b 24 62 61 73 65 7d 5d 0a 20 20  r {$j+$base}].  
0380: 20 20 7d 0a 20 20 7d 0a 20 20 73 65 74 20 76 61    }.  }.  set va
0390: 6c 75 65 73 20 5b 73 63 72 61 6d 62 6c 65 20 24  lues [scramble $
03a0: 76 61 6c 75 65 73 5d 0a 20 20 73 65 74 20 63 6f  values].  set co
03b0: 6c 73 20 5b 73 63 72 61 6d 62 6c 65 20 7b 61 20  ls [scramble {a 
03c0: 62 20 63 20 64 20 65 7d 5d 0a 20 20 73 65 74 20  b c d e}].  set 
03d0: 73 71 6c 20 22 49 4e 53 45 52 54 20 49 4e 54 4f  sql "INSERT INTO
03e0: 20 74 31 28 5b 6a 6f 69 6e 20 24 63 6f 6c 73 20   t1([join $cols 
03f0: 2c 5d 29 20 56 41 4c 55 45 53 28 5b 6a 6f 69 6e  ,]) VALUES([join
0400: 20 24 76 61 6c 75 65 73 20 2c 5d 29 22 0a 20 20   $values ,])".  
0410: 70 75 74 73 20 22 73 74 61 74 65 6d 65 6e 74 20  puts "statement 
0420: 6f 6b 22 0a 20 20 70 75 74 73 20 24 73 71 6c 0a  ok".  puts $sql.
0430: 20 20 70 75 74 73 20 22 22 0a 7d 0a 0a 73 65 74    puts "".}..set
0440: 20 72 65 78 70 72 20 7b 0a 20 20 61 20 62 20 63   rexpr {.  a b c
0450: 20 64 20 65 0a 20 20 61 2d 62 20 62 2d 63 20 63   d e.  a-b b-c c
0460: 2d 64 20 64 2d 65 0a 20 20 61 2b 62 2a 32 20 61  -d d-e.  a+b*2 a
0470: 2b 62 2a 32 2b 63 2a 33 20 61 2b 62 2a 32 2b 63  +b*2+c*3 a+b*2+c
0480: 2a 33 2b 64 2a 34 20 61 2b 62 2a 32 2b 63 2a 33  *3+d*4 a+b*2+c*3
0490: 2b 64 2a 34 2b 65 2a 35 0a 20 20 28 61 2b 62 2b  +d*4+e*5.  (a+b+
04a0: 63 2b 64 2b 65 29 2f 35 0a 20 20 61 62 73 28 61  c+d+e)/5.  abs(a
04b0: 29 20 61 62 73 28 62 2d 63 29 0a 20 20 7b 28 53  ) abs(b-c).  {(S
04c0: 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 20 46  ELECT count(*) F
04d0: 52 4f 4d 20 74 31 20 41 53 20 78 20 57 48 45 52  ROM t1 AS x WHER
04e0: 45 20 78 2e 62 3c 74 31 2e 62 29 7d 0a 20 20 7b  E x.b<t1.b)}.  {
04f0: 28 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29  (SELECT count(*)
0500: 20 46 52 4f 4d 20 74 31 20 41 53 20 78 20 57 48   FROM t1 AS x WH
0510: 45 52 45 20 78 2e 63 3e 74 31 2e 63 20 41 4e 44  ERE x.c>t1.c AND
0520: 20 78 2e 64 3c 74 31 2e 64 29 7d 0a 20 20 7b 43   x.d<t1.d)}.  {C
0530: 41 53 45 20 57 48 45 4e 20 63 3e 28 53 45 4c 45  ASE WHEN c>(SELE
0540: 43 54 20 61 76 67 28 63 29 20 46 52 4f 4d 20 74  CT avg(c) FROM t
0550: 31 29 20 54 48 45 4e 20 61 2a 32 20 45 4c 53 45  1) THEN a*2 ELSE
0560: 20 62 2a 31 30 20 45 4e 44 7d 0a 20 20 7b 43 41   b*10 END}.  {CA
0570: 53 45 20 57 48 45 4e 20 61 3c 62 2d 33 20 54 48  SE WHEN a<b-3 TH
0580: 45 4e 20 31 31 31 20 57 48 45 4e 20 61 3c 3d 62  EN 111 WHEN a<=b
0590: 20 54 48 45 4e 20 32 32 32 0a 20 20 20 20 20 20   THEN 222.      
05a0: 20 20 57 48 45 4e 20 61 3c 62 2b 33 20 54 48 45    WHEN a<b+3 THE
05b0: 4e 20 33 33 33 20 45 4c 53 45 20 34 34 34 20 45  N 333 ELSE 444 E
05c0: 4e 44 7d 0a 20 20 7b 43 41 53 45 20 61 2b 31 20  ND}.  {CASE a+1 
05d0: 57 48 45 4e 20 62 20 54 48 45 4e 20 31 31 31 20  WHEN b THEN 111 
05e0: 57 48 45 4e 20 63 20 54 48 45 4e 20 32 32 32 0a  WHEN c THEN 222.
05f0: 20 20 20 20 20 20 20 20 57 48 45 4e 20 64 20 54          WHEN d T
0600: 48 45 4e 20 33 33 33 20 20 57 48 45 4e 20 65 20  HEN 333  WHEN e 
0610: 54 48 45 4e 20 34 34 34 20 45 4c 53 45 20 35 35  THEN 444 ELSE 55
0620: 35 20 45 4e 44 7d 0a 7d 0a 73 65 74 20 6e 72 65  5 END}.}.set nre
0630: 78 70 72 20 5b 6c 6c 65 6e 67 74 68 20 24 72 65  xpr [llength $re
0640: 78 70 72 5d 0a 73 65 74 20 73 65 71 75 65 6e 63  xpr].set sequenc
0650: 65 20 7b 7d 0a 73 65 74 20 74 79 70 65 20 7b 7d  e {}.set type {}
0660: 0a 66 6f 72 20 7b 73 65 74 20 69 20 31 7d 20 7b  .for {set i 1} {
0670: 24 69 3c 3d 24 6e 72 65 78 70 72 7d 20 7b 69 6e  $i<=$nrexpr} {in
0680: 63 72 20 69 7d 20 7b 0a 20 20 6c 61 70 70 65 6e  cr i} {.  lappen
0690: 64 20 73 65 71 75 65 6e 63 65 20 24 69 0a 20 20  d sequence $i.  
06a0: 61 70 70 65 6e 64 20 74 79 70 65 20 49 0a 7d 0a  append type I.}.
06b0: 73 65 74 20 77 65 78 70 72 20 7b 0a 20 20 61 3e  set wexpr {.  a>
06c0: 62 0a 20 20 62 3e 63 0a 20 20 63 3e 64 0a 20 20  b.  b>c.  c>d.  
06d0: 64 3e 65 0a 20 20 7b 63 20 42 45 54 57 45 45 4e  d>e.  {c BETWEEN
06e0: 20 62 2d 32 20 41 4e 44 20 64 2b 32 7d 0a 20 20   b-2 AND d+2}.  
06f0: 7b 64 20 4e 4f 54 20 42 45 54 57 45 45 4e 20 31  {d NOT BETWEEN 1
0700: 31 30 20 41 4e 44 20 31 35 30 7d 0a 20 20 7b 65  10 AND 150}.  {e
0710: 2b 64 20 42 45 54 57 45 45 4e 20 61 2b 62 2d 31  +d BETWEEN a+b-1
0720: 30 20 41 4e 44 20 63 2b 31 33 30 7d 0a 20 20 7b  0 AND c+130}.  {
0730: 28 61 3e 62 2d 32 20 41 4e 44 20 61 3c 62 2b 32  (a>b-2 AND a<b+2
0740: 29 7d 0a 20 20 7b 28 65 3e 61 20 41 4e 44 20 65  )}.  {(e>a AND e
0750: 3c 62 29 7d 0a 20 20 7b 28 63 3c 3d 64 2d 32 20  <b)}.  {(c<=d-2 
0760: 4f 52 20 63 3e 3d 64 2b 32 29 7d 0a 20 20 7b 28  OR c>=d+2)}.  {(
0770: 65 3e 63 20 4f 52 20 65 3c 64 29 7d 0a 20 20 7b  e>c OR e<d)}.  {
0780: 45 58 49 53 54 53 28 53 45 4c 45 43 54 20 31 20  EXISTS(SELECT 1 
0790: 46 52 4f 4d 20 74 31 20 41 53 20 78 20 57 48 45  FROM t1 AS x WHE
07a0: 52 45 20 78 2e 62 3c 74 31 2e 62 29 7d 0a 7d 0a  RE x.b<t1.b)}.}.
07b0: 73 65 74 20 6e 77 65 78 70 72 20 5b 6c 6c 65 6e  set nwexpr [llen
07c0: 67 74 68 20 24 77 65 78 70 72 5d 0a 0a 66 6f 72  gth $wexpr]..for
07d0: 20 7b 73 65 74 20 69 20 30 7d 20 7b 24 69 3c 31   {set i 0} {$i<1
07e0: 30 30 30 7d 20 7b 69 6e 63 72 20 69 7d 20 7b 0a  000} {incr i} {.
07f0: 20 20 73 65 74 20 6e 20 5b 65 78 70 72 20 7b 69    set n [expr {i
0800: 6e 74 28 72 61 6e 64 28 29 2a 37 29 2b 31 7d 5d  nt(rand()*7)+1}]
0810: 0a 20 20 73 65 74 20 72 20 5b 6c 72 61 6e 67 65  .  set r [lrange
0820: 20 5b 73 63 72 61 6d 62 6c 65 20 24 72 65 78 70   [scramble $rexp
0830: 72 5d 20 31 20 24 6e 5d 0a 20 20 73 65 74 20 73  r] 1 $n].  set s
0840: 71 6c 20 22 53 45 4c 45 43 54 20 5b 6a 6f 69 6e  ql "SELECT [join
0850: 20 24 72 20 22 2c 5c 6e 20 20 20 20 20 20 20 22   $r ",\n       "
0860: 5d 5c 6e 20 20 46 52 4f 4d 20 74 31 22 0a 20 20  ]\n  FROM t1".  
0870: 73 65 74 20 6d 20 5b 65 78 70 72 20 7b 69 6e 74  set m [expr {int
0880: 28 72 61 6e 64 28 29 2a 34 29 7d 5d 0a 20 20 69  (rand()*4)}].  i
0890: 66 20 7b 24 6d 3e 30 7d 20 7b 0a 20 20 20 20 73  f {$m>0} {.    s
08a0: 65 74 20 6f 70 20 5b 65 78 70 72 20 7b 72 61 6e  et op [expr {ran
08b0: 64 28 29 3e 30 2e 35 20 3f 20 22 5c 6e 20 20 20  d()>0.5 ? "\n   
08c0: 20 4f 52 20 22 20 3a 20 22 5c 6e 20 20 20 41 4e   OR " : "\n   AN
08d0: 44 20 22 7d 5d 0a 20 20 20 20 73 65 74 20 77 20  D "}].    set w 
08e0: 5b 6c 72 61 6e 67 65 20 5b 73 63 72 61 6d 62 6c  [lrange [scrambl
08f0: 65 20 24 77 65 78 70 72 5d 20 31 20 24 6d 5d 0a  e $wexpr] 1 $m].
0900: 20 20 20 20 61 70 70 65 6e 64 20 73 71 6c 20 22      append sql "
0910: 5c 6e 20 57 48 45 52 45 20 5b 6a 6f 69 6e 20 24  \n WHERE [join $
0920: 77 20 24 6f 70 5d 22 0a 20 20 7d 0a 20 20 69 6e  w $op]".  }.  in
0930: 63 72 20 6e 20 2d 31 0a 20 20 61 70 70 65 6e 64  cr n -1.  append
0940: 20 73 71 6c 20 22 5c 6e 20 4f 52 44 45 52 20 42   sql "\n ORDER B
0950: 59 20 5b 6a 6f 69 6e 20 5b 73 63 72 61 6d 62 6c  Y [join [scrambl
0960: 65 20 5b 6c 72 61 6e 67 65 20 24 73 65 71 75 65  e [lrange $seque
0970: 6e 63 65 20 30 20 24 6e 5d 5d 20 2c 5d 22 0a 20  nce 0 $n]] ,]". 
0980: 20 70 75 74 73 20 22 71 75 65 72 79 20 5b 73 74   puts "query [st
0990: 72 69 6e 67 20 72 61 6e 67 65 20 24 74 79 70 65  ring range $type
09a0: 20 30 20 24 6e 5d 20 6e 6f 73 6f 72 74 22 0a 20   0 $n] nosort". 
09b0: 20 70 75 74 73 20 22 24 73 71 6c 22 0a 20 20 70   puts "$sql".  p
09c0: 75 74 73 20 22 22 0a 7d 0a                       uts "".}.