/ Hex Artifact Content
Login

Artifact e24553116e482a94e9cd22a4eea4909b1c6ed1c6:


0000: 23 20 32 30 30 32 20 46 65 62 72 75 61 72 79 20  # 2002 February 
0010: 32 36 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  26.#.# 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 0a 23 20 54 68 69 73 20  ********.# This 
0170: 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20  file implements 
0180: 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73  regression tests
0190: 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62 72   for SQLite libr
01a0: 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f 63 75  ary.  The.# focu
01b0: 73 20 6f 66 20 74 68 69 73 20 66 69 6c 65 20 69  s of this file i
01c0: 73 20 74 65 73 74 69 6e 67 20 56 49 45 57 20 73  s testing VIEW s
01d0: 74 61 74 65 6d 65 6e 74 73 2e 0a 23 0a 23 20 24  tatements..#.# $
01e0: 49 64 3a 20 76 69 65 77 2e 74 65 73 74 2c 76 20  Id: view.test,v 
01f0: 31 2e 32 35 20 32 30 30 35 2f 30 36 2f 30 36 20  1.25 2005/06/06 
0200: 31 35 3a 33 32 3a 30 38 20 64 72 68 20 45 78 70  15:32:08 drh Exp
0210: 20 24 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b   $.set testdir [
0220: 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72  file dirname $ar
0230: 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73  gv0].source $tes
0240: 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a  tdir/tester.tcl.
0250: 0a 23 20 4f 6d 69 74 20 74 68 69 73 20 65 6e 74  .# Omit this ent
0260: 69 72 65 20 66 69 6c 65 20 69 66 20 74 68 65 20  ire file if the 
0270: 6c 69 62 72 61 72 79 20 69 73 20 6e 6f 74 20 63  library is not c
0280: 6f 6e 66 69 67 75 72 65 64 20 77 69 74 68 20 76  onfigured with v
0290: 69 65 77 73 20 65 6e 61 62 6c 65 64 2e 0a 69 66  iews enabled..if
02a0: 63 61 70 61 62 6c 65 20 21 76 69 65 77 20 7b 0a  capable !view {.
02b0: 20 20 66 69 6e 69 73 68 5f 74 65 73 74 0a 20 20    finish_test.  
02c0: 72 65 74 75 72 6e 0a 7d 0a 0a 64 6f 5f 74 65 73  return.}..do_tes
02d0: 74 20 76 69 65 77 2d 31 2e 30 20 7b 0a 20 20 65  t view-1.0 {.  e
02e0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
02f0: 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 62  ATE TABLE t1(a,b
0300: 2c 63 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  ,c);.    INSERT 
0310: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31  INTO t1 VALUES(1
0320: 2c 32 2c 33 29 3b 0a 20 20 20 20 49 4e 53 45 52  ,2,3);.    INSER
0330: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
0340: 28 34 2c 35 2c 36 29 3b 0a 20 20 20 20 49 4e 53  (4,5,6);.    INS
0350: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
0360: 45 53 28 37 2c 38 2c 39 29 3b 0a 20 20 20 20 53  ES(7,8,9);.    S
0370: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 3b  ELECT * FROM t1;
0380: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 20 34 20  .  }.} {1 2 3 4 
0390: 35 20 36 20 37 20 38 20 39 7d 0a 0a 64 6f 5f 74  5 6 7 8 9}..do_t
03a0: 65 73 74 20 76 69 65 77 2d 31 2e 31 20 7b 0a 20  est view-1.1 {. 
03b0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 42   execsql {.    B
03c0: 45 47 49 4e 3b 0a 20 20 20 20 43 52 45 41 54 45  EGIN;.    CREATE
03d0: 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c 45   VIEW v1 AS SELE
03e0: 43 54 20 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a  CT a,b FROM t1;.
03f0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0400: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
0410: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35 20  .  }.} {1 2 4 5 
0420: 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  7 8}.do_test vie
0430: 77 2d 31 2e 32 20 7b 0a 20 20 63 61 74 63 68 73  w-1.2 {.  catchs
0440: 71 6c 20 7b 0a 20 20 20 20 52 4f 4c 4c 42 41 43  ql {.    ROLLBAC
0450: 4b 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  K;.    SELECT * 
0460: 46 52 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59  FROM v1 ORDER BY
0470: 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f   a;.  }.} {1 {no
0480: 20 73 75 63 68 20 74 61 62 6c 65 3a 20 76 31 7d   such table: v1}
0490: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  }.do_test view-1
04a0: 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .3 {.  execsql {
04b0: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
04c0: 20 76 31 20 41 53 20 53 45 4c 45 43 54 20 61 2c   v1 AS SELECT a,
04d0: 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53  b FROM t1;.    S
04e0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20  ELECT * FROM v1 
04f0: 4f 52 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a  ORDER BY a;.  }.
0500: 7d 20 7b 31 20 32 20 34 20 35 20 37 20 38 7d 0a  } {1 2 4 5 7 8}.
0510: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 33  do_test view-1.3
0520: 2e 31 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  .1 {.  db close.
0530: 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73    sqlite3 db tes
0540: 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b  t.db.  execsql {
0550: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
0560: 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61  OM v1 ORDER BY a
0570: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35  ;.  }.} {1 2 4 5
0580: 20 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69   7 8}.do_test vi
0590: 65 77 2d 31 2e 34 20 7b 0a 20 20 63 61 74 63 68  ew-1.4 {.  catch
05a0: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56  sql {.    DROP V
05b0: 49 45 57 20 76 31 3b 0a 20 20 20 20 53 45 4c 45  IEW v1;.    SELE
05c0: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
05d0: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
05e0: 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c 65  1 {no such table
05f0: 3a 20 76 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76  : v1}}.do_test v
0600: 69 65 77 2d 31 2e 35 20 7b 0a 20 20 65 78 65 63  iew-1.5 {.  exec
0610: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
0620: 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c 45   VIEW v1 AS SELE
0630: 43 54 20 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a  CT a,b FROM t1;.
0640: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0650: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
0660: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35 20  .  }.} {1 2 4 5 
0670: 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  7 8}.do_test vie
0680: 77 2d 31 2e 36 20 7b 0a 20 20 63 61 74 63 68 73  w-1.6 {.  catchs
0690: 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41  ql {.    DROP TA
06a0: 42 4c 45 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  BLE t1;.    SELE
06b0: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
06c0: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
06d0: 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c 65  1 {no such table
06e0: 3a 20 6d 61 69 6e 2e 74 31 7d 7d 0a 64 6f 5f 74  : main.t1}}.do_t
06f0: 65 73 74 20 76 69 65 77 2d 31 2e 37 20 7b 0a 20  est view-1.7 {. 
0700: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
0710: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 78  REATE TABLE t1(x
0720: 2c 61 2c 62 2c 63 29 3b 0a 20 20 20 20 49 4e 53  ,a,b,c);.    INS
0730: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
0740: 45 53 28 31 2c 32 2c 33 2c 34 29 3b 0a 20 20 20  ES(1,2,3,4);.   
0750: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0760: 56 41 4c 55 45 53 28 34 2c 35 2c 36 2c 37 29 3b  VALUES(4,5,6,7);
0770: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0780: 20 74 31 20 56 41 4c 55 45 53 28 37 2c 38 2c 39   t1 VALUES(7,8,9
0790: 2c 31 30 29 3b 0a 20 20 20 20 53 45 4c 45 43 54  ,10);.    SELECT
07a0: 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45 52   * FROM v1 ORDER
07b0: 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 32 20   BY a;.  }.} {2 
07c0: 33 20 35 20 36 20 38 20 39 7d 0a 64 6f 5f 74 65  3 5 6 8 9}.do_te
07d0: 73 74 20 76 69 65 77 2d 31 2e 38 20 7b 0a 20 20  st view-1.8 {.  
07e0: 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74  db close.  sqlit
07f0: 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20  e3 db test.db.  
0800: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
0810: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f  LECT * FROM v1 O
0820: 52 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d  RDER BY a;.  }.}
0830: 20 7b 32 20 33 20 35 20 36 20 38 20 39 7d 0a 0a   {2 3 5 6 8 9}..
0840: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 31  do_test view-2.1
0850: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
0860: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
0870: 32 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52  2 AS SELECT * FR
0880: 4f 4d 20 74 31 20 57 48 45 52 45 20 61 3e 35 0a  OM t1 WHERE a>5.
0890: 20 20 7d 3b 20 20 23 20 4e 6f 20 73 65 6d 69 63    };  # No semic
08a0: 6f 6c 6f 6e 0a 20 20 65 78 65 63 73 71 6c 32 20  olon.  execsql2 
08b0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
08c0: 52 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 78  ROM v2;.  }.} {x
08d0: 20 37 20 61 20 38 20 62 20 39 20 63 20 31 30 7d   7 a 8 b 9 c 10}
08e0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e  .do_test view-2.
08f0: 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  2 {.  catchsql {
0900: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0910: 20 76 32 20 56 41 4c 55 45 53 28 31 2c 32 2c 33   v2 VALUES(1,2,3
0920: 2c 34 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 63  ,4);.  }.} {1 {c
0930: 61 6e 6e 6f 74 20 6d 6f 64 69 66 79 20 76 32 20  annot modify v2 
0940: 62 65 63 61 75 73 65 20 69 74 20 69 73 20 61 20  because it is a 
0950: 76 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76  view}}.do_test v
0960: 69 65 77 2d 32 2e 33 20 7b 0a 20 20 63 61 74 63  iew-2.3 {.  catc
0970: 68 73 71 6c 20 7b 0a 20 20 20 20 55 50 44 41 54  hsql {.    UPDAT
0980: 45 20 76 32 20 53 45 54 20 61 3d 31 30 20 57 48  E v2 SET a=10 WH
0990: 45 52 45 20 61 3d 35 3b 0a 20 20 7d 0a 7d 20 7b  ERE a=5;.  }.} {
09a0: 31 20 7b 63 61 6e 6e 6f 74 20 6d 6f 64 69 66 79  1 {cannot modify
09b0: 20 76 32 20 62 65 63 61 75 73 65 20 69 74 20 69   v2 because it i
09c0: 73 20 61 20 76 69 65 77 7d 7d 0a 64 6f 5f 74 65  s a view}}.do_te
09d0: 73 74 20 76 69 65 77 2d 32 2e 34 20 7b 0a 20 20  st view-2.4 {.  
09e0: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 44  catchsql {.    D
09f0: 45 4c 45 54 45 20 46 52 4f 4d 20 76 32 3b 0a 20  ELETE FROM v2;. 
0a00: 20 7d 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20   }.} {1 {cannot 
0a10: 6d 6f 64 69 66 79 20 76 32 20 62 65 63 61 75 73  modify v2 becaus
0a20: 65 20 69 74 20 69 73 20 61 20 76 69 65 77 7d 7d  e it is a view}}
0a30: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e  .do_test view-2.
0a40: 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  5 {.  execsql {.
0a50: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0a60: 74 31 20 56 41 4c 55 45 53 28 31 31 2c 31 32 2c  t1 VALUES(11,12,
0a70: 31 33 2c 31 34 29 3b 0a 20 20 20 20 53 45 4c 45  13,14);.    SELE
0a80: 43 54 20 2a 20 46 52 4f 4d 20 76 32 20 4f 52 44  CT * FROM v2 ORD
0a90: 45 52 20 42 59 20 78 3b 0a 20 20 7d 0a 7d 20 7b  ER BY x;.  }.} {
0aa0: 37 20 38 20 39 20 31 30 20 31 31 20 31 32 20 31  7 8 9 10 11 12 1
0ab0: 33 20 31 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69  3 14}.do_test vi
0ac0: 65 77 2d 32 2e 36 20 7b 0a 20 20 65 78 65 63 73  ew-2.6 {.  execs
0ad0: 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  ql {.    SELECT 
0ae0: 78 20 46 52 4f 4d 20 76 32 20 57 48 45 52 45 20  x FROM v2 WHERE 
0af0: 61 3e 31 30 0a 20 20 7d 0a 7d 20 7b 31 31 7d 0a  a>10.  }.} {11}.
0b00: 0a 23 20 54 65 73 74 20 74 68 61 74 20 63 6f 6c  .# Test that col
0b10: 75 6d 6e 20 6e 61 6d 65 20 6f 66 20 76 69 65 77  umn name of view
0b20: 73 20 61 72 65 20 67 65 6e 65 72 61 74 65 64 20  s are generated 
0b30: 63 6f 72 72 65 63 74 6c 79 2e 0a 23 0a 64 6f 5f  correctly..#.do_
0b40: 74 65 73 74 20 76 69 65 77 2d 33 2e 31 20 7b 0a  test view-3.1 {.
0b50: 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20    execsql2 {.   
0b60: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
0b70: 31 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a 7d 20  1 LIMIT 1.  }.} 
0b80: 7b 61 20 32 20 62 20 33 7d 0a 64 6f 5f 74 65 73  {a 2 b 3}.do_tes
0b90: 74 20 76 69 65 77 2d 33 2e 32 20 7b 0a 20 20 65  t view-3.2 {.  e
0ba0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45  xecsql2 {.    SE
0bb0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 20 4c  LECT * FROM v2 L
0bc0: 49 4d 49 54 20 31 0a 20 20 7d 0a 7d 20 7b 78 20  IMIT 1.  }.} {x 
0bd0: 37 20 61 20 38 20 62 20 39 20 63 20 31 30 7d 0a  7 a 8 b 9 c 10}.
0be0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33 2e 33  do_test view-3.3
0bf0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a   {.  execsql2 {.
0c00: 20 20 20 20 44 52 4f 50 20 56 49 45 57 20 76 31      DROP VIEW v1
0c10: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
0c20: 57 20 76 31 20 41 53 20 53 45 4c 45 43 54 20 61  W v1 AS SELECT a
0c30: 20 41 53 20 27 78 79 7a 27 2c 20 62 2b 63 20 41   AS 'xyz', b+c A
0c40: 53 20 27 70 71 72 27 2c 20 63 2d 62 20 46 52 4f  S 'pqr', c-b FRO
0c50: 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54  M t1;.    SELECT
0c60: 20 2a 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54   * FROM v1 LIMIT
0c70: 20 31 0a 20 20 7d 0a 7d 20 7b 78 79 7a 20 32 20   1.  }.} {xyz 2 
0c80: 70 71 72 20 37 20 63 2d 62 20 31 7d 0a 0a 69 66  pqr 7 c-b 1}..if
0c90: 63 61 70 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64  capable compound
0ca0: 20 7b 0a 64 6f 5f 74 65 73 74 20 20 76 69 65 77   {.do_test  view
0cb0: 2d 33 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.4 {.  execsql
0cc0: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
0cd0: 49 45 57 20 76 33 20 41 53 20 53 45 4c 45 43 54  IEW v3 AS SELECT
0ce0: 20 61 20 46 52 4f 4d 20 74 31 20 55 4e 49 4f 4e   a FROM t1 UNION
0cf0: 20 53 45 4c 45 43 54 20 62 20 46 52 4f 4d 20 74   SELECT b FROM t
0d00: 31 20 4f 52 44 45 52 20 42 59 20 62 3b 0a 20 20  1 ORDER BY b;.  
0d10: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0d20: 76 33 20 4c 49 4d 49 54 20 34 3b 0a 20 20 7d 0a  v3 LIMIT 4;.  }.
0d30: 7d 20 7b 62 20 32 20 62 20 33 20 62 20 35 20 62  } {b 2 b 3 b 5 b
0d40: 20 36 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   6}.do_test view
0d50: 2d 33 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.5 {.  execsql
0d60: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
0d70: 49 45 57 20 76 34 20 41 53 20 0a 20 20 20 20 20  IEW v4 AS .     
0d80: 20 53 45 4c 45 43 54 20 61 2c 20 62 20 46 52 4f   SELECT a, b FRO
0d90: 4d 20 74 31 20 0a 20 20 20 20 20 20 55 4e 49 4f  M t1 .      UNIO
0da0: 4e 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 62  N.      SELECT b
0db0: 20 41 53 20 27 78 27 2c 20 61 20 41 53 20 27 79   AS 'x', a AS 'y
0dc0: 27 20 46 52 4f 4d 20 74 31 0a 20 20 20 20 20 20  ' FROM t1.      
0dd0: 4f 52 44 45 52 20 42 59 20 78 2c 20 79 3b 0a 20  ORDER BY x, y;. 
0de0: 20 20 20 53 45 4c 45 43 54 20 79 20 46 52 4f 4d     SELECT y FROM
0df0: 20 76 34 20 4f 52 44 45 52 20 42 59 20 79 20 4c   v4 ORDER BY y L
0e00: 49 4d 49 54 20 34 3b 0a 20 20 7d 0a 7d 20 7b 79  IMIT 4;.  }.} {y
0e10: 20 32 20 79 20 33 20 79 20 35 20 79 20 36 7d 0a   2 y 3 y 5 y 6}.
0e20: 7d 20 3b 23 20 69 66 63 61 70 61 62 6c 65 20 63  } ;# ifcapable c
0e30: 6f 6d 70 6f 75 6e 64 0a 0a 0a 64 6f 5f 74 65 73  ompound...do_tes
0e40: 74 20 76 69 65 77 2d 34 2e 31 20 7b 0a 20 20 63  t view-4.1 {.  c
0e50: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 44 52  atchsql {.    DR
0e60: 4f 50 20 56 49 45 57 20 74 31 3b 0a 20 20 7d 0a  OP VIEW t1;.  }.
0e70: 7d 20 7b 31 20 7b 75 73 65 20 44 52 4f 50 20 54  } {1 {use DROP T
0e80: 41 42 4c 45 20 74 6f 20 64 65 6c 65 74 65 20 74  ABLE to delete t
0e90: 61 62 6c 65 20 74 31 7d 7d 0a 64 6f 5f 74 65 73  able t1}}.do_tes
0ea0: 74 20 76 69 65 77 2d 34 2e 32 20 7b 0a 20 20 65  t view-4.2 {.  e
0eb0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
0ec0: 45 43 54 20 31 20 46 52 4f 4d 20 74 31 20 4c 49  ECT 1 FROM t1 LI
0ed0: 4d 49 54 20 31 3b 0a 20 20 7d 0a 7d 20 31 0a 64  MIT 1;.  }.} 1.d
0ee0: 6f 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 33 20  o_test view-4.3 
0ef0: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
0f00: 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 76 31     DROP TABLE v1
0f10: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73 65 20  ;.  }.} {1 {use 
0f20: 44 52 4f 50 20 56 49 45 57 20 74 6f 20 64 65 6c  DROP VIEW to del
0f30: 65 74 65 20 76 69 65 77 20 76 31 7d 7d 0a 64 6f  ete view v1}}.do
0f40: 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 34 20 7b  _test view-4.4 {
0f50: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0f60: 20 20 53 45 4c 45 43 54 20 31 20 46 52 4f 4d 20    SELECT 1 FROM 
0f70: 76 31 20 4c 49 4d 49 54 20 31 3b 0a 20 20 7d 0a  v1 LIMIT 1;.  }.
0f80: 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69  } {1}.do_test vi
0f90: 65 77 2d 34 2e 35 20 7b 0a 20 20 63 61 74 63 68  ew-4.5 {.  catch
0fa0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
0fb0: 20 49 4e 44 45 58 20 69 31 76 31 20 4f 4e 20 76   INDEX i1v1 ON v
0fc0: 31 28 78 79 7a 29 3b 0a 20 20 7d 0a 7d 20 7b 31  1(xyz);.  }.} {1
0fd0: 20 7b 76 69 65 77 73 20 6d 61 79 20 6e 6f 74 20   {views may not 
0fe0: 62 65 20 69 6e 64 65 78 65 64 7d 7d 0a 0a 64 6f  be indexed}}..do
0ff0: 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 31 20 7b  _test view-5.1 {
1000: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1010: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
1020: 28 79 2c 61 29 3b 0a 20 20 20 20 49 4e 53 45 52  (y,a);.    INSER
1030: 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53  T INTO t2 VALUES
1040: 28 32 32 2c 32 29 3b 0a 20 20 20 20 49 4e 53 45  (22,2);.    INSE
1050: 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45  RT INTO t2 VALUE
1060: 53 28 33 33 2c 33 29 3b 0a 20 20 20 20 49 4e 53  S(33,3);.    INS
1070: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
1080: 45 53 28 34 34 2c 34 29 3b 0a 20 20 20 20 49 4e  ES(44,4);.    IN
1090: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
10a0: 55 45 53 28 35 35 2c 35 29 3b 0a 20 20 20 20 53  UES(55,5);.    S
10b0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b  ELECT * FROM t2;
10c0: 0a 20 20 7d 0a 7d 20 7b 32 32 20 32 20 33 33 20  .  }.} {22 2 33 
10d0: 33 20 34 34 20 34 20 35 35 20 35 7d 0a 64 6f 5f  3 44 4 55 5}.do_
10e0: 74 65 73 74 20 76 69 65 77 2d 35 2e 32 20 7b 0a  test view-5.2 {.
10f0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1100: 43 52 45 41 54 45 20 56 49 45 57 20 76 35 20 41  CREATE VIEW v5 A
1110: 53 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 74  S.      SELECT t
1120: 31 2e 78 20 41 53 20 76 2c 20 74 32 2e 79 20 41  1.x AS v, t2.y A
1130: 53 20 77 20 46 52 4f 4d 20 74 31 20 4a 4f 49 4e  S w FROM t1 JOIN
1140: 20 74 32 20 55 53 49 4e 47 28 61 29 3b 0a 20 20   t2 USING(a);.  
1150: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1160: 76 35 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 32 20  v5;.  }.} {1 22 
1170: 34 20 35 35 7d 0a 0a 23 20 56 65 72 69 66 79 20  4 55}..# Verify 
1180: 74 68 61 74 20 74 68 65 20 76 69 65 77 20 76 35  that the view v5
1190: 20 67 65 74 73 20 66 6c 61 74 74 65 6e 65 64 2e   gets flattened.
11a0: 20 20 73 65 65 20 73 71 6c 69 74 65 46 6c 61 74    see sqliteFlat
11b0: 74 65 6e 53 75 62 71 75 65 72 79 28 29 2e 0a 23  tenSubquery()..#
11c0: 20 54 68 69 73 20 77 69 6c 6c 20 6f 6e 6c 79 20   This will only 
11d0: 77 6f 72 6b 20 69 66 20 45 58 50 4c 41 49 4e 20  work if EXPLAIN 
11e0: 69 73 20 65 6e 61 62 6c 65 64 2e 0a 23 20 54 69  is enabled..# Ti
11f0: 63 6b 65 74 20 23 32 37 32 0a 23 0a 69 66 63 61  cket #272.#.ifca
1200: 70 61 62 6c 65 20 7b 65 78 70 6c 61 69 6e 7d 20  pable {explain} 
1210: 7b 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35  {.do_test view-5
1220: 2e 33 20 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b  .3 {.  lsearch [
1230: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 45 58  execsql {.    EX
1240: 50 4c 41 49 4e 20 53 45 4c 45 43 54 20 2a 20 46  PLAIN SELECT * F
1250: 52 4f 4d 20 76 35 3b 0a 20 20 7d 5d 20 4f 70 65  ROM v5;.  }] Ope
1260: 6e 54 65 6d 70 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f  nTemp.} {-1}.do_
1270: 74 65 73 74 20 76 69 65 77 2d 35 2e 34 20 7b 0a  test view-5.4 {.
1280: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1290: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 35  SELECT * FROM v5
12a0: 20 41 53 20 61 2c 20 74 32 20 41 53 20 62 20 57   AS a, t2 AS b W
12b0: 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b 0a 20 20  HERE a.w=b.y;.  
12c0: 7d 0a 7d 20 7b 31 20 32 32 20 32 32 20 32 20 34  }.} {1 22 22 2 4
12d0: 20 35 35 20 35 35 20 35 7d 0a 64 6f 5f 74 65 73   55 55 5}.do_tes
12e0: 74 20 76 69 65 77 2d 35 2e 35 20 7b 0a 20 20 6c  t view-5.5 {.  l
12f0: 73 65 61 72 63 68 20 5b 65 78 65 63 73 71 6c 20  search [execsql 
1300: 7b 0a 20 20 20 20 45 58 50 4c 41 49 4e 20 53 45  {.    EXPLAIN SE
1310: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 35 20 41  LECT * FROM v5 A
1320: 53 20 61 2c 20 74 32 20 41 53 20 62 20 57 48 45  S a, t2 AS b WHE
1330: 52 45 20 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 5d  RE a.w=b.y;.  }]
1340: 20 4f 70 65 6e 54 65 6d 70 0a 7d 20 7b 2d 31 7d   OpenTemp.} {-1}
1350: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e  .do_test view-5.
1360: 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  6 {.  execsql {.
1370: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1380: 4d 20 74 32 20 41 53 20 62 2c 20 76 35 20 41 53  M t2 AS b, v5 AS
1390: 20 61 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79   a WHERE a.w=b.y
13a0: 3b 0a 20 20 7d 0a 7d 20 7b 32 32 20 32 20 31 20  ;.  }.} {22 2 1 
13b0: 32 32 20 35 35 20 35 20 34 20 35 35 7d 0a 64 6f  22 55 5 4 55}.do
13c0: 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 37 20 7b  _test view-5.7 {
13d0: 0a 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65 63  .  lsearch [exec
13e0: 73 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41 49  sql {.    EXPLAI
13f0: 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  N SELECT * FROM 
1400: 74 32 20 41 53 20 62 2c 20 76 35 20 41 53 20 61  t2 AS b, v5 AS a
1410: 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b 0a   WHERE a.w=b.y;.
1420: 20 20 7d 5d 20 4f 70 65 6e 54 65 6d 70 0a 7d 20    }] OpenTemp.} 
1430: 7b 2d 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  {-1}.do_test vie
1440: 77 2d 35 2e 38 20 7b 0a 20 20 65 78 65 63 73 71  w-5.8 {.  execsq
1450: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
1460: 20 46 52 4f 4d 20 74 31 20 41 53 20 61 2c 20 76   FROM t1 AS a, v
1470: 35 20 41 53 20 62 2c 20 74 32 20 41 53 20 63 20  5 AS b, t2 AS c 
1480: 57 48 45 52 45 20 61 2e 78 3d 62 2e 76 20 41 4e  WHERE a.x=b.v AN
1490: 44 20 62 2e 77 3d 63 2e 79 3b 0a 20 20 7d 0a 7d  D b.w=c.y;.  }.}
14a0: 20 7b 31 20 32 20 33 20 34 20 31 20 32 32 20 32   {1 2 3 4 1 22 2
14b0: 32 20 32 20 34 20 35 20 36 20 37 20 34 20 35 35  2 2 4 5 6 7 4 55
14c0: 20 35 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76   55 5}.do_test v
14d0: 69 65 77 2d 35 2e 39 20 7b 0a 20 20 6c 73 65 61  iew-5.9 {.  lsea
14e0: 72 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20  rch [execsql {. 
14f0: 20 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43     EXPLAIN SELEC
1500: 54 20 2a 20 46 52 4f 4d 20 74 31 20 41 53 20 61  T * FROM t1 AS a
1510: 2c 20 76 35 20 41 53 20 62 2c 20 74 32 20 41 53  , v5 AS b, t2 AS
1520: 20 63 20 57 48 45 52 45 20 61 2e 78 3d 62 2e 76   c WHERE a.x=b.v
1530: 20 41 4e 44 20 62 2e 77 3d 63 2e 79 3b 0a 20 20   AND b.w=c.y;.  
1540: 7d 5d 20 4f 70 65 6e 54 65 6d 70 0a 7d 20 7b 2d  }] OpenTemp.} {-
1550: 31 7d 0a 7d 20 3b 23 20 65 6e 64 69 66 20 65 78  1}.} ;# endif ex
1560: 70 6c 61 69 6e 0a 0a 64 6f 5f 74 65 73 74 20 76  plain..do_test v
1570: 69 65 77 2d 36 2e 31 20 7b 0a 20 20 65 78 65 63  iew-6.1 {.  exec
1580: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
1590: 20 6d 69 6e 28 78 29 2c 20 6d 69 6e 28 61 29 2c   min(x), min(a),
15a0: 20 6d 69 6e 28 62 29 2c 20 6d 69 6e 28 63 29 2c   min(b), min(c),
15b0: 20 6d 69 6e 28 61 2b 62 2b 63 29 20 46 52 4f 4d   min(a+b+c) FROM
15c0: 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 37 20 38 20   v2;.  }.} {7 8 
15d0: 39 20 31 30 20 32 37 7d 0a 64 6f 5f 74 65 73 74  9 10 27}.do_test
15e0: 20 76 69 65 77 2d 36 2e 32 20 7b 0a 20 20 65 78   view-6.2 {.  ex
15f0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
1600: 43 54 20 6d 61 78 28 78 29 2c 20 6d 61 78 28 61  CT max(x), max(a
1610: 29 2c 20 6d 61 78 28 62 29 2c 20 6d 61 78 28 63  ), max(b), max(c
1620: 29 2c 20 6d 61 78 28 61 2b 62 2b 63 29 20 46 52  ), max(a+b+c) FR
1630: 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 31 31  OM v2;.  }.} {11
1640: 20 31 32 20 31 33 20 31 34 20 33 39 7d 0a 0a 64   12 13 14 39}..d
1650: 6f 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 31 20  o_test view-7.1 
1660: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1670: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
1680: 65 73 74 31 28 69 64 20 69 6e 74 65 67 65 72 20  est1(id integer 
1690: 70 72 69 6d 61 72 79 20 6b 65 79 2c 20 61 29 3b  primary key, a);
16a0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
16b0: 45 20 74 65 73 74 32 28 69 64 20 69 6e 74 65 67  E test2(id integ
16c0: 65 72 2c 20 62 29 3b 0a 20 20 20 20 49 4e 53 45  er, b);.    INSE
16d0: 52 54 20 49 4e 54 4f 20 74 65 73 74 31 20 56 41  RT INTO test1 VA
16e0: 4c 55 45 53 28 31 2c 32 29 3b 0a 20 20 20 20 49  LUES(1,2);.    I
16f0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 65 73 74 32  NSERT INTO test2
1700: 20 56 41 4c 55 45 53 28 31 2c 33 29 3b 0a 20 20   VALUES(1,3);.  
1710: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 74 65    CREATE VIEW te
1720: 73 74 20 41 53 0a 20 20 20 20 20 20 53 45 4c 45  st AS.      SELE
1730: 43 54 20 74 65 73 74 31 2e 69 64 2c 20 61 2c 20  CT test1.id, a, 
1740: 62 0a 20 20 20 20 20 20 46 52 4f 4d 20 74 65 73  b.      FROM tes
1750: 74 31 20 4a 4f 49 4e 20 74 65 73 74 32 20 4f 4e  t1 JOIN test2 ON
1760: 20 74 65 73 74 32 2e 69 64 3d 74 65 73 74 31 2e   test2.id=test1.
1770: 69 64 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  id;.    SELECT *
1780: 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a   FROM test;.  }.
1790: 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73  } {1 2 3}.do_tes
17a0: 74 20 76 69 65 77 2d 37 2e 32 20 7b 0a 20 20 64  t view-7.2 {.  d
17b0: 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65  b close.  sqlite
17c0: 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65  3 db test.db.  e
17d0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
17e0: 45 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b  ECT * FROM test;
17f0: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64  .  }.} {1 2 3}.d
1800: 6f 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 33 20  o_test view-7.3 
1810: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1820: 20 20 44 52 4f 50 20 56 49 45 57 20 74 65 73 74    DROP VIEW test
1830: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
1840: 57 20 74 65 73 74 20 41 53 0a 20 20 20 20 20 20  W test AS.      
1850: 53 45 4c 45 43 54 20 74 65 73 74 31 2e 69 64 2c  SELECT test1.id,
1860: 20 61 2c 20 62 0a 20 20 20 20 20 20 46 52 4f 4d   a, b.      FROM
1870: 20 74 65 73 74 31 20 4a 4f 49 4e 20 74 65 73 74   test1 JOIN test
1880: 32 20 55 53 49 4e 47 28 69 64 29 3b 0a 20 20 20  2 USING(id);.   
1890: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
18a0: 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  est;.  }.} {1 2 
18b0: 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  3}.do_test view-
18c0: 37 2e 34 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65  7.4 {.  db close
18d0: 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65  .  sqlite3 db te
18e0: 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20  st.db.  execsql 
18f0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
1900: 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20  ROM test;.  }.} 
1910: 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20  {1 2 3}.do_test 
1920: 76 69 65 77 2d 37 2e 35 20 7b 0a 20 20 65 78 65  view-7.5 {.  exe
1930: 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  csql {.    DROP 
1940: 56 49 45 57 20 74 65 73 74 3b 0a 20 20 20 20 43  VIEW test;.    C
1950: 52 45 41 54 45 20 56 49 45 57 20 74 65 73 74 20  REATE VIEW test 
1960: 41 53 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  AS.      SELECT 
1970: 74 65 73 74 31 2e 69 64 2c 20 61 2c 20 62 0a 20  test1.id, a, b. 
1980: 20 20 20 20 20 46 52 4f 4d 20 74 65 73 74 31 20       FROM test1 
1990: 4e 41 54 55 52 41 4c 20 4a 4f 49 4e 20 74 65 73  NATURAL JOIN tes
19a0: 74 32 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t2;.    SELECT *
19b0: 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a   FROM test;.  }.
19c0: 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73  } {1 2 3}.do_tes
19d0: 74 20 76 69 65 77 2d 37 2e 36 20 7b 0a 20 20 64  t view-7.6 {.  d
19e0: 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65  b close.  sqlite
19f0: 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65  3 db test.db.  e
1a00: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1a10: 45 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b  ECT * FROM test;
1a20: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 0a  .  }.} {1 2 3}..
1a30: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e 31  do_test view-8.1
1a40: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
1a50: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
1a60: 36 20 41 53 20 53 45 4c 45 43 54 20 70 71 72 2c  6 AS SELECT pqr,
1a70: 20 78 79 7a 20 46 52 4f 4d 20 76 31 3b 0a 20 20   xyz FROM v1;.  
1a80: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1a90: 76 36 20 4f 52 44 45 52 20 42 59 20 78 79 7a 3b  v6 ORDER BY xyz;
1aa0: 0a 20 20 7d 0a 7d 20 7b 37 20 32 20 31 33 20 35  .  }.} {7 2 13 5
1ab0: 20 31 39 20 38 20 32 37 20 31 32 7d 0a 64 6f 5f   19 8 27 12}.do_
1ac0: 74 65 73 74 20 76 69 65 77 2d 38 2e 32 20 7b 0a  test view-8.2 {.
1ad0: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c    db close.  sql
1ae0: 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a  ite3 db test.db.
1af0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1b00: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 36  SELECT * FROM v6
1b10: 20 4f 52 44 45 52 20 42 59 20 78 79 7a 3b 0a 20   ORDER BY xyz;. 
1b20: 20 7d 0a 7d 20 7b 37 20 32 20 31 33 20 35 20 31   }.} {7 2 13 5 1
1b30: 39 20 38 20 32 37 20 31 32 7d 0a 64 6f 5f 74 65  9 8 27 12}.do_te
1b40: 73 74 20 76 69 65 77 2d 38 2e 33 20 7b 0a 20 20  st view-8.3 {.  
1b50: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
1b60: 45 41 54 45 20 56 49 45 57 20 76 37 20 41 53 20  EATE VIEW v7 AS 
1b70: 53 45 4c 45 43 54 20 70 71 72 2b 78 79 7a 20 41  SELECT pqr+xyz A
1b80: 53 20 61 20 46 52 4f 4d 20 76 36 3b 0a 20 20 20  S a FROM v6;.   
1b90: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
1ba0: 37 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20 20  7 ORDER BY a;.  
1bb0: 7d 0a 7d 20 7b 39 20 31 38 20 32 37 20 33 39 7d  }.} {9 18 27 39}
1bc0: 0a 0a 69 66 63 61 70 61 62 6c 65 20 73 75 62 71  ..ifcapable subq
1bd0: 75 65 72 79 20 7b 0a 20 20 64 6f 5f 74 65 73 74  uery {.  do_test
1be0: 20 76 69 65 77 2d 38 2e 34 20 7b 0a 20 20 20 20   view-8.4 {.    
1bf0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
1c00: 43 52 45 41 54 45 20 56 49 45 57 20 76 38 20 41  CREATE VIEW v8 A
1c10: 53 20 53 45 4c 45 43 54 20 6d 61 78 28 63 6e 74  S SELECT max(cnt
1c20: 29 20 41 53 20 6d 78 20 46 52 4f 4d 0a 20 20 20  ) AS mx FROM.   
1c30: 20 20 20 20 20 28 53 45 4c 45 43 54 20 61 25 32       (SELECT a%2
1c40: 20 41 53 20 65 6f 2c 20 63 6f 75 6e 74 28 2a 29   AS eo, count(*)
1c50: 20 41 53 20 63 6e 74 20 46 52 4f 4d 20 74 31 20   AS cnt FROM t1 
1c60: 47 52 4f 55 50 20 42 59 20 65 6f 29 3b 0a 20 20  GROUP BY eo);.  
1c70: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1c80: 4d 20 76 38 3b 0a 20 20 20 20 7d 0a 20 20 7d 20  M v8;.    }.  } 
1c90: 33 0a 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77  3.  do_test view
1ca0: 2d 38 2e 35 20 7b 0a 20 20 20 20 65 78 65 63 73  -8.5 {.    execs
1cb0: 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43  ql {.      SELEC
1cc0: 54 20 6d 78 2b 31 30 2c 20 6d 78 2a 32 20 46 52  T mx+10, mx*2 FR
1cd0: 4f 4d 20 76 38 3b 0a 20 20 20 20 7d 0a 20 20 7d  OM v8;.    }.  }
1ce0: 20 7b 31 33 20 36 7d 0a 20 20 64 6f 5f 74 65 73   {13 6}.  do_tes
1cf0: 74 20 76 69 65 77 2d 38 2e 36 20 7b 0a 20 20 20  t view-8.6 {.   
1d00: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
1d10: 20 53 45 4c 45 43 54 20 6d 78 2b 31 30 2c 20 70   SELECT mx+10, p
1d20: 71 72 20 46 52 4f 4d 20 76 36 2c 20 76 38 20 57  qr FROM v6, v8 W
1d30: 48 45 52 45 20 78 79 7a 3d 32 3b 0a 20 20 20 20  HERE xyz=2;.    
1d40: 7d 0a 20 20 7d 20 7b 31 33 20 37 7d 0a 20 20 64  }.  } {13 7}.  d
1d50: 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e 37 20  o_test view-8.7 
1d60: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
1d70: 20 20 20 20 20 20 53 45 4c 45 43 54 20 6d 78 2b        SELECT mx+
1d80: 31 30 2c 20 70 71 72 20 46 52 4f 4d 20 76 36 2c  10, pqr FROM v6,
1d90: 20 76 38 20 57 48 45 52 45 20 78 79 7a 3e 32 3b   v8 WHERE xyz>2;
1da0: 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 33 20 31  .    }.  } {13 1
1db0: 33 20 31 33 20 31 39 20 31 33 20 32 37 7d 0a 7d  3 13 19 13 27}.}
1dc0: 20 3b 23 20 69 66 63 61 70 61 62 6c 65 20 73 75   ;# ifcapable su
1dd0: 62 71 75 65 72 79 0a 0a 23 20 54 65 73 74 73 20  bquery..# Tests 
1de0: 66 6f 72 20 61 20 62 75 67 20 66 6f 75 6e 64 20  for a bug found 
1df0: 62 79 20 4d 69 63 68 69 65 6c 20 64 65 20 57 69  by Michiel de Wi
1e00: 74 20 69 6e 76 6f 6c 76 69 6e 67 20 4f 52 44 45  t involving ORDE
1e10: 52 20 42 59 20 69 6e 20 61 20 56 49 45 57 2e 0a  R BY in a VIEW..
1e20: 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 39  #.do_test view-9
1e30: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .1 {.  execsql {
1e40: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
1e50: 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52 4f   t2 SELECT * FRO
1e60: 4d 20 74 32 20 57 48 45 52 45 20 61 3c 35 3b 0a  M t2 WHERE a<5;.
1e70: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
1e80: 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  t2 SELECT * FROM
1e90: 20 74 32 20 57 48 45 52 45 20 61 3c 34 3b 0a 20   t2 WHERE a<4;. 
1ea0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
1eb0: 32 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  2 SELECT * FROM 
1ec0: 74 32 20 57 48 45 52 45 20 61 3c 33 3b 0a 20 20  t2 WHERE a<3;.  
1ed0: 20 20 53 45 4c 45 43 54 20 44 49 53 54 49 4e 43    SELECT DISTINC
1ee0: 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20  T count(*) FROM 
1ef0: 74 32 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52  t2 GROUP BY a OR
1f00: 44 45 52 20 42 59 20 31 3b 0a 20 20 7d 0a 7d 20  DER BY 1;.  }.} 
1f10: 7b 31 20 32 20 34 20 38 7d 0a 64 6f 5f 74 65 73  {1 2 4 8}.do_tes
1f20: 74 20 76 69 65 77 2d 39 2e 32 20 7b 0a 20 20 65  t view-9.2 {.  e
1f30: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1f40: 45 43 54 20 44 49 53 54 49 4e 43 54 20 63 6f 75  ECT DISTINCT cou
1f50: 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32 20 47 52  nt(*) FROM t2 GR
1f60: 4f 55 50 20 42 59 20 61 20 4f 52 44 45 52 20 42  OUP BY a ORDER B
1f70: 59 20 31 20 4c 49 4d 49 54 20 33 3b 0a 20 20 7d  Y 1 LIMIT 3;.  }
1f80: 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f 5f 74 65  .} {1 2 4}.do_te
1f90: 73 74 20 76 69 65 77 2d 39 2e 33 20 7b 0a 20 20  st view-9.3 {.  
1fa0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
1fb0: 45 41 54 45 20 56 49 45 57 20 76 39 20 41 53 20  EATE VIEW v9 AS 
1fc0: 0a 20 20 20 20 20 20 20 53 45 4c 45 43 54 20 44  .       SELECT D
1fd0: 49 53 54 49 4e 43 54 20 63 6f 75 6e 74 28 2a 29  ISTINCT count(*)
1fe0: 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50 20 42   FROM t2 GROUP B
1ff0: 59 20 61 20 4f 52 44 45 52 20 42 59 20 31 20 4c  Y a ORDER BY 1 L
2000: 49 4d 49 54 20 33 3b 0a 20 20 20 20 53 45 4c 45  IMIT 3;.    SELE
2010: 43 54 20 2a 20 46 52 4f 4d 20 76 39 3b 0a 20 20  CT * FROM v9;.  
2020: 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f 5f 74  }.} {1 2 4}.do_t
2030: 65 73 74 20 76 69 65 77 2d 39 2e 34 20 7b 0a 20  est view-9.4 {. 
2040: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
2050: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 39 20  ELECT * FROM v9 
2060: 4f 52 44 45 52 20 42 59 20 31 20 44 45 53 43 3b  ORDER BY 1 DESC;
2070: 0a 20 20 7d 0a 7d 20 7b 34 20 32 20 31 7d 0a 64  .  }.} {4 2 1}.d
2080: 6f 5f 74 65 73 74 20 76 69 65 77 2d 39 2e 35 20  o_test view-9.5 
2090: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
20a0: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31    CREATE VIEW v1
20b0: 30 20 41 53 20 0a 20 20 20 20 20 20 20 53 45 4c  0 AS .       SEL
20c0: 45 43 54 20 44 49 53 54 49 4e 43 54 20 61 2c 20  ECT DISTINCT a, 
20d0: 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32  count(*) FROM t2
20e0: 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52 44 45   GROUP BY a ORDE
20f0: 52 20 42 59 20 32 20 4c 49 4d 49 54 20 33 3b 0a  R BY 2 LIMIT 3;.
2100: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
2110: 4d 20 76 31 30 3b 0a 20 20 7d 0a 7d 20 7b 35 20  M v10;.  }.} {5 
2120: 31 20 34 20 32 20 33 20 34 7d 0a 64 6f 5f 74 65  1 4 2 3 4}.do_te
2130: 73 74 20 76 69 65 77 2d 39 2e 36 20 7b 0a 20 20  st view-9.6 {.  
2140: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
2150: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 30 20  LECT * FROM v10 
2160: 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20 7d 0a  ORDER BY 1;.  }.
2170: 7d 20 7b 33 20 34 20 34 20 32 20 35 20 31 7d 0a  } {3 4 4 2 5 1}.
2180: 0a 23 20 54 61 62 6c 65 73 20 77 69 74 68 20 63  .# Tables with c
2190: 6f 6c 75 6d 6e 73 20 68 61 76 69 6e 67 20 70 65  olumns having pe
21a0: 63 75 6c 69 61 72 20 71 75 6f 74 65 64 20 6e 61  culiar quoted na
21b0: 6d 65 73 20 75 73 65 64 20 69 6e 20 76 69 65 77  mes used in view
21c0: 73 0a 23 20 54 69 63 6b 65 74 20 23 37 35 36 2e  s.# Ticket #756.
21d0: 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  .#.do_test view-
21e0: 31 30 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  10.1 {.  execsql
21f0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
2200: 42 4c 45 20 74 33 28 22 39 22 20 69 6e 74 65 67  BLE t3("9" integ
2210: 65 72 2c 20 5b 34 5d 20 74 65 78 74 29 3b 0a 20  er, [4] text);. 
2220: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
2230: 33 20 56 41 4c 55 45 53 28 31 2c 32 29 3b 0a 20  3 VALUES(1,2);. 
2240: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
2250: 5f 74 33 5f 61 20 41 53 20 53 45 4c 45 43 54 20  _t3_a AS SELECT 
2260: 61 2e 5b 39 5d 20 46 52 4f 4d 20 74 33 20 41 53  a.[9] FROM t3 AS
2270: 20 61 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56   a;.    CREATE V
2280: 49 45 57 20 76 5f 74 33 5f 62 20 41 53 20 53 45  IEW v_t3_b AS SE
2290: 4c 45 43 54 20 22 34 22 20 46 52 4f 4d 20 74 33  LECT "4" FROM t3
22a0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
22b0: 52 4f 4d 20 76 5f 74 33 5f 61 3b 0a 20 20 7d 0a  ROM v_t3_a;.  }.
22c0: 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69  } {1}.do_test vi
22d0: 65 77 2d 31 30 2e 32 20 7b 0a 20 20 65 78 65 63  ew-10.2 {.  exec
22e0: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
22f0: 20 2a 20 46 52 4f 4d 20 76 5f 74 33 5f 62 3b 0a   * FROM v_t3_b;.
2300: 20 20 7d 0a 7d 20 7b 32 7d 0a 0a 64 6f 5f 74 65    }.} {2}..do_te
2310: 73 74 20 76 69 65 77 2d 31 31 2e 31 20 7b 0a 20  st view-11.1 {. 
2320: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
2330: 52 45 41 54 45 20 54 41 42 4c 45 20 74 34 28 61  REATE TABLE t4(a
2340: 20 43 4f 4c 4c 41 54 45 20 4e 4f 43 41 53 45 29   COLLATE NOCASE)
2350: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
2360: 4f 20 74 34 20 56 41 4c 55 45 53 28 27 54 68 69  O t4 VALUES('Thi
2370: 73 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  s');.    INSERT 
2380: 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53 28 27  INTO t4 VALUES('
2390: 74 68 69 73 27 29 3b 0a 20 20 20 20 49 4e 53 45  this');.    INSE
23a0: 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55 45  RT INTO t4 VALUE
23b0: 53 28 27 54 48 49 53 27 29 3b 0a 20 20 20 20 53  S('THIS');.    S
23c0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 34 20  ELECT * FROM t4 
23d0: 57 48 45 52 45 20 61 20 3d 20 27 54 48 49 53 27  WHERE a = 'THIS'
23e0: 3b 0a 20 20 7d 0a 7d 20 7b 54 68 69 73 20 74 68  ;.  }.} {This th
23f0: 69 73 20 54 48 49 53 7d 0a 64 6f 5f 74 65 73 74  is THIS}.do_test
2400: 20 76 69 65 77 2d 31 31 2e 32 20 7b 0a 20 20 65   view-11.2 {.  e
2410: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
2420: 45 43 54 20 2a 20 46 52 4f 4d 20 28 53 45 4c 45  ECT * FROM (SELE
2430: 43 54 20 2a 20 46 52 4f 4d 20 74 34 29 20 57 48  CT * FROM t4) WH
2440: 45 52 45 20 61 20 3d 20 27 54 48 49 53 27 3b 0a  ERE a = 'THIS';.
2450: 20 20 7d 0a 7d 20 7b 54 68 69 73 20 74 68 69 73    }.} {This this
2460: 20 54 48 49 53 7d 0a 64 6f 5f 74 65 73 74 20 76   THIS}.do_test v
2470: 69 65 77 2d 31 31 2e 33 20 7b 0a 20 20 65 78 65  iew-11.3 {.  exe
2480: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
2490: 45 20 56 49 45 57 20 76 31 31 20 41 53 20 53 45  E VIEW v11 AS SE
24a0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 34 3b 0a  LECT * FROM t4;.
24b0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
24c0: 4d 20 76 31 31 20 57 48 45 52 45 20 61 20 3d 20  M v11 WHERE a = 
24d0: 27 54 48 49 53 27 3b 0a 20 20 7d 0a 7d 20 7b 54  'THIS';.  }.} {T
24e0: 68 69 73 20 74 68 69 73 20 54 48 49 53 7d 0a 0a  his this THIS}..
24f0: 23 20 54 69 63 6b 65 74 20 23 31 32 37 30 3a 20  # Ticket #1270: 
2500: 20 44 6f 20 6e 6f 74 20 61 6c 6c 6f 77 20 70 61   Do not allow pa
2510: 72 61 6d 65 74 65 72 73 20 69 6e 20 76 69 65 77  rameters in view
2520: 20 64 65 66 69 6e 69 74 69 6f 6e 73 2e 0a 23 0a   definitions..#.
2530: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 32 2e  do_test view-12.
2540: 31 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  1 {.  catchsql {
2550: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
2560: 20 76 31 32 20 41 53 20 53 45 4c 45 43 54 20 61   v12 AS SELECT a
2570: 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 62   FROM t1 WHERE b
2580: 3d 3f 0a 20 20 7d 0a 7d 20 7b 31 20 7b 70 61 72  =?.  }.} {1 {par
2590: 61 6d 65 74 65 72 73 20 61 72 65 20 6e 6f 74 20  ameters are not 
25a0: 61 6c 6c 6f 77 65 64 20 69 6e 20 76 69 65 77 73  allowed in views
25b0: 7d 7d 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a  }}..finish_test.