/ Hex Artifact Content
Login

Artifact 7bc346788390475e77a345da2b92270d04d35856:


0000: 23 20 32 30 31 34 20 4a 75 6c 79 20 31 35 0a 23  # 2014 July 15.#
0010: 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20 64 69  .# The author di
0020: 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68  sclaims copyrigh
0030: 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65  t to this source
0040: 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65   code.  In place
0050: 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f   of.# a legal no
0060: 74 69 63 65 2c 20 68 65 72 65 20 69 73 20 61 20  tice, here is a 
0070: 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20  blessing:.#.#   
0080: 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64   May you do good
0090: 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23   and not evil..#
00a0: 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64      May you find
00b0: 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72   forgiveness for
00c0: 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f   yourself and fo
00d0: 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20  rgive others..# 
00e0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
00f0: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0100: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0110: 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a  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 0a 23 20 54 68 69 73 20 66 69 6c 65  ****.# This file
0170: 20 69 6d 70 6c 65 6d 65 6e 74 73 20 72 65 67 72   implements regr
0180: 65 73 73 69 6f 6e 20 74 65 73 74 73 20 66 6f 72  ession tests for
0190: 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79 2e   SQLite library.
01a0: 0a 23 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20  .#..set testdir 
01b0: 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61  [file dirname $a
01c0: 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65  rgv0].source $te
01d0: 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c  stdir/tester.tcl
01e0: 0a 73 65 74 20 74 65 73 74 70 72 65 66 69 78 20  .set testprefix 
01f0: 63 75 72 73 6f 72 68 69 6e 74 0a 0a 69 66 63 61  cursorhint..ifca
0200: 70 61 62 6c 65 20 21 63 75 72 73 6f 72 68 69 6e  pable !cursorhin
0210: 74 73 20 7b 0a 20 20 66 69 6e 69 73 68 5f 74 65  ts {.  finish_te
0220: 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 64  st.  return.}..d
0230: 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 31  o_execsql_test 1
0240: 2e 30 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41  .0 {.  CREATE TA
0250: 42 4c 45 20 74 31 28 61 2c 62 2c 63 2c 64 29 3b  BLE t1(a,b,c,d);
0260: 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20  .  CREATE TABLE 
0270: 74 32 28 78 2c 79 2c 7a 29 3b 0a 20 20 49 4e 53  t2(x,y,z);.  INS
0280: 45 52 54 20 49 4e 54 4f 20 74 31 28 61 2c 62 29  ERT INTO t1(a,b)
0290: 20 56 41 4c 55 45 53 28 31 30 2c 20 31 35 29 3b   VALUES(10, 15);
02a0: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  .  INSERT INTO t
02b0: 31 28 61 2c 62 29 20 56 41 4c 55 45 53 28 32 30  1(a,b) VALUES(20
02c0: 2c 20 32 35 29 3b 0a 20 20 49 4e 53 45 52 54 20  , 25);.  INSERT 
02d0: 49 4e 54 4f 20 74 32 28 78 2c 79 29 20 56 41 4c  INTO t2(x,y) VAL
02e0: 55 45 53 28 27 74 65 6e 27 2c 20 27 66 69 66 74  UES('ten', 'fift
02f0: 65 65 6e 27 29 3b 0a 20 20 49 4e 53 45 52 54 20  een');.  INSERT 
0300: 49 4e 54 4f 20 74 32 28 78 2c 79 29 20 56 41 4c  INTO t2(x,y) VAL
0310: 55 45 53 28 27 74 77 65 6e 74 79 27 2c 20 27 74  UES('twenty', 't
0320: 77 65 6e 74 79 66 69 76 65 27 29 3b 0a 20 20 43  wentyfive');.  C
0330: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 69  REATE TABLE t3(i
0340: 64 20 54 45 58 54 20 50 52 49 4d 41 52 59 20 4b  d TEXT PRIMARY K
0350: 45 59 2c 20 61 2c 20 62 2c 20 63 2c 20 64 29 20  EY, a, b, c, d) 
0360: 57 49 54 48 4f 55 54 20 52 4f 57 49 44 3b 0a 20  WITHOUT ROWID;. 
0370: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 28   INSERT INTO t3(
0380: 69 64 2c 61 2c 62 2c 63 2c 64 29 20 53 45 4c 45  id,a,b,c,d) SELE
0390: 43 54 20 72 6f 77 69 64 2c 20 61 2c 20 62 2c 20  CT rowid, a, b, 
03a0: 63 2c 20 64 20 46 52 4f 4d 20 74 31 3b 0a 20 20  c, d FROM t1;.  
03b0: 50 52 41 47 4d 41 20 61 75 74 6f 6d 61 74 69 63  PRAGMA automatic
03c0: 5f 69 6e 64 65 78 20 3d 20 30 3b 0a 7d 0a 0a 23  _index = 0;.}..#
03d0: 20 52 75 6e 20 45 58 50 4c 41 49 4e 20 6f 6e 20   Run EXPLAIN on 
03e0: 24 73 71 6c 2e 20 20 52 65 74 75 72 6e 20 61 20  $sql.  Return a 
03f0: 6c 69 73 74 20 6f 66 20 50 34 20 76 61 6c 75 65  list of P4 value
0400: 73 20 66 6f 72 20 61 6c 6c 20 24 6f 70 63 6f 64  s for all $opcod
0410: 65 0a 23 20 6f 70 63 6f 64 65 73 2e 0a 23 0a 70  e.# opcodes..#.p
0420: 72 6f 63 20 70 34 5f 6f 66 5f 6f 70 63 6f 64 65  roc p4_of_opcode
0430: 20 7b 64 62 20 6f 70 63 6f 64 65 20 73 71 6c 7d   {db opcode sql}
0440: 20 7b 0a 20 20 73 65 74 20 72 65 73 20 7b 7d 0a   {.  set res {}.
0450: 20 20 24 64 62 20 65 76 61 6c 20 22 45 58 50 4c    $db eval "EXPL
0460: 41 49 4e 20 24 73 71 6c 22 20 78 20 7b 0a 20 20  AIN $sql" x {.  
0470: 20 20 69 66 20 7b 24 78 28 6f 70 63 6f 64 65 29    if {$x(opcode)
0480: 3d 3d 24 6f 70 63 6f 64 65 7d 20 7b 6c 61 70 70  ==$opcode} {lapp
0490: 65 6e 64 20 72 65 73 20 24 78 28 70 34 29 7d 0a  end res $x(p4)}.
04a0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 24 72 65    }.  return $re
04b0: 73 0a 7d 0a 0a 23 20 52 75 6e 20 45 58 50 4c 41  s.}..# Run EXPLA
04c0: 49 4e 20 6f 6e 20 24 73 71 6c 2e 20 20 52 65 74  IN on $sql.  Ret
04d0: 75 72 6e 20 61 20 6c 69 73 74 20 6f 66 20 50 35  urn a list of P5
04e0: 20 76 61 6c 75 65 73 20 66 6f 72 20 61 6c 6c 20   values for all 
04f0: 24 6f 70 63 6f 64 65 0a 23 20 6f 70 63 6f 64 65  $opcode.# opcode
0500: 73 20 74 68 61 74 20 63 6f 6e 74 61 69 6e 20 72  s that contain r
0510: 65 67 65 78 70 20 24 63 6f 6d 6d 65 6e 74 20 69  egexp $comment i
0520: 6e 20 74 68 65 69 72 20 63 6f 6d 6d 65 6e 74 0a  n their comment.
0530: 23 0a 70 72 6f 63 20 70 35 5f 6f 66 5f 6f 70 63  #.proc p5_of_opc
0540: 6f 64 65 20 7b 64 62 20 6f 70 63 6f 64 65 20 73  ode {db opcode s
0550: 71 6c 7d 20 7b 0a 20 20 73 65 74 20 72 65 73 20  ql} {.  set res 
0560: 7b 7d 0a 20 20 24 64 62 20 65 76 61 6c 20 22 45  {}.  $db eval "E
0570: 58 50 4c 41 49 4e 20 24 73 71 6c 22 20 78 20 7b  XPLAIN $sql" x {
0580: 0a 20 20 20 20 69 66 20 7b 24 78 28 6f 70 63 6f  .    if {$x(opco
0590: 64 65 29 3d 3d 24 6f 70 63 6f 64 65 7d 20 7b 0a  de)==$opcode} {.
05a0: 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65        lappend re
05b0: 73 20 24 78 28 70 35 29 0a 20 20 20 20 7d 0a 20  s $x(p5).    }. 
05c0: 20 7d 0a 20 20 72 65 74 75 72 6e 20 24 72 65 73   }.  return $res
05d0: 0a 7d 0a 0a 23 20 56 65 72 69 66 79 20 74 68 61  .}..# Verify tha
05e0: 74 20 77 68 65 6e 20 74 31 20 69 73 20 69 6e 20  t when t1 is in 
05f0: 74 68 65 20 6f 75 74 65 72 20 6c 6f 6f 70 20 61  the outer loop a
0600: 6e 64 20 74 32 20 69 73 20 69 6e 20 74 68 65 20  nd t2 is in the 
0610: 69 6e 6e 65 72 20 6c 6f 6f 70 2c 0a 23 20 6e 6f  inner loop,.# no
0620: 20 63 75 72 73 6f 72 20 68 69 6e 74 73 20 6f 63   cursor hints oc
0630: 63 75 72 20 66 6f 72 20 74 31 20 28 73 69 6e 63  cur for t1 (sinc
0640: 65 20 69 74 20 69 73 20 61 20 66 75 6c 6c 20 74  e it is a full t
0650: 61 62 6c 65 20 73 63 61 6e 29 20 62 75 74 20 74  able scan) but t
0660: 68 61 74 0a 23 20 65 61 63 68 20 74 32 20 61 63  hat.# each t2 ac
0670: 63 65 73 73 20 68 61 73 20 61 20 63 75 72 73 6f  cess has a curso
0680: 72 20 68 69 6e 74 20 62 61 73 65 64 20 6f 6e 20  r hint based on 
0690: 74 68 65 20 63 75 72 72 65 6e 74 20 74 31 2e 61  the current t1.a
06a0: 20 76 61 6c 75 65 2e 0a 23 0a 64 6f 5f 74 65 73   value..#.do_tes
06b0: 74 20 31 2e 31 20 7b 0a 20 20 70 34 5f 6f 66 5f  t 1.1 {.  p4_of_
06c0: 6f 70 63 6f 64 65 20 64 62 20 43 75 72 73 6f 72  opcode db Cursor
06d0: 48 69 6e 74 20 7b 0a 20 20 20 20 20 53 45 4c 45  Hint {.     SELE
06e0: 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 43 52 4f  CT * FROM t1 CRO
06f0: 53 53 20 4a 4f 49 4e 20 74 32 20 57 48 45 52 45  SS JOIN t2 WHERE
0700: 20 61 3d 78 0a 20 20 7d 0a 7d 20 7b 7b 45 51 28   a=x.  }.} {{EQ(
0710: 72 5b 31 5d 2c 63 30 29 7d 7d 0a 64 6f 5f 74 65  r[1],c0)}}.do_te
0720: 73 74 20 31 2e 32 20 7b 0a 20 20 70 35 5f 6f 66  st 1.2 {.  p5_of
0730: 5f 6f 70 63 6f 64 65 20 64 62 20 4f 70 65 6e 52  _opcode db OpenR
0740: 65 61 64 20 7b 0a 20 20 20 20 20 53 45 4c 45 43  ead {.     SELEC
0750: 54 20 2a 20 46 52 4f 4d 20 74 31 20 43 52 4f 53  T * FROM t1 CROS
0760: 53 20 4a 4f 49 4e 20 74 32 20 57 48 45 52 45 20  S JOIN t2 WHERE 
0770: 61 3d 78 0a 20 20 7d 0a 7d 20 7b 30 30 20 30 30  a=x.  }.} {00 00
0780: 7d 0a 0a 23 20 44 6f 20 74 68 65 20 73 61 6d 65  }..# Do the same
0790: 20 74 65 73 74 20 74 68 65 20 6f 74 68 65 72 20   test the other 
07a0: 77 61 79 20 61 72 6f 75 6e 64 2e 0a 23 0a 64 6f  way around..#.do
07b0: 5f 74 65 73 74 20 32 2e 31 20 7b 0a 20 20 70 34  _test 2.1 {.  p4
07c0: 5f 6f 66 5f 6f 70 63 6f 64 65 20 64 62 20 43 75  _of_opcode db Cu
07d0: 72 73 6f 72 48 69 6e 74 20 7b 0a 20 20 20 20 20  rsorHint {.     
07e0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32  SELECT * FROM t2
07f0: 20 43 52 4f 53 53 20 4a 4f 49 4e 20 74 31 20 57   CROSS JOIN t1 W
0800: 48 45 52 45 20 61 3d 78 0a 20 20 7d 0a 7d 20 7b  HERE a=x.  }.} {
0810: 7b 45 51 28 63 30 2c 72 5b 31 5d 29 7d 7d 0a 64  {EQ(c0,r[1])}}.d
0820: 6f 5f 74 65 73 74 20 32 2e 32 20 7b 0a 20 20 70  o_test 2.2 {.  p
0830: 35 5f 6f 66 5f 6f 70 63 6f 64 65 20 64 62 20 4f  5_of_opcode db O
0840: 70 65 6e 52 65 61 64 20 7b 0a 20 20 20 20 20 53  penRead {.     S
0850: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 20  ELECT * FROM t2 
0860: 43 52 4f 53 53 20 4a 4f 49 4e 20 74 31 20 57 48  CROSS JOIN t1 WH
0870: 45 52 45 20 61 3d 78 0a 20 20 7d 0a 7d 20 7b 30  ERE a=x.  }.} {0
0880: 30 20 30 30 7d 0a 0a 23 20 56 61 72 69 6f 75 73  0 00}..# Various
0890: 20 65 78 70 72 65 73 73 69 6f 6e 73 20 63 61 70   expressions cap
08a0: 74 75 72 65 64 20 62 79 20 43 75 72 73 6f 72 48  tured by CursorH
08b0: 69 6e 74 0a 23 0a 64 6f 5f 74 65 73 74 20 33 2e  int.#.do_test 3.
08c0: 31 20 7b 0a 20 20 70 34 5f 6f 66 5f 6f 70 63 6f  1 {.  p4_of_opco
08d0: 64 65 20 64 62 20 43 75 72 73 6f 72 48 69 6e 74  de db CursorHint
08e0: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
08f0: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 61 3d  FROM t1 WHERE a=
0900: 31 35 20 41 4e 44 20 63 3d 32 32 20 41 4e 44 20  15 AND c=22 AND 
0910: 72 6f 77 69 64 21 3d 39 38 0a 20 20 7d 0a 7d 20  rowid!=98.  }.} 
0920: 7b 41 4e 44 28 41 4e 44 28 45 51 28 63 30 2c 31  {AND(AND(EQ(c0,1
0930: 35 29 2c 45 51 28 63 32 2c 32 32 29 29 2c 4e 45  5),EQ(c2,22)),NE
0940: 28 72 6f 77 69 64 2c 39 38 29 29 7d 0a 64 6f 5f  (rowid,98))}.do_
0950: 74 65 73 74 20 33 2e 32 20 7b 0a 20 20 70 34 5f  test 3.2 {.  p4_
0960: 6f 66 5f 6f 70 63 6f 64 65 20 64 62 20 43 75 72  of_opcode db Cur
0970: 73 6f 72 48 69 6e 74 20 7b 0a 20 20 20 20 53 45  sorHint {.    SE
0980: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 33 20 57  LECT * FROM t3 W
0990: 48 45 52 45 20 61 3c 31 35 20 41 4e 44 20 62 3e  HERE a<15 AND b>
09a0: 32 32 20 41 4e 44 20 69 64 21 3d 39 38 0a 20 20  22 AND id!=98.  
09b0: 7d 0a 7d 20 7b 41 4e 44 28 41 4e 44 28 4c 54 28  }.} {AND(AND(LT(
09c0: 63 31 2c 31 35 29 2c 47 54 28 63 32 2c 32 32 29  c1,15),GT(c2,22)
09d0: 29 2c 4e 45 28 63 30 2c 39 38 29 29 7d 0a 0a 23  ),NE(c0,98))}..#
09e0: 20 49 6e 64 65 78 65 64 20 71 75 65 72 69 65 73   Indexed queries
09f0: 0a 23 0a 64 6f 5f 74 65 73 74 20 34 2e 31 61 73  .#.do_test 4.1as
0a00: 63 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 0a  c {.  db eval {.
0a10: 20 20 20 20 43 52 45 41 54 45 20 49 4e 44 45 58      CREATE INDEX
0a20: 20 74 31 62 63 20 4f 4e 20 74 31 28 62 2c 63 29   t1bc ON t1(b,c)
0a30: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 49 4e 44  ;.    CREATE IND
0a40: 45 58 20 74 32 79 7a 20 4f 4e 20 74 32 28 79 2c  EX t2yz ON t2(y,
0a50: 7a 29 3b 0a 20 20 7d 0a 20 20 70 34 5f 6f 66 5f  z);.  }.  p4_of_
0a60: 6f 70 63 6f 64 65 20 64 62 20 43 75 72 73 6f 72  opcode db Cursor
0a70: 48 69 6e 74 20 7b 0a 20 20 20 20 53 45 4c 45 43  Hint {.    SELEC
0a80: 54 20 2a 20 46 52 4f 4d 20 74 31 20 57 48 45 52  T * FROM t1 WHER
0a90: 45 20 62 3e 31 31 20 4f 52 44 45 52 20 42 59 20  E b>11 ORDER BY 
0aa0: 62 20 41 53 43 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  b ASC;.  }.} {}.
0ab0: 64 6f 5f 74 65 73 74 20 34 2e 31 64 65 73 63 20  do_test 4.1desc 
0ac0: 7b 0a 20 20 70 34 5f 6f 66 5f 6f 70 63 6f 64 65  {.  p4_of_opcode
0ad0: 20 64 62 20 43 75 72 73 6f 72 48 69 6e 74 20 7b   db CursorHint {
0ae0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
0af0: 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3e 31 31  OM t1 WHERE b>11
0b00: 20 4f 52 44 45 52 20 42 59 20 62 20 44 45 53 43   ORDER BY b DESC
0b10: 3b 0a 20 20 7d 0a 7d 20 7b 47 54 28 63 30 2c 31  ;.  }.} {GT(c0,1
0b20: 31 29 7d 0a 64 6f 5f 74 65 73 74 20 34 2e 32 20  1)}.do_test 4.2 
0b30: 7b 0a 20 20 70 35 5f 6f 66 5f 6f 70 63 6f 64 65  {.  p5_of_opcode
0b40: 20 64 62 20 4f 70 65 6e 52 65 61 64 20 7b 0a 20   db OpenRead {. 
0b50: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0b60: 20 74 31 20 57 48 45 52 45 20 62 3e 31 31 3b 0a   t1 WHERE b>11;.
0b70: 20 20 7d 0a 7d 20 7b 30 32 20 30 30 7d 0a 64 6f    }.} {02 00}.do
0b80: 5f 74 65 73 74 20 34 2e 33 61 73 63 20 7b 0a 20  _test 4.3asc {. 
0b90: 20 70 34 5f 6f 66 5f 6f 70 63 6f 64 65 20 64 62   p4_of_opcode db
0ba0: 20 43 75 72 73 6f 72 48 69 6e 74 20 7b 0a 20 20   CursorHint {.  
0bb0: 20 20 53 45 4c 45 43 54 20 63 20 46 52 4f 4d 20    SELECT c FROM 
0bc0: 74 31 20 57 48 45 52 45 20 62 3c 31 31 20 4f 52  t1 WHERE b<11 OR
0bd0: 44 45 52 20 42 59 20 62 20 41 53 43 3b 0a 20 20  DER BY b ASC;.  
0be0: 7d 0a 7d 20 7b 4c 54 28 63 30 2c 31 31 29 7d 0a  }.} {LT(c0,11)}.
0bf0: 64 6f 5f 74 65 73 74 20 34 2e 33 64 65 73 63 20  do_test 4.3desc 
0c00: 7b 0a 20 20 70 34 5f 6f 66 5f 6f 70 63 6f 64 65  {.  p4_of_opcode
0c10: 20 64 62 20 43 75 72 73 6f 72 48 69 6e 74 20 7b   db CursorHint {
0c20: 0a 20 20 20 20 53 45 4c 45 43 54 20 63 20 46 52  .    SELECT c FR
0c30: 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3c 31 31  OM t1 WHERE b<11
0c40: 20 4f 52 44 45 52 20 42 59 20 62 20 44 45 53 43   ORDER BY b DESC
0c50: 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  ;.  }.} {}.do_te
0c60: 73 74 20 34 2e 34 20 7b 0a 20 20 70 35 5f 6f 66  st 4.4 {.  p5_of
0c70: 5f 6f 70 63 6f 64 65 20 64 62 20 4f 70 65 6e 52  _opcode db OpenR
0c80: 65 61 64 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  ead {.    SELECT
0c90: 20 63 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45   c FROM t1 WHERE
0ca0: 20 62 3c 31 31 3b 0a 20 20 7d 0a 7d 20 7b 30 30   b<11;.  }.} {00
0cb0: 7d 0a 0a 64 6f 5f 74 65 73 74 20 34 2e 35 61 73  }..do_test 4.5as
0cc0: 63 20 7b 0a 20 20 70 34 5f 6f 66 5f 6f 70 63 6f  c {.  p4_of_opco
0cd0: 64 65 20 64 62 20 43 75 72 73 6f 72 48 69 6e 74  de db CursorHint
0ce0: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 63 20   {.    SELECT c 
0cf0: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3e  FROM t1 WHERE b>
0d00: 3d 31 30 20 41 4e 44 20 62 3c 3d 32 30 20 4f 52  =10 AND b<=20 OR
0d10: 44 45 52 20 42 59 20 62 20 41 53 43 3b 0a 20 20  DER BY b ASC;.  
0d20: 7d 0a 7d 20 7b 4c 45 28 63 30 2c 32 30 29 7d 0a  }.} {LE(c0,20)}.
0d30: 64 6f 5f 74 65 73 74 20 34 2e 35 64 65 73 63 20  do_test 4.5desc 
0d40: 7b 0a 20 20 70 34 5f 6f 66 5f 6f 70 63 6f 64 65  {.  p4_of_opcode
0d50: 20 64 62 20 43 75 72 73 6f 72 48 69 6e 74 20 7b   db CursorHint {
0d60: 0a 20 20 20 20 53 45 4c 45 43 54 20 63 20 46 52  .    SELECT c FR
0d70: 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3e 3d 31  OM t1 WHERE b>=1
0d80: 30 20 41 4e 44 20 62 3c 3d 32 30 20 4f 52 44 45  0 AND b<=20 ORDE
0d90: 52 20 42 59 20 62 20 44 45 53 43 3b 0a 20 20 7d  R BY b DESC;.  }
0da0: 0a 7d 20 7b 47 45 28 63 30 2c 31 30 29 7d 0a 0a  .} {GE(c0,10)}..
0db0: 23 20 49 66 20 74 68 65 72 65 20 61 72 65 20 61  # If there are a
0dc0: 6e 79 20 65 71 75 61 6c 69 74 79 20 74 65 72 6d  ny equality term
0dd0: 73 20 75 73 65 64 20 69 6e 20 74 68 65 20 63 6f  s used in the co
0de0: 6e 73 74 72 61 69 6e 74 2c 20 74 68 65 6e 20 61  nstraint, then a
0df0: 6c 6c 20 74 65 72 6d 73 0a 23 20 73 68 6f 75 6c  ll terms.# shoul
0e00: 64 20 62 65 20 68 69 6e 74 65 64 2e 0a 23 0a 64  d be hinted..#.d
0e10: 6f 5f 74 65 73 74 20 34 2e 36 61 73 63 20 7b 0a  o_test 4.6asc {.
0e20: 20 20 70 34 5f 6f 66 5f 6f 70 63 6f 64 65 20 64    p4_of_opcode d
0e30: 62 20 43 75 72 73 6f 72 48 69 6e 74 20 7b 0a 20  b CursorHint {. 
0e40: 20 20 20 53 45 4c 45 43 54 20 72 6f 77 69 64 20     SELECT rowid 
0e50: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3d  FROM t1 WHERE b=
0e60: 32 32 20 41 4e 44 20 63 3e 3d 31 30 20 41 4e 44  22 AND c>=10 AND
0e70: 20 63 3c 3d 32 30 20 4f 52 44 45 52 20 42 59 20   c<=20 ORDER BY 
0e80: 62 2c 63 20 41 53 43 3b 0a 20 20 7d 0a 7d 20 7b  b,c ASC;.  }.} {
0e90: 41 4e 44 28 41 4e 44 28 45 51 28 63 30 2c 32 32  AND(AND(EQ(c0,22
0ea0: 29 2c 47 45 28 63 31 2c 31 30 29 29 2c 4c 45 28  ),GE(c1,10)),LE(
0eb0: 63 31 2c 32 30 29 29 7d 0a 64 6f 5f 74 65 73 74  c1,20))}.do_test
0ec0: 20 34 2e 36 64 65 73 63 20 7b 0a 20 20 70 34 5f   4.6desc {.  p4_
0ed0: 6f 66 5f 6f 70 63 6f 64 65 20 64 62 20 43 75 72  of_opcode db Cur
0ee0: 73 6f 72 48 69 6e 74 20 7b 0a 20 20 20 20 53 45  sorHint {.    SE
0ef0: 4c 45 43 54 20 72 6f 77 69 64 20 46 52 4f 4d 20  LECT rowid FROM 
0f00: 74 31 20 57 48 45 52 45 20 62 3d 32 32 20 41 4e  t1 WHERE b=22 AN
0f10: 44 20 63 3e 3d 31 30 20 41 4e 44 20 63 3c 3d 32  D c>=10 AND c<=2
0f20: 30 20 4f 52 44 45 52 20 42 59 20 62 2c 63 20 44  0 ORDER BY b,c D
0f30: 45 53 43 3b 0a 20 20 7d 0a 7d 20 7b 41 4e 44 28  ESC;.  }.} {AND(
0f40: 41 4e 44 28 45 51 28 63 30 2c 32 32 29 2c 47 45  AND(EQ(c0,22),GE
0f50: 28 63 31 2c 31 30 29 29 2c 4c 45 28 63 31 2c 32  (c1,10)),LE(c1,2
0f60: 30 29 29 7d 0a 0a 66 69 6e 69 73 68 5f 74 65 73  0))}..finish_tes
0f70: 74 0a                                            t.