/ Hex Artifact Content
Login

Artifact 7fba28a47f76541f6aea9542f62f3412e3519bad:


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 33 38 20 32 30 30 38 2f 30 38 2f 32 31 20  1.38 2008/08/21 
0200: 31 34 3a 35 34 3a 32 39 20 64 72 68 20 45 78 70  14:54:29 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 49 46 20 4e 4f 54 20 45 58 49   VIEW IF NOT EXI
03e0: 53 54 53 20 76 31 20 41 53 20 53 45 4c 45 43 54  STS v1 AS SELECT
03f0: 20 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20   a,b FROM t1;.  
0400: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0410: 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20  v1 ORDER BY a;. 
0420: 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35 20 37 20   }.} {1 2 4 5 7 
0430: 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  8}.do_test view-
0440: 31 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  1.2 {.  catchsql
0450: 20 7b 0a 20 20 20 20 52 4f 4c 4c 42 41 43 4b 3b   {.    ROLLBACK;
0460: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
0470: 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61  OM v1 ORDER BY a
0480: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73  ;.  }.} {1 {no s
0490: 75 63 68 20 74 61 62 6c 65 3a 20 76 31 7d 7d 0a  uch table: v1}}.
04a0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 33  do_test view-1.3
04b0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
04c0: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
04d0: 31 20 41 53 20 53 45 4c 45 43 54 20 61 2c 62 20  1 AS SELECT a,b 
04e0: 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c  FROM t1;.    SEL
04f0: 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52  ECT * FROM v1 OR
0500: 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20  DER BY a;.  }.} 
0510: 7b 31 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f  {1 2 4 5 7 8}.do
0520: 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 33 2e 31  _test view-1.3.1
0530: 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20   {.  db close.  
0540: 73 71 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e  sqlite3 db test.
0550: 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  db.  execsql {. 
0560: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0570: 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a   v1 ORDER BY a;.
0580: 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35 20 37    }.} {1 2 4 5 7
0590: 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   8}.do_test view
05a0: 2d 31 2e 34 20 7b 0a 20 20 63 61 74 63 68 73 71  -1.4 {.  catchsq
05b0: 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56 49 45  l {.    DROP VIE
05c0: 57 20 49 46 20 45 58 49 53 54 53 20 76 31 3b 0a  W IF EXISTS v1;.
05d0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
05e0: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
05f0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75  .  }.} {1 {no su
0600: 63 68 20 74 61 62 6c 65 3a 20 76 31 7d 7d 0a 64  ch table: v1}}.d
0610: 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 35 20  o_test view-1.5 
0620: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
0630: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31    CREATE VIEW v1
0640: 20 41 53 20 53 45 4c 45 43 54 20 61 2c 62 20 46   AS SELECT a,b F
0650: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  ROM t1;.    SELE
0660: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
0670: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
0680: 31 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f  1 2 4 5 7 8}.do_
0690: 74 65 73 74 20 76 69 65 77 2d 31 2e 36 20 7b 0a  test view-1.6 {.
06a0: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
06b0: 20 44 52 4f 50 20 54 41 42 4c 45 20 74 31 3b 0a   DROP TABLE t1;.
06c0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
06d0: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
06e0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75  .  }.} {1 {no su
06f0: 63 68 20 74 61 62 6c 65 3a 20 6d 61 69 6e 2e 74  ch table: main.t
0700: 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  1}}.do_test view
0710: 2d 31 2e 37 20 7b 0a 20 20 65 78 65 63 73 71 6c  -1.7 {.  execsql
0720: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
0730: 42 4c 45 20 74 31 28 78 2c 61 2c 62 2c 63 29 3b  BLE t1(x,a,b,c);
0740: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0750: 20 74 31 20 56 41 4c 55 45 53 28 31 2c 32 2c 33   t1 VALUES(1,2,3
0760: 2c 34 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  ,4);.    INSERT 
0770: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 34  INTO t1 VALUES(4
0780: 2c 35 2c 36 2c 37 29 3b 0a 20 20 20 20 49 4e 53  ,5,6,7);.    INS
0790: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
07a0: 45 53 28 37 2c 38 2c 39 2c 31 30 29 3b 0a 20 20  ES(7,8,9,10);.  
07b0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
07c0: 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20  v1 ORDER BY a;. 
07d0: 20 7d 0a 7d 20 7b 32 20 33 20 35 20 36 20 38 20   }.} {2 3 5 6 8 
07e0: 39 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  9}.do_test view-
07f0: 31 2e 38 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65  1.8 {.  db close
0800: 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65  .  sqlite3 db te
0810: 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20  st.db.  execsql 
0820: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
0830: 52 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20  ROM v1 ORDER BY 
0840: 61 3b 0a 20 20 7d 0a 7d 20 7b 32 20 33 20 35 20  a;.  }.} {2 3 5 
0850: 36 20 38 20 39 7d 0a 0a 64 6f 5f 74 65 73 74 20  6 8 9}..do_test 
0860: 76 69 65 77 2d 32 2e 31 20 7b 0a 20 20 65 78 65  view-2.1 {.  exe
0870: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
0880: 45 20 56 49 45 57 20 76 32 20 41 53 20 53 45 4c  E VIEW v2 AS SEL
0890: 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 57 48  ECT * FROM t1 WH
08a0: 45 52 45 20 61 3e 35 0a 20 20 7d 3b 20 20 23 20  ERE a>5.  };  # 
08b0: 4e 6f 20 73 65 6d 69 63 6f 6c 6f 6e 0a 20 20 65  No semicolon.  e
08c0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45  xecsql2 {.    SE
08d0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 3b 0a  LECT * FROM v2;.
08e0: 20 20 7d 0a 7d 20 7b 78 20 37 20 61 20 38 20 62    }.} {x 7 a 8 b
08f0: 20 39 20 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74   9 c 10}.do_test
0900: 20 76 69 65 77 2d 32 2e 32 20 7b 0a 20 20 63 61   view-2.2 {.  ca
0910: 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  tchsql {.    INS
0920: 45 52 54 20 49 4e 54 4f 20 76 32 20 56 41 4c 55  ERT INTO v2 VALU
0930: 45 53 28 31 2c 32 2c 33 2c 34 29 3b 0a 20 20 7d  ES(1,2,3,4);.  }
0940: 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 6d 6f  .} {1 {cannot mo
0950: 64 69 66 79 20 76 32 20 62 65 63 61 75 73 65 20  dify v2 because 
0960: 69 74 20 69 73 20 61 20 76 69 65 77 7d 7d 0a 64  it is a view}}.d
0970: 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 33 20  o_test view-2.3 
0980: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
0990: 20 20 20 55 50 44 41 54 45 20 76 32 20 53 45 54     UPDATE v2 SET
09a0: 20 61 3d 31 30 20 57 48 45 52 45 20 61 3d 35 3b   a=10 WHERE a=5;
09b0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f  .  }.} {1 {canno
09c0: 74 20 6d 6f 64 69 66 79 20 76 32 20 62 65 63 61  t modify v2 beca
09d0: 75 73 65 20 69 74 20 69 73 20 61 20 76 69 65 77  use it is a view
09e0: 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }}.do_test view-
09f0: 32 2e 34 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  2.4 {.  catchsql
0a00: 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52   {.    DELETE FR
0a10: 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20  OM v2;.  }.} {1 
0a20: 7b 63 61 6e 6e 6f 74 20 6d 6f 64 69 66 79 20 76  {cannot modify v
0a30: 32 20 62 65 63 61 75 73 65 20 69 74 20 69 73 20  2 because it is 
0a40: 61 20 76 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74  a view}}.do_test
0a50: 20 76 69 65 77 2d 32 2e 35 20 7b 0a 20 20 65 78   view-2.5 {.  ex
0a60: 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45  ecsql {.    INSE
0a70: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
0a80: 53 28 31 31 2c 31 32 2c 31 33 2c 31 34 29 3b 0a  S(11,12,13,14);.
0a90: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0aa0: 4d 20 76 32 20 4f 52 44 45 52 20 42 59 20 78 3b  M v2 ORDER BY x;
0ab0: 0a 20 20 7d 0a 7d 20 7b 37 20 38 20 39 20 31 30  .  }.} {7 8 9 10
0ac0: 20 31 31 20 31 32 20 31 33 20 31 34 7d 0a 64 6f   11 12 13 14}.do
0ad0: 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 36 20 7b  _test view-2.6 {
0ae0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0af0: 20 53 45 4c 45 43 54 20 78 20 46 52 4f 4d 20 76   SELECT x FROM v
0b00: 32 20 57 48 45 52 45 20 61 3e 31 30 0a 20 20 7d  2 WHERE a>10.  }
0b10: 0a 7d 20 7b 31 31 7d 0a 0a 23 20 54 65 73 74 20  .} {11}..# Test 
0b20: 74 68 61 74 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65  that column name
0b30: 20 6f 66 20 76 69 65 77 73 20 61 72 65 20 67 65   of views are ge
0b40: 6e 65 72 61 74 65 64 20 63 6f 72 72 65 63 74 6c  nerated correctl
0b50: 79 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65  y..#.do_test vie
0b60: 77 2d 33 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  w-3.1 {.  execsq
0b70: 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  l2 {.    SELECT 
0b80: 2a 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54 20  * FROM v1 LIMIT 
0b90: 31 0a 20 20 7d 0a 7d 20 7b 61 20 32 20 62 20 33  1.  }.} {a 2 b 3
0ba0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33  }.do_test view-3
0bb0: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20  .2 {.  execsql2 
0bc0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
0bd0: 52 4f 4d 20 76 32 20 4c 49 4d 49 54 20 31 0a 20  ROM v2 LIMIT 1. 
0be0: 20 7d 0a 7d 20 7b 78 20 37 20 61 20 38 20 62 20   }.} {x 7 a 8 b 
0bf0: 39 20 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74 20  9 c 10}.do_test 
0c00: 76 69 65 77 2d 33 2e 33 2e 31 20 7b 0a 20 20 65  view-3.3.1 {.  e
0c10: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 44 52  xecsql2 {.    DR
0c20: 4f 50 20 56 49 45 57 20 76 31 3b 0a 20 20 20 20  OP VIEW v1;.    
0c30: 43 52 45 41 54 45 20 56 49 45 57 20 76 31 20 41  CREATE VIEW v1 A
0c40: 53 20 53 45 4c 45 43 54 20 61 20 41 53 20 27 78  S SELECT a AS 'x
0c50: 79 7a 27 2c 20 62 2b 63 20 41 53 20 27 70 71 72  yz', b+c AS 'pqr
0c60: 27 2c 20 63 2d 62 20 46 52 4f 4d 20 74 31 3b 0a  ', c-b FROM t1;.
0c70: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0c80: 4d 20 76 31 20 4c 49 4d 49 54 20 31 0a 20 20 7d  M v1 LIMIT 1.  }
0c90: 0a 7d 20 7b 78 79 7a 20 32 20 70 71 72 20 37 20  .} {xyz 2 pqr 7 
0ca0: 63 2d 62 20 31 7d 0a 64 6f 5f 74 65 73 74 20 76  c-b 1}.do_test v
0cb0: 69 65 77 2d 33 2e 33 2e 32 20 7b 0a 20 20 65 78  iew-3.3.2 {.  ex
0cc0: 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 43 52 45  ecsql2 {.    CRE
0cd0: 41 54 45 20 56 49 45 57 20 76 31 62 20 41 53 20  ATE VIEW v1b AS 
0ce0: 53 45 4c 45 43 54 20 74 31 2e 61 2c 20 62 2b 63  SELECT t1.a, b+c
0cf0: 2c 20 74 31 2e 63 20 46 52 4f 4d 20 74 31 3b 0a  , t1.c FROM t1;.
0d00: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0d10: 4d 20 76 31 62 20 4c 49 4d 49 54 20 31 0a 20 20  M v1b LIMIT 1.  
0d20: 7d 0a 7d 20 7b 61 20 32 20 62 2b 63 20 37 20 63  }.} {a 2 b+c 7 c
0d30: 20 34 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 63   4}..ifcapable c
0d40: 6f 6d 70 6f 75 6e 64 20 7b 0a 64 6f 5f 74 65 73  ompound {.do_tes
0d50: 74 20 20 76 69 65 77 2d 33 2e 34 20 7b 0a 20 20  t  view-3.4 {.  
0d60: 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 43  execsql2 {.    C
0d70: 52 45 41 54 45 20 56 49 45 57 20 76 33 20 41 53  REATE VIEW v3 AS
0d80: 20 53 45 4c 45 43 54 20 61 20 46 52 4f 4d 20 74   SELECT a FROM t
0d90: 31 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 62  1 UNION SELECT b
0da0: 20 46 52 4f 4d 20 74 31 20 4f 52 44 45 52 20 42   FROM t1 ORDER B
0db0: 59 20 62 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  Y b;.    SELECT 
0dc0: 2a 20 46 52 4f 4d 20 76 33 20 4c 49 4d 49 54 20  * FROM v3 LIMIT 
0dd0: 34 3b 0a 20 20 7d 0a 7d 20 7b 61 20 32 20 61 20  4;.  }.} {a 2 a 
0de0: 33 20 61 20 35 20 61 20 36 7d 0a 64 6f 5f 74 65  3 a 5 a 6}.do_te
0df0: 73 74 20 76 69 65 77 2d 33 2e 35 20 7b 0a 20 20  st view-3.5 {.  
0e00: 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 43  execsql2 {.    C
0e10: 52 45 41 54 45 20 56 49 45 57 20 76 34 20 41 53  REATE VIEW v4 AS
0e20: 20 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 61   .      SELECT a
0e30: 2c 20 62 20 46 52 4f 4d 20 74 31 20 0a 20 20 20  , b FROM t1 .   
0e40: 20 20 20 55 4e 49 4f 4e 0a 20 20 20 20 20 20 53     UNION.      S
0e50: 45 4c 45 43 54 20 62 20 41 53 20 27 78 27 2c 20  ELECT b AS 'x', 
0e60: 61 20 41 53 20 27 79 27 20 46 52 4f 4d 20 74 31  a AS 'y' FROM t1
0e70: 0a 20 20 20 20 20 20 4f 52 44 45 52 20 42 59 20  .      ORDER BY 
0e80: 78 2c 20 79 3b 0a 20 20 20 20 53 45 4c 45 43 54  x, y;.    SELECT
0e90: 20 62 20 46 52 4f 4d 20 76 34 20 4f 52 44 45 52   b FROM v4 ORDER
0ea0: 20 42 59 20 62 20 4c 49 4d 49 54 20 34 3b 0a 20   BY b LIMIT 4;. 
0eb0: 20 7d 0a 7d 20 7b 62 20 32 20 62 20 33 20 62 20   }.} {b 2 b 3 b 
0ec0: 35 20 62 20 36 7d 0a 7d 20 3b 23 20 69 66 63 61  5 b 6}.} ;# ifca
0ed0: 70 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64 0a 0a  pable compound..
0ee0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34 2e  .do_test view-4.
0ef0: 31 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  1 {.  catchsql {
0f00: 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20 74  .    DROP VIEW t
0f10: 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73 65  1;.  }.} {1 {use
0f20: 20 44 52 4f 50 20 54 41 42 4c 45 20 74 6f 20 64   DROP TABLE to d
0f30: 65 6c 65 74 65 20 74 61 62 6c 65 20 74 31 7d 7d  elete table t1}}
0f40: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34 2e  .do_test view-4.
0f50: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  2 {.  execsql {.
0f60: 20 20 20 20 53 45 4c 45 43 54 20 31 20 46 52 4f      SELECT 1 FRO
0f70: 4d 20 74 31 20 4c 49 4d 49 54 20 31 3b 0a 20 20  M t1 LIMIT 1;.  
0f80: 7d 0a 7d 20 31 0a 64 6f 5f 74 65 73 74 20 76 69  }.} 1.do_test vi
0f90: 65 77 2d 34 2e 33 20 7b 0a 20 20 63 61 74 63 68  ew-4.3 {.  catch
0fa0: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 54  sql {.    DROP T
0fb0: 41 42 4c 45 20 76 31 3b 0a 20 20 7d 0a 7d 20 7b  ABLE v1;.  }.} {
0fc0: 31 20 7b 75 73 65 20 44 52 4f 50 20 56 49 45 57  1 {use DROP VIEW
0fd0: 20 74 6f 20 64 65 6c 65 74 65 20 76 69 65 77 20   to delete view 
0fe0: 76 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  v1}}.do_test vie
0ff0: 77 2d 34 2e 34 20 7b 0a 20 20 65 78 65 63 73 71  w-4.4 {.  execsq
1000: 6c 20 7b 0a 20 20 20 20 20 53 45 4c 45 43 54 20  l {.     SELECT 
1010: 31 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54 20  1 FROM v1 LIMIT 
1020: 31 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f  1;.  }.} {1}.do_
1030: 74 65 73 74 20 76 69 65 77 2d 34 2e 35 20 7b 0a  test view-4.5 {.
1040: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
1050: 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 69 31   CREATE INDEX i1
1060: 76 31 20 4f 4e 20 76 31 28 78 79 7a 29 3b 0a 20  v1 ON v1(xyz);. 
1070: 20 7d 0a 7d 20 7b 31 20 7b 76 69 65 77 73 20 6d   }.} {1 {views m
1080: 61 79 20 6e 6f 74 20 62 65 20 69 6e 64 65 78 65  ay not be indexe
1090: 64 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65  d}}..do_test vie
10a0: 77 2d 35 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  w-5.1 {.  execsq
10b0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
10c0: 41 42 4c 45 20 74 32 28 79 2c 61 29 3b 0a 20 20  ABLE t2(y,a);.  
10d0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
10e0: 20 56 41 4c 55 45 53 28 32 32 2c 32 29 3b 0a 20   VALUES(22,2);. 
10f0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
1100: 32 20 56 41 4c 55 45 53 28 33 33 2c 33 29 3b 0a  2 VALUES(33,3);.
1110: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
1120: 74 32 20 56 41 4c 55 45 53 28 34 34 2c 34 29 3b  t2 VALUES(44,4);
1130: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
1140: 20 74 32 20 56 41 4c 55 45 53 28 35 35 2c 35 29   t2 VALUES(55,5)
1150: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
1160: 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 32  ROM t2;.  }.} {2
1170: 32 20 32 20 33 33 20 33 20 34 34 20 34 20 35 35  2 2 33 3 44 4 55
1180: 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   5}.do_test view
1190: 2d 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c  -5.2 {.  execsql
11a0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
11b0: 45 57 20 76 35 20 41 53 0a 20 20 20 20 20 20 53  EW v5 AS.      S
11c0: 45 4c 45 43 54 20 74 31 2e 78 20 41 53 20 76 2c  ELECT t1.x AS v,
11d0: 20 74 32 2e 79 20 41 53 20 77 20 46 52 4f 4d 20   t2.y AS w FROM 
11e0: 74 31 20 4a 4f 49 4e 20 74 32 20 55 53 49 4e 47  t1 JOIN t2 USING
11f0: 28 61 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  (a);.    SELECT 
1200: 2a 20 46 52 4f 4d 20 76 35 3b 0a 20 20 7d 0a 7d  * FROM v5;.  }.}
1210: 20 7b 31 20 32 32 20 34 20 35 35 7d 0a 0a 23 20   {1 22 4 55}..# 
1220: 56 65 72 69 66 79 20 74 68 61 74 20 74 68 65 20  Verify that the 
1230: 76 69 65 77 20 76 35 20 67 65 74 73 20 66 6c 61  view v5 gets fla
1240: 74 74 65 6e 65 64 2e 20 20 73 65 65 20 73 71 6c  ttened.  see sql
1250: 69 74 65 46 6c 61 74 74 65 6e 53 75 62 71 75 65  iteFlattenSubque
1260: 72 79 28 29 2e 0a 23 20 54 68 69 73 20 77 69 6c  ry()..# This wil
1270: 6c 20 6f 6e 6c 79 20 77 6f 72 6b 20 69 66 20 45  l only work if E
1280: 58 50 4c 41 49 4e 20 69 73 20 65 6e 61 62 6c 65  XPLAIN is enable
1290: 64 2e 0a 23 20 54 69 63 6b 65 74 20 23 32 37 32  d..# Ticket #272
12a0: 0a 23 0a 69 66 63 61 70 61 62 6c 65 20 7b 65 78  .#.ifcapable {ex
12b0: 70 6c 61 69 6e 7d 20 7b 0a 64 6f 5f 74 65 73 74  plain} {.do_test
12c0: 20 76 69 65 77 2d 35 2e 33 20 7b 0a 20 20 6c 73   view-5.3 {.  ls
12d0: 65 61 72 63 68 20 5b 65 78 65 63 73 71 6c 20 7b  earch [execsql {
12e0: 0a 20 20 20 20 45 58 50 4c 41 49 4e 20 53 45 4c  .    EXPLAIN SEL
12f0: 45 43 54 20 2a 20 46 52 4f 4d 20 76 35 3b 0a 20  ECT * FROM v5;. 
1300: 20 7d 5d 20 4f 70 65 6e 45 70 68 65 6d 65 72 61   }] OpenEphemera
1310: 6c 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65 73 74  l.} {-1}.do_test
1320: 20 76 69 65 77 2d 35 2e 34 20 7b 0a 20 20 65 78   view-5.4 {.  ex
1330: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
1340: 43 54 20 2a 20 46 52 4f 4d 20 76 35 20 41 53 20  CT * FROM v5 AS 
1350: 61 2c 20 74 32 20 41 53 20 62 20 57 48 45 52 45  a, t2 AS b WHERE
1360: 20 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 0a 7d 20   a.w=b.y;.  }.} 
1370: 7b 31 20 32 32 20 32 32 20 32 20 34 20 35 35 20  {1 22 22 2 4 55 
1380: 35 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69  55 5}.do_test vi
1390: 65 77 2d 35 2e 35 20 7b 0a 20 20 6c 73 65 61 72  ew-5.5 {.  lsear
13a0: 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20 20  ch [execsql {.  
13b0: 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43 54    EXPLAIN SELECT
13c0: 20 2a 20 46 52 4f 4d 20 76 35 20 41 53 20 61 2c   * FROM v5 AS a,
13d0: 20 74 32 20 41 53 20 62 20 57 48 45 52 45 20 61   t2 AS b WHERE a
13e0: 2e 77 3d 62 2e 79 3b 0a 20 20 7d 5d 20 4f 70 65  .w=b.y;.  }] Ope
13f0: 6e 45 70 68 65 6d 65 72 61 6c 0a 7d 20 7b 2d 31  nEphemeral.} {-1
1400: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35  }.do_test view-5
1410: 2e 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .6 {.  execsql {
1420: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
1430: 4f 4d 20 74 32 20 41 53 20 62 2c 20 76 35 20 41  OM t2 AS b, v5 A
1440: 53 20 61 20 57 48 45 52 45 20 61 2e 77 3d 62 2e  S a WHERE a.w=b.
1450: 79 3b 0a 20 20 7d 0a 7d 20 7b 32 32 20 32 20 31  y;.  }.} {22 2 1
1460: 20 32 32 20 35 35 20 35 20 34 20 35 35 7d 0a 64   22 55 5 4 55}.d
1470: 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 37 20  o_test view-5.7 
1480: 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65  {.  lsearch [exe
1490: 63 73 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41  csql {.    EXPLA
14a0: 49 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  IN SELECT * FROM
14b0: 20 74 32 20 41 53 20 62 2c 20 76 35 20 41 53 20   t2 AS b, v5 AS 
14c0: 61 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b  a WHERE a.w=b.y;
14d0: 0a 20 20 7d 5d 20 4f 70 65 6e 45 70 68 65 6d 65  .  }] OpenEpheme
14e0: 72 61 6c 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65  ral.} {-1}.do_te
14f0: 73 74 20 76 69 65 77 2d 35 2e 38 20 7b 0a 20 20  st view-5.8 {.  
1500: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
1510: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 41  LECT * FROM t1 A
1520: 53 20 61 2c 20 76 35 20 41 53 20 62 2c 20 74 32  S a, v5 AS b, t2
1530: 20 41 53 20 63 20 57 48 45 52 45 20 61 2e 78 3d   AS c WHERE a.x=
1540: 62 2e 76 20 41 4e 44 20 62 2e 77 3d 63 2e 79 3b  b.v AND b.w=c.y;
1550: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 20 34 20  .  }.} {1 2 3 4 
1560: 31 20 32 32 20 32 32 20 32 20 34 20 35 20 36 20  1 22 22 2 4 5 6 
1570: 37 20 34 20 35 35 20 35 35 20 35 7d 0a 64 6f 5f  7 4 55 55 5}.do_
1580: 74 65 73 74 20 76 69 65 77 2d 35 2e 39 20 7b 0a  test view-5.9 {.
1590: 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65 63 73    lsearch [execs
15a0: 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41 49 4e  ql {.    EXPLAIN
15b0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
15c0: 31 20 41 53 20 61 2c 20 76 35 20 41 53 20 62 2c  1 AS a, v5 AS b,
15d0: 20 74 32 20 41 53 20 63 20 57 48 45 52 45 20 61   t2 AS c WHERE a
15e0: 2e 78 3d 62 2e 76 20 41 4e 44 20 62 2e 77 3d 63  .x=b.v AND b.w=c
15f0: 2e 79 3b 0a 20 20 7d 5d 20 4f 70 65 6e 45 70 68  .y;.  }] OpenEph
1600: 65 6d 65 72 61 6c 0a 7d 20 7b 2d 31 7d 0a 7d 20  emeral.} {-1}.} 
1610: 3b 23 20 65 6e 64 69 66 20 65 78 70 6c 61 69 6e  ;# endif explain
1620: 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 36  ..do_test view-6
1630: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .1 {.  execsql {
1640: 0a 20 20 20 20 53 45 4c 45 43 54 20 6d 69 6e 28  .    SELECT min(
1650: 78 29 2c 20 6d 69 6e 28 61 29 2c 20 6d 69 6e 28  x), min(a), min(
1660: 62 29 2c 20 6d 69 6e 28 63 29 2c 20 6d 69 6e 28  b), min(c), min(
1670: 61 2b 62 2b 63 29 20 46 52 4f 4d 20 76 32 3b 0a  a+b+c) FROM v2;.
1680: 20 20 7d 0a 7d 20 7b 37 20 38 20 39 20 31 30 20    }.} {7 8 9 10 
1690: 32 37 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  27}.do_test view
16a0: 2d 36 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c  -6.2 {.  execsql
16b0: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 6d 61   {.    SELECT ma
16c0: 78 28 78 29 2c 20 6d 61 78 28 61 29 2c 20 6d 61  x(x), max(a), ma
16d0: 78 28 62 29 2c 20 6d 61 78 28 63 29 2c 20 6d 61  x(b), max(c), ma
16e0: 78 28 61 2b 62 2b 63 29 20 46 52 4f 4d 20 76 32  x(a+b+c) FROM v2
16f0: 3b 0a 20 20 7d 0a 7d 20 7b 31 31 20 31 32 20 31  ;.  }.} {11 12 1
1700: 33 20 31 34 20 33 39 7d 0a 0a 64 6f 5f 74 65 73  3 14 39}..do_tes
1710: 74 20 76 69 65 77 2d 37 2e 31 20 7b 0a 20 20 65  t view-7.1 {.  e
1720: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
1730: 41 54 45 20 54 41 42 4c 45 20 74 65 73 74 31 28  ATE TABLE test1(
1740: 69 64 20 69 6e 74 65 67 65 72 20 70 72 69 6d 61  id integer prima
1750: 72 79 20 6b 65 79 2c 20 61 29 3b 0a 20 20 20 20  ry key, a);.    
1760: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 65 73  CREATE TABLE tes
1770: 74 32 28 69 64 20 69 6e 74 65 67 65 72 2c 20 62  t2(id integer, b
1780: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
1790: 54 4f 20 74 65 73 74 31 20 56 41 4c 55 45 53 28  TO test1 VALUES(
17a0: 31 2c 32 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  1,2);.    INSERT
17b0: 20 49 4e 54 4f 20 74 65 73 74 32 20 56 41 4c 55   INTO test2 VALU
17c0: 45 53 28 31 2c 33 29 3b 0a 20 20 20 20 43 52 45  ES(1,3);.    CRE
17d0: 41 54 45 20 56 49 45 57 20 74 65 73 74 20 41 53  ATE VIEW test AS
17e0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 74 65  .      SELECT te
17f0: 73 74 31 2e 69 64 2c 20 61 2c 20 62 0a 20 20 20  st1.id, a, b.   
1800: 20 20 20 46 52 4f 4d 20 74 65 73 74 31 20 4a 4f     FROM test1 JO
1810: 49 4e 20 74 65 73 74 32 20 4f 4e 20 74 65 73 74  IN test2 ON test
1820: 32 2e 69 64 3d 74 65 73 74 31 2e 69 64 3b 0a 20  2.id=test1.id;. 
1830: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
1840: 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20   test;.  }.} {1 
1850: 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  2 3}.do_test vie
1860: 77 2d 37 2e 32 20 7b 0a 20 20 64 62 20 63 6c 6f  w-7.2 {.  db clo
1870: 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20  se.  sqlite3 db 
1880: 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71  test.db.  execsq
1890: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
18a0: 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a   FROM test;.  }.
18b0: 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73  } {1 2 3}.do_tes
18c0: 74 20 76 69 65 77 2d 37 2e 33 20 7b 0a 20 20 65  t view-7.3 {.  e
18d0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f  xecsql {.    DRO
18e0: 50 20 56 49 45 57 20 74 65 73 74 3b 0a 20 20 20  P VIEW test;.   
18f0: 20 43 52 45 41 54 45 20 56 49 45 57 20 74 65 73   CREATE VIEW tes
1900: 74 20 41 53 0a 20 20 20 20 20 20 53 45 4c 45 43  t AS.      SELEC
1910: 54 20 74 65 73 74 31 2e 69 64 2c 20 61 2c 20 62  T test1.id, a, b
1920: 0a 20 20 20 20 20 20 46 52 4f 4d 20 74 65 73 74  .      FROM test
1930: 31 20 4a 4f 49 4e 20 74 65 73 74 32 20 55 53 49  1 JOIN test2 USI
1940: 4e 47 28 69 64 29 3b 0a 20 20 20 20 53 45 4c 45  NG(id);.    SELE
1950: 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a  CT * FROM test;.
1960: 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f    }.} {1 2 3}.do
1970: 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 34 20 7b  _test view-7.4 {
1980: 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71  .  db close.  sq
1990: 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62  lite3 db test.db
19a0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
19b0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
19c0: 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  est;.  }.} {1 2 
19d0: 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  3}.do_test view-
19e0: 37 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  7.5 {.  execsql 
19f0: 7b 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20  {.    DROP VIEW 
1a00: 74 65 73 74 3b 0a 20 20 20 20 43 52 45 41 54 45  test;.    CREATE
1a10: 20 56 49 45 57 20 74 65 73 74 20 41 53 0a 20 20   VIEW test AS.  
1a20: 20 20 20 20 53 45 4c 45 43 54 20 74 65 73 74 31      SELECT test1
1a30: 2e 69 64 2c 20 61 2c 20 62 0a 20 20 20 20 20 20  .id, a, b.      
1a40: 46 52 4f 4d 20 74 65 73 74 31 20 4e 41 54 55 52  FROM test1 NATUR
1a50: 41 4c 20 4a 4f 49 4e 20 74 65 73 74 32 3b 0a 20  AL JOIN test2;. 
1a60: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
1a70: 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20   test;.  }.} {1 
1a80: 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  2 3}.do_test vie
1a90: 77 2d 37 2e 36 20 7b 0a 20 20 64 62 20 63 6c 6f  w-7.6 {.  db clo
1aa0: 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20  se.  sqlite3 db 
1ab0: 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71  test.db.  execsq
1ac0: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
1ad0: 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a   FROM test;.  }.
1ae0: 7d 20 7b 31 20 32 20 33 7d 0a 0a 64 6f 5f 74 65  } {1 2 3}..do_te
1af0: 73 74 20 76 69 65 77 2d 38 2e 31 20 7b 0a 20 20  st view-8.1 {.  
1b00: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
1b10: 45 41 54 45 20 56 49 45 57 20 76 36 20 41 53 20  EATE VIEW v6 AS 
1b20: 53 45 4c 45 43 54 20 70 71 72 2c 20 78 79 7a 20  SELECT pqr, xyz 
1b30: 46 52 4f 4d 20 76 31 3b 0a 20 20 20 20 53 45 4c  FROM v1;.    SEL
1b40: 45 43 54 20 2a 20 46 52 4f 4d 20 76 36 20 4f 52  ECT * FROM v6 OR
1b50: 44 45 52 20 42 59 20 78 79 7a 3b 0a 20 20 7d 0a  DER BY xyz;.  }.
1b60: 7d 20 7b 37 20 32 20 31 33 20 35 20 31 39 20 38  } {7 2 13 5 19 8
1b70: 20 32 37 20 31 32 7d 0a 64 6f 5f 74 65 73 74 20   27 12}.do_test 
1b80: 76 69 65 77 2d 38 2e 32 20 7b 0a 20 20 64 62 20  view-8.2 {.  db 
1b90: 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20  close.  sqlite3 
1ba0: 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65  db test.db.  exe
1bb0: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
1bc0: 54 20 2a 20 46 52 4f 4d 20 76 36 20 4f 52 44 45  T * FROM v6 ORDE
1bd0: 52 20 42 59 20 78 79 7a 3b 0a 20 20 7d 0a 7d 20  R BY xyz;.  }.} 
1be0: 7b 37 20 32 20 31 33 20 35 20 31 39 20 38 20 32  {7 2 13 5 19 8 2
1bf0: 37 20 31 32 7d 0a 64 6f 5f 74 65 73 74 20 76 69  7 12}.do_test vi
1c00: 65 77 2d 38 2e 33 20 7b 0a 20 20 65 78 65 63 73  ew-8.3 {.  execs
1c10: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
1c20: 56 49 45 57 20 76 37 20 41 53 20 53 45 4c 45 43  VIEW v7 AS SELEC
1c30: 54 20 70 71 72 2b 78 79 7a 20 41 53 20 61 20 46  T pqr+xyz AS a F
1c40: 52 4f 4d 20 76 36 3b 0a 20 20 20 20 53 45 4c 45  ROM v6;.    SELE
1c50: 43 54 20 2a 20 46 52 4f 4d 20 76 37 20 4f 52 44  CT * FROM v7 ORD
1c60: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
1c70: 39 20 31 38 20 32 37 20 33 39 7d 0a 0a 69 66 63  9 18 27 39}..ifc
1c80: 61 70 61 62 6c 65 20 73 75 62 71 75 65 72 79 20  apable subquery 
1c90: 7b 0a 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77  {.  do_test view
1ca0: 2d 38 2e 34 20 7b 0a 20 20 20 20 65 78 65 63 73  -8.4 {.    execs
1cb0: 71 6c 20 7b 0a 20 20 20 20 20 20 43 52 45 41 54  ql {.      CREAT
1cc0: 45 20 56 49 45 57 20 76 38 20 41 53 20 53 45 4c  E VIEW v8 AS SEL
1cd0: 45 43 54 20 6d 61 78 28 63 6e 74 29 20 41 53 20  ECT max(cnt) AS 
1ce0: 6d 78 20 46 52 4f 4d 0a 20 20 20 20 20 20 20 20  mx FROM.        
1cf0: 28 53 45 4c 45 43 54 20 61 25 32 20 41 53 20 65  (SELECT a%2 AS e
1d00: 6f 2c 20 63 6f 75 6e 74 28 2a 29 20 41 53 20 63  o, count(*) AS c
1d10: 6e 74 20 46 52 4f 4d 20 74 31 20 47 52 4f 55 50  nt FROM t1 GROUP
1d20: 20 42 59 20 65 6f 29 3b 0a 20 20 20 20 20 20 53   BY eo);.      S
1d30: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 38 3b  ELECT * FROM v8;
1d40: 0a 20 20 20 20 7d 0a 20 20 7d 20 33 0a 20 20 64  .    }.  } 3.  d
1d50: 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e 35 20  o_test view-8.5 
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 6d 78 2a 32 20 46 52 4f 4d 20 76 38  10, mx*2 FROM v8
1d90: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 33 20  ;.    }.  } {13 
1da0: 36 7d 0a 20 20 64 6f 5f 74 65 73 74 20 76 69 65  6}.  do_test vie
1db0: 77 2d 38 2e 36 20 7b 0a 20 20 20 20 65 78 65 63  w-8.6 {.    exec
1dc0: 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c 45  sql {.      SELE
1dd0: 43 54 20 6d 78 2b 31 30 2c 20 70 71 72 20 46 52  CT mx+10, pqr FR
1de0: 4f 4d 20 76 36 2c 20 76 38 20 57 48 45 52 45 20  OM v6, v8 WHERE 
1df0: 78 79 7a 3d 32 3b 0a 20 20 20 20 7d 0a 20 20 7d  xyz=2;.    }.  }
1e00: 20 7b 31 33 20 37 7d 0a 20 20 64 6f 5f 74 65 73   {13 7}.  do_tes
1e10: 74 20 76 69 65 77 2d 38 2e 37 20 7b 0a 20 20 20  t view-8.7 {.   
1e20: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
1e30: 20 53 45 4c 45 43 54 20 6d 78 2b 31 30 2c 20 70   SELECT mx+10, p
1e40: 71 72 20 46 52 4f 4d 20 76 36 2c 20 76 38 20 57  qr FROM v6, v8 W
1e50: 48 45 52 45 20 78 79 7a 3e 32 3b 0a 20 20 20 20  HERE xyz>2;.    
1e60: 7d 0a 20 20 7d 20 7b 31 33 20 31 33 20 31 33 20  }.  } {13 13 13 
1e70: 31 39 20 31 33 20 32 37 7d 0a 7d 20 3b 23 20 69  19 13 27}.} ;# i
1e80: 66 63 61 70 61 62 6c 65 20 73 75 62 71 75 65 72  fcapable subquer
1e90: 79 0a 0a 23 20 54 65 73 74 73 20 66 6f 72 20 61  y..# Tests for a
1ea0: 20 62 75 67 20 66 6f 75 6e 64 20 62 79 20 4d 69   bug found by Mi
1eb0: 63 68 69 65 6c 20 64 65 20 57 69 74 20 69 6e 76  chiel de Wit inv
1ec0: 6f 6c 76 69 6e 67 20 4f 52 44 45 52 20 42 59 20  olving ORDER BY 
1ed0: 69 6e 20 61 20 56 49 45 57 2e 0a 23 0a 64 6f 5f  in a VIEW..#.do_
1ee0: 74 65 73 74 20 76 69 65 77 2d 39 2e 31 20 7b 0a  test view-9.1 {.
1ef0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1f00: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 53  INSERT INTO t2 S
1f10: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 20  ELECT * FROM t2 
1f20: 57 48 45 52 45 20 61 3c 35 3b 0a 20 20 20 20 49  WHERE a<5;.    I
1f30: 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 53 45  NSERT INTO t2 SE
1f40: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 57  LECT * FROM t2 W
1f50: 48 45 52 45 20 61 3c 34 3b 0a 20 20 20 20 49 4e  HERE a<4;.    IN
1f60: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 53 45 4c  SERT INTO t2 SEL
1f70: 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 57 48  ECT * FROM t2 WH
1f80: 45 52 45 20 61 3c 33 3b 0a 20 20 20 20 53 45 4c  ERE a<3;.    SEL
1f90: 45 43 54 20 44 49 53 54 49 4e 43 54 20 63 6f 75  ECT DISTINCT cou
1fa0: 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32 20 47 52  nt(*) FROM t2 GR
1fb0: 4f 55 50 20 42 59 20 61 20 4f 52 44 45 52 20 42  OUP BY a ORDER B
1fc0: 59 20 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  Y 1;.  }.} {1 2 
1fd0: 34 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  4 8}.do_test vie
1fe0: 77 2d 39 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  w-9.2 {.  execsq
1ff0: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 44  l {.    SELECT D
2000: 49 53 54 49 4e 43 54 20 63 6f 75 6e 74 28 2a 29  ISTINCT count(*)
2010: 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50 20 42   FROM t2 GROUP B
2020: 59 20 61 20 4f 52 44 45 52 20 42 59 20 31 20 4c  Y a ORDER BY 1 L
2030: 49 4d 49 54 20 33 3b 0a 20 20 7d 0a 7d 20 7b 31  IMIT 3;.  }.} {1
2040: 20 32 20 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69   2 4}.do_test vi
2050: 65 77 2d 39 2e 33 20 7b 0a 20 20 65 78 65 63 73  ew-9.3 {.  execs
2060: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
2070: 56 49 45 57 20 76 39 20 41 53 20 0a 20 20 20 20  VIEW v9 AS .    
2080: 20 20 20 53 45 4c 45 43 54 20 44 49 53 54 49 4e     SELECT DISTIN
2090: 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d  CT count(*) FROM
20a0: 20 74 32 20 47 52 4f 55 50 20 42 59 20 61 20 4f   t2 GROUP BY a O
20b0: 52 44 45 52 20 42 59 20 31 20 4c 49 4d 49 54 20  RDER BY 1 LIMIT 
20c0: 33 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  3;.    SELECT * 
20d0: 46 52 4f 4d 20 76 39 3b 0a 20 20 7d 0a 7d 20 7b  FROM v9;.  }.} {
20e0: 31 20 32 20 34 7d 0a 64 6f 5f 74 65 73 74 20 76  1 2 4}.do_test v
20f0: 69 65 77 2d 39 2e 34 20 7b 0a 20 20 65 78 65 63  iew-9.4 {.  exec
2100: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
2110: 20 2a 20 46 52 4f 4d 20 76 39 20 4f 52 44 45 52   * FROM v9 ORDER
2120: 20 42 59 20 31 20 44 45 53 43 3b 0a 20 20 7d 0a   BY 1 DESC;.  }.
2130: 7d 20 7b 34 20 32 20 31 7d 0a 64 6f 5f 74 65 73  } {4 2 1}.do_tes
2140: 74 20 76 69 65 77 2d 39 2e 35 20 7b 0a 20 20 65  t view-9.5 {.  e
2150: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
2160: 41 54 45 20 56 49 45 57 20 76 31 30 20 41 53 20  ATE VIEW v10 AS 
2170: 0a 20 20 20 20 20 20 20 53 45 4c 45 43 54 20 44  .       SELECT D
2180: 49 53 54 49 4e 43 54 20 61 2c 20 63 6f 75 6e 74  ISTINCT a, count
2190: 28 2a 29 20 46 52 4f 4d 20 74 32 20 47 52 4f 55  (*) FROM t2 GROU
21a0: 50 20 42 59 20 61 20 4f 52 44 45 52 20 42 59 20  P BY a ORDER BY 
21b0: 32 20 4c 49 4d 49 54 20 33 3b 0a 20 20 20 20 53  2 LIMIT 3;.    S
21c0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 30  ELECT * FROM v10
21d0: 3b 0a 20 20 7d 0a 7d 20 7b 35 20 31 20 34 20 32  ;.  }.} {5 1 4 2
21e0: 20 33 20 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69   3 4}.do_test vi
21f0: 65 77 2d 39 2e 36 20 7b 0a 20 20 65 78 65 63 73  ew-9.6 {.  execs
2200: 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  ql {.    SELECT 
2210: 2a 20 46 52 4f 4d 20 76 31 30 20 4f 52 44 45 52  * FROM v10 ORDER
2220: 20 42 59 20 31 3b 0a 20 20 7d 0a 7d 20 7b 33 20   BY 1;.  }.} {3 
2230: 34 20 34 20 32 20 35 20 31 7d 0a 0a 23 20 54 61  4 4 2 5 1}..# Ta
2240: 62 6c 65 73 20 77 69 74 68 20 63 6f 6c 75 6d 6e  bles with column
2250: 73 20 68 61 76 69 6e 67 20 70 65 63 75 6c 69 61  s having peculia
2260: 72 20 71 75 6f 74 65 64 20 6e 61 6d 65 73 20 75  r quoted names u
2270: 73 65 64 20 69 6e 20 76 69 65 77 73 0a 23 20 54  sed in views.# T
2280: 69 63 6b 65 74 20 23 37 35 36 2e 0a 23 0a 64 6f  icket #756..#.do
2290: 5f 74 65 73 74 20 76 69 65 77 2d 31 30 2e 31 20  _test view-10.1 
22a0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
22b0: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
22c0: 33 28 22 39 22 20 69 6e 74 65 67 65 72 2c 20 5b  3("9" integer, [
22d0: 34 5d 20 74 65 78 74 29 3b 0a 20 20 20 20 49 4e  4] text);.    IN
22e0: 53 45 52 54 20 49 4e 54 4f 20 74 33 20 56 41 4c  SERT INTO t3 VAL
22f0: 55 45 53 28 31 2c 32 29 3b 0a 20 20 20 20 43 52  UES(1,2);.    CR
2300: 45 41 54 45 20 56 49 45 57 20 76 5f 74 33 5f 61  EATE VIEW v_t3_a
2310: 20 41 53 20 53 45 4c 45 43 54 20 61 2e 5b 39 5d   AS SELECT a.[9]
2320: 20 46 52 4f 4d 20 74 33 20 41 53 20 61 3b 0a 20   FROM t3 AS a;. 
2330: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
2340: 5f 74 33 5f 62 20 41 53 20 53 45 4c 45 43 54 20  _t3_b AS SELECT 
2350: 22 34 22 20 46 52 4f 4d 20 74 33 3b 0a 20 20 20  "4" FROM t3;.   
2360: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
2370: 5f 74 33 5f 61 3b 0a 20 20 7d 0a 7d 20 7b 31 7d  _t3_a;.  }.} {1}
2380: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 30  .do_test view-10
2390: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
23a0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
23b0: 4f 4d 20 76 5f 74 33 5f 62 3b 0a 20 20 7d 0a 7d  OM v_t3_b;.  }.}
23c0: 20 7b 32 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69   {2}..do_test vi
23d0: 65 77 2d 31 31 2e 31 20 7b 0a 20 20 65 78 65 63  ew-11.1 {.  exec
23e0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
23f0: 20 54 41 42 4c 45 20 74 34 28 61 20 43 4f 4c 4c   TABLE t4(a COLL
2400: 41 54 45 20 4e 4f 43 41 53 45 29 3b 0a 20 20 20  ATE NOCASE);.   
2410: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 34 20   INSERT INTO t4 
2420: 56 41 4c 55 45 53 28 27 54 68 69 73 27 29 3b 0a  VALUES('This');.
2430: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
2440: 74 34 20 56 41 4c 55 45 53 28 27 74 68 69 73 27  t4 VALUES('this'
2450: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
2460: 54 4f 20 74 34 20 56 41 4c 55 45 53 28 27 54 48  TO t4 VALUES('TH
2470: 49 53 27 29 3b 0a 20 20 20 20 53 45 4c 45 43 54  IS');.    SELECT
2480: 20 2a 20 46 52 4f 4d 20 74 34 20 57 48 45 52 45   * FROM t4 WHERE
2490: 20 61 20 3d 20 27 54 48 49 53 27 3b 0a 20 20 7d   a = 'THIS';.  }
24a0: 0a 7d 20 7b 54 68 69 73 20 74 68 69 73 20 54 48  .} {This this TH
24b0: 49 53 7d 0a 69 66 63 61 70 61 62 6c 65 20 73 75  IS}.ifcapable su
24c0: 62 71 75 65 72 79 20 7b 0a 20 20 64 6f 5f 74 65  bquery {.  do_te
24d0: 73 74 20 76 69 65 77 2d 31 31 2e 32 20 7b 0a 20  st view-11.2 {. 
24e0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
24f0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
2500: 20 28 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20   (SELECT * FROM 
2510: 74 34 29 20 57 48 45 52 45 20 61 20 3d 20 27 54  t4) WHERE a = 'T
2520: 48 49 53 27 3b 0a 20 20 20 20 7d 0a 20 20 7d 20  HIS';.    }.  } 
2530: 7b 54 68 69 73 20 74 68 69 73 20 54 48 49 53 7d  {This this THIS}
2540: 0a 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  .}.do_test view-
2550: 31 31 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c  11.3 {.  execsql
2560: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
2570: 45 57 20 76 31 31 20 41 53 20 53 45 4c 45 43 54  EW v11 AS SELECT
2580: 20 2a 20 46 52 4f 4d 20 74 34 3b 0a 20 20 20 20   * FROM t4;.    
2590: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
25a0: 31 20 57 48 45 52 45 20 61 20 3d 20 27 54 48 49  1 WHERE a = 'THI
25b0: 53 27 3b 0a 20 20 7d 0a 7d 20 7b 54 68 69 73 20  S';.  }.} {This 
25c0: 74 68 69 73 20 54 48 49 53 7d 0a 0a 23 20 54 69  this THIS}..# Ti
25d0: 63 6b 65 74 20 23 31 32 37 30 3a 20 20 44 6f 20  cket #1270:  Do 
25e0: 6e 6f 74 20 61 6c 6c 6f 77 20 70 61 72 61 6d 65  not allow parame
25f0: 74 65 72 73 20 69 6e 20 76 69 65 77 20 64 65 66  ters in view def
2600: 69 6e 69 74 69 6f 6e 73 2e 0a 23 0a 64 6f 5f 74  initions..#.do_t
2610: 65 73 74 20 76 69 65 77 2d 31 32 2e 31 20 7b 0a  est view-12.1 {.
2620: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
2630: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 32   CREATE VIEW v12
2640: 20 41 53 20 53 45 4c 45 43 54 20 61 20 46 52 4f   AS SELECT a FRO
2650: 4d 20 74 31 20 57 48 45 52 45 20 62 3d 3f 0a 20  M t1 WHERE b=?. 
2660: 20 7d 0a 7d 20 7b 31 20 7b 70 61 72 61 6d 65 74   }.} {1 {paramet
2670: 65 72 73 20 61 72 65 20 6e 6f 74 20 61 6c 6c 6f  ers are not allo
2680: 77 65 64 20 69 6e 20 76 69 65 77 73 7d 7d 0a 0a  wed in views}}..
2690: 69 66 63 61 70 61 62 6c 65 20 61 74 74 61 63 68  ifcapable attach
26a0: 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 76 69 65   {.  do_test vie
26b0: 77 2d 31 33 2e 31 20 7b 0a 20 20 20 20 66 69 6c  w-13.1 {.    fil
26c0: 65 20 64 65 6c 65 74 65 20 2d 66 6f 72 63 65 20  e delete -force 
26d0: 74 65 73 74 32 2e 64 62 0a 20 20 20 20 63 61 74  test2.db.    cat
26e0: 63 68 73 71 6c 20 7b 0a 20 20 20 20 20 20 41 54  chsql {.      AT
26f0: 54 41 43 48 20 27 74 65 73 74 32 2e 64 62 27 20  TACH 'test2.db' 
2700: 41 53 20 74 77 6f 3b 0a 20 20 20 20 20 20 43 52  AS two;.      CR
2710: 45 41 54 45 20 54 41 42 4c 45 20 74 77 6f 2e 74  EATE TABLE two.t
2720: 32 28 78 2c 79 29 3b 0a 20 20 20 20 20 20 43 52  2(x,y);.      CR
2730: 45 41 54 45 20 56 49 45 57 20 76 31 33 20 41 53  EATE VIEW v13 AS
2740: 20 53 45 4c 45 43 54 20 79 20 46 52 4f 4d 20 74   SELECT y FROM t
2750: 77 6f 2e 74 32 3b 0a 20 20 20 20 7d 0a 20 20 7d  wo.t2;.    }.  }
2760: 20 7b 31 20 7b 76 69 65 77 20 76 31 33 20 63 61   {1 {view v13 ca
2770: 6e 6e 6f 74 20 72 65 66 65 72 65 6e 63 65 20 6f  nnot reference o
2780: 62 6a 65 63 74 73 20 69 6e 20 64 61 74 61 62 61  bjects in databa
2790: 73 65 20 74 77 6f 7d 7d 0a 7d 0a 0a 23 20 54 69  se two}}.}..# Ti
27a0: 63 6b 65 74 20 23 31 36 35 38 0a 23 0a 64 6f 5f  cket #1658.#.do_
27b0: 74 65 73 74 20 76 69 65 77 2d 31 34 2e 31 20 7b  test view-14.1 {
27c0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
27d0: 20 20 43 52 45 41 54 45 20 54 45 4d 50 20 56 49    CREATE TEMP VI
27e0: 45 57 20 74 31 20 41 53 20 53 45 4c 45 43 54 20  EW t1 AS SELECT 
27f0: 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20  a,b FROM t1;.   
2800: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
2810: 65 6d 70 2e 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31  emp.t1;.  }.} {1
2820: 20 7b 76 69 65 77 20 74 31 20 69 73 20 63 69 72   {view t1 is cir
2830: 63 75 6c 61 72 6c 79 20 64 65 66 69 6e 65 64 7d  cularly defined}
2840: 7d 0a 0a 23 20 54 69 63 6b 65 74 73 20 23 31 36  }..# Tickets #16
2850: 38 38 2c 20 23 31 37 30 39 0a 23 0a 64 6f 5f 74  88, #1709.#.do_t
2860: 65 73 74 20 76 69 65 77 2d 31 35 2e 31 20 7b 0a  est view-15.1 {.
2870: 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20    execsql2 {.   
2880: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 35   CREATE VIEW v15
2890: 20 41 53 20 53 45 4c 45 43 54 20 61 20 41 53 20   AS SELECT a AS 
28a0: 78 2c 20 62 20 41 53 20 79 20 46 52 4f 4d 20 74  x, b AS y FROM t
28b0: 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  1;.    SELECT * 
28c0: 46 52 4f 4d 20 76 31 35 20 4c 49 4d 49 54 20 31  FROM v15 LIMIT 1
28d0: 3b 0a 20 20 7d 0a 7d 20 7b 78 20 32 20 79 20 33  ;.  }.} {x 2 y 3
28e0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  }.do_test view-1
28f0: 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 32  5.2 {.  execsql2
2900: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 78 2c   {.    SELECT x,
2910: 20 79 20 46 52 4f 4d 20 76 31 35 20 4c 49 4d 49   y FROM v15 LIMI
2920: 54 20 31 0a 20 20 7d 0a 7d 20 7b 78 20 32 20 79  T 1.  }.} {x 2 y
2930: 20 33 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65   3}..do_test vie
2940: 77 2d 31 36 2e 31 20 7b 0a 20 20 63 61 74 63 68  w-16.1 {.  catch
2950: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
2960: 20 56 49 45 57 20 49 46 20 4e 4f 54 20 45 58 49   VIEW IF NOT EXI
2970: 53 54 53 20 76 31 20 41 53 20 53 45 4c 45 43 54  STS v1 AS SELECT
2980: 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a   * FROM t1;.  }.
2990: 7d 20 7b 30 20 7b 7d 7d 0a 64 6f 5f 74 65 73 74  } {0 {}}.do_test
29a0: 20 76 69 65 77 2d 31 36 2e 32 20 7b 0a 20 20 65   view-16.2 {.  e
29b0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
29c0: 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 73 71 6c  ECT sql FROM sql
29d0: 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45  ite_master WHERE
29e0: 20 6e 61 6d 65 3d 27 76 31 27 0a 20 20 7d 0a 7d   name='v1'.  }.}
29f0: 20 7b 7b 43 52 45 41 54 45 20 56 49 45 57 20 76   {{CREATE VIEW v
2a00: 31 20 41 53 20 53 45 4c 45 43 54 20 61 20 41 53  1 AS SELECT a AS
2a10: 20 27 78 79 7a 27 2c 20 62 2b 63 20 41 53 20 27   'xyz', b+c AS '
2a20: 70 71 72 27 2c 20 63 2d 62 20 46 52 4f 4d 20 74  pqr', c-b FROM t
2a30: 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  1}}.do_test view
2a40: 2d 31 36 2e 33 20 7b 0a 20 20 63 61 74 63 68 73  -16.3 {.  catchs
2a50: 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56 49  ql {.    DROP VI
2a60: 45 57 20 49 46 20 45 58 49 53 54 53 20 6e 6f 73  EW IF EXISTS nos
2a70: 75 63 68 76 69 65 77 0a 20 20 7d 0a 7d 20 7b 30  uchview.  }.} {0
2a80: 20 7b 7d 7d 0a 0a 23 20 63 6f 72 72 65 63 74 20   {}}..# correct 
2a90: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 77 68  error message wh
2aa0: 65 6e 20 61 74 74 65 6d 70 74 69 6e 67 20 74 6f  en attempting to
2ab0: 20 64 72 6f 70 20 61 20 76 69 65 77 20 74 68 61   drop a view tha
2ac0: 74 20 64 6f 65 73 20 6e 6f 74 0a 23 20 65 78 69  t does not.# exi
2ad0: 73 74 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69  st..#.do_test vi
2ae0: 65 77 2d 31 37 2e 31 20 7b 0a 20 20 63 61 74 63  ew-17.1 {.  catc
2af0: 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  hsql {.    DROP 
2b00: 56 49 45 57 20 6e 6f 73 75 63 68 76 69 65 77 0a  VIEW nosuchview.
2b10: 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75 63    }.} {1 {no suc
2b20: 68 20 76 69 65 77 3a 20 6e 6f 73 75 63 68 76 69  h view: nosuchvi
2b30: 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  ew}}.do_test vie
2b40: 77 2d 31 37 2e 32 20 7b 0a 20 20 63 61 74 63 68  w-17.2 {.  catch
2b50: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56  sql {.    DROP V
2b60: 49 45 57 20 6d 61 69 6e 2e 6e 6f 73 75 63 68 76  IEW main.nosuchv
2b70: 69 65 77 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f  iew.  }.} {1 {no
2b80: 20 73 75 63 68 20 76 69 65 77 3a 20 6d 61 69 6e   such view: main
2b90: 2e 6e 6f 73 75 63 68 76 69 65 77 7d 7d 0a 0a 64  .nosuchview}}..d
2ba0: 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 38 2e 31  o_test view-18.1
2bb0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
2bc0: 20 20 20 44 52 4f 50 20 56 49 45 57 20 74 31 3b     DROP VIEW t1;
2bd0: 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20  .    DROP TABLE 
2be0: 74 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  t1;.    CREATE T
2bf0: 41 42 4c 45 20 74 31 28 61 2c 20 62 2c 20 63 29  ABLE t1(a, b, c)
2c00: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
2c10: 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c 20 32  O t1 VALUES(1, 2
2c20: 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  , 3);.    INSERT
2c30: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
2c40: 34 2c 20 35 2c 20 36 29 3b 0a 0a 20 20 20 20 43  4, 5, 6);..    C
2c50: 52 45 41 54 45 20 56 49 45 57 20 76 76 31 20 41  REATE VIEW vv1 A
2c60: 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  S SELECT * FROM 
2c70: 74 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56  t1;.    CREATE V
2c80: 49 45 57 20 76 76 32 20 41 53 20 53 45 4c 45 43  IEW vv2 AS SELEC
2c90: 54 20 2a 20 46 52 4f 4d 20 76 76 31 3b 0a 20 20  T * FROM vv1;.  
2ca0: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 76    CREATE VIEW vv
2cb0: 33 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52  3 AS SELECT * FR
2cc0: 4f 4d 20 76 76 32 3b 0a 20 20 20 20 43 52 45 41  OM vv2;.    CREA
2cd0: 54 45 20 56 49 45 57 20 76 76 34 20 41 53 20 53  TE VIEW vv4 AS S
2ce0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 76 33  ELECT * FROM vv3
2cf0: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
2d00: 57 20 76 76 35 20 41 53 20 53 45 4c 45 43 54 20  W vv5 AS SELECT 
2d10: 2a 20 46 52 4f 4d 20 76 76 34 3b 0a 0a 20 20 20  * FROM vv4;..   
2d20: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
2d30: 76 35 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  v5;.  }.} {1 2 3
2d40: 20 34 20 35 20 36 7d 0a 0a 23 20 54 69 63 6b 65   4 5 6}..# Ticke
2d50: 74 20 23 33 33 30 38 0a 23 20 4d 61 6b 65 20 73  t #3308.# Make s
2d60: 75 72 65 20 22 72 6f 77 69 64 22 20 63 6f 6c 75  ure "rowid" colu
2d70: 6d 6e 73 20 69 6e 20 61 20 76 69 65 77 20 61 72  mns in a view ar
2d80: 65 20 6e 61 6d 65 64 20 63 6f 72 72 65 63 74 6c  e named correctl
2d90: 79 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65  y..#.do_test vie
2da0: 77 2d 31 39 2e 31 20 7b 0a 20 20 65 78 65 63 73  w-19.1 {.  execs
2db0: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
2dc0: 56 49 45 57 20 76 33 33 30 38 61 20 41 53 20 53  VIEW v3308a AS S
2dd0: 45 4c 45 43 54 20 72 6f 77 69 64 2c 20 2a 20 46  ELECT rowid, * F
2de0: 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 65 78  ROM t1;.  }.  ex
2df0: 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c  ecsql2 {.    SEL
2e00: 45 43 54 20 2a 20 46 52 4f 4d 20 76 33 33 30 38  ECT * FROM v3308
2e10: 61 0a 20 20 7d 0a 7d 20 7b 72 6f 77 69 64 20 31  a.  }.} {rowid 1
2e20: 20 61 20 31 20 62 20 32 20 63 20 33 20 72 6f 77   a 1 b 2 c 3 row
2e30: 69 64 20 32 20 61 20 34 20 62 20 35 20 63 20 36  id 2 a 4 b 5 c 6
2e40: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  }.do_test view-1
2e50: 39 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  9.2 {.  execsql 
2e60: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
2e70: 57 20 76 33 33 30 38 62 20 41 53 20 53 45 4c 45  W v3308b AS SELE
2e80: 43 54 20 74 31 2e 72 6f 77 69 64 2c 20 74 31 2e  CT t1.rowid, t1.
2e90: 61 2c 20 74 31 2e 62 2b 74 31 2e 63 20 46 52 4f  a, t1.b+t1.c FRO
2ea0: 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 65 78 65 63  M t1;.  }.  exec
2eb0: 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45 43  sql2 {.    SELEC
2ec0: 54 20 2a 20 46 52 4f 4d 20 76 33 33 30 38 62 0a  T * FROM v3308b.
2ed0: 20 20 7d 0a 7d 20 7b 72 6f 77 69 64 20 31 20 61    }.} {rowid 1 a
2ee0: 20 31 20 74 31 2e 62 2b 74 31 2e 63 20 35 20 72   1 t1.b+t1.c 5 r
2ef0: 6f 77 69 64 20 32 20 61 20 34 20 74 31 2e 62 2b  owid 2 a 4 t1.b+
2f00: 74 31 2e 63 20 31 31 7d 0a 64 6f 5f 74 65 73 74  t1.c 11}.do_test
2f10: 20 76 69 65 77 2d 31 39 2e 33 20 7b 0a 20 20 65   view-19.3 {.  e
2f20: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
2f30: 41 54 45 20 56 49 45 57 20 76 33 33 30 38 63 20  ATE VIEW v3308c 
2f40: 41 53 20 53 45 4c 45 43 54 20 74 31 2e 6f 69 64  AS SELECT t1.oid
2f50: 2c 20 41 2c 20 74 31 2e 62 2b 74 31 2e 63 20 41  , A, t1.b+t1.c A
2f60: 53 20 78 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  S x FROM t1;.  }
2f70: 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20  .  execsql2 {.  
2f80: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2f90: 76 33 33 30 38 63 0a 20 20 7d 0a 7d 20 7b 72 6f  v3308c.  }.} {ro
2fa0: 77 69 64 20 31 20 61 20 31 20 78 20 35 20 72 6f  wid 1 a 1 x 5 ro
2fb0: 77 69 64 20 32 20 61 20 34 20 78 20 31 31 7d 0a  wid 2 a 4 x 11}.
2fc0: 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a           .finish_test.