/ Hex Artifact Content
Login

Artifact b182a67ec43f490b156b5a710827a341be83dd17:


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 39 20 32 30 30 38 2f 31 32 2f 31 34 20  1.39 2008/12/14 
0200: 31 34 3a 34 35 3a 32 31 20 64 61 6e 69 65 6c 6b  14:45:21 danielk
0210: 31 39 37 37 20 45 78 70 20 24 0a 73 65 74 20 74  1977 Exp $.set t
0220: 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64 69 72  estdir [file dir
0230: 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73 6f 75  name $argv0].sou
0240: 72 63 65 20 24 74 65 73 74 64 69 72 2f 74 65 73  rce $testdir/tes
0250: 74 65 72 2e 74 63 6c 0a 0a 23 20 4f 6d 69 74 20  ter.tcl..# Omit 
0260: 74 68 69 73 20 65 6e 74 69 72 65 20 66 69 6c 65  this entire file
0270: 20 69 66 20 74 68 65 20 6c 69 62 72 61 72 79 20   if the library 
0280: 69 73 20 6e 6f 74 20 63 6f 6e 66 69 67 75 72 65  is not configure
0290: 64 20 77 69 74 68 20 76 69 65 77 73 20 65 6e 61  d with views ena
02a0: 62 6c 65 64 2e 0a 69 66 63 61 70 61 62 6c 65 20  bled..ifcapable 
02b0: 21 76 69 65 77 20 7b 0a 20 20 66 69 6e 69 73 68  !view {.  finish
02c0: 5f 74 65 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d  _test.  return.}
02d0: 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  ..do_test view-1
02e0: 2e 30 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .0 {.  execsql {
02f0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
0300: 45 20 74 31 28 61 2c 62 2c 63 29 3b 0a 20 20 20  E t1(a,b,c);.   
0310: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0320: 56 41 4c 55 45 53 28 31 2c 32 2c 33 29 3b 0a 20  VALUES(1,2,3);. 
0330: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0340: 31 20 56 41 4c 55 45 53 28 34 2c 35 2c 36 29 3b  1 VALUES(4,5,6);
0350: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0360: 20 74 31 20 56 41 4c 55 45 53 28 37 2c 38 2c 39   t1 VALUES(7,8,9
0370: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  );.    SELECT * 
0380: 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b  FROM t1;.  }.} {
0390: 31 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20  1 2 3 4 5 6 7 8 
03a0: 39 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  9}..do_test view
03b0: 2d 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -1.1 {.  execsql
03c0: 20 7b 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20   {.    BEGIN;.  
03d0: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 49 46    CREATE VIEW IF
03e0: 20 4e 4f 54 20 45 58 49 53 54 53 20 76 31 20 41   NOT EXISTS v1 A
03f0: 53 20 53 45 4c 45 43 54 20 61 2c 62 20 46 52 4f  S SELECT a,b FRO
0400: 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54  M t1;.    SELECT
0410: 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45 52   * FROM v1 ORDER
0420: 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31 20   BY a;.  }.} {1 
0430: 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f 74 65  2 4 5 7 8}.do_te
0440: 73 74 20 76 69 65 77 2d 31 2e 32 20 7b 0a 20 20  st view-1.2 {.  
0450: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 52  catchsql {.    R
0460: 4f 4c 4c 42 41 43 4b 3b 0a 20 20 20 20 53 45 4c  OLLBACK;.    SEL
0470: 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52  ECT * FROM v1 OR
0480: 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20  DER BY a;.  }.} 
0490: 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c  {1 {no such tabl
04a0: 65 3a 20 76 31 7d 7d 0a 64 6f 5f 74 65 73 74 20  e: v1}}.do_test 
04b0: 76 69 65 77 2d 31 2e 33 20 7b 0a 20 20 65 78 65  view-1.3 {.  exe
04c0: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
04d0: 45 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c  E VIEW v1 AS SEL
04e0: 45 43 54 20 61 2c 62 20 46 52 4f 4d 20 74 31 3b  ECT a,b FROM t1;
04f0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
0500: 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61  OM v1 ORDER BY a
0510: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35  ;.  }.} {1 2 4 5
0520: 20 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69   7 8}.do_test vi
0530: 65 77 2d 31 2e 33 2e 31 20 7b 0a 20 20 64 62 20  ew-1.3.1 {.  db 
0540: 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20  close.  sqlite3 
0550: 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65  db test.db.  exe
0560: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
0570: 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45  T * FROM v1 ORDE
0580: 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31  R BY a;.  }.} {1
0590: 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f 74   2 4 5 7 8}.do_t
05a0: 65 73 74 20 76 69 65 77 2d 31 2e 34 20 7b 0a 20  est view-1.4 {. 
05b0: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
05c0: 44 52 4f 50 20 56 49 45 57 20 49 46 20 45 58 49  DROP VIEW IF EXI
05d0: 53 54 53 20 76 31 3b 0a 20 20 20 20 53 45 4c 45  STS v1;.    SELE
05e0: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
05f0: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
0600: 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c 65  1 {no such table
0610: 3a 20 76 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76  : v1}}.do_test v
0620: 69 65 77 2d 31 2e 35 20 7b 0a 20 20 65 78 65 63  iew-1.5 {.  exec
0630: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
0640: 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c 45   VIEW v1 AS SELE
0650: 43 54 20 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a  CT a,b FROM t1;.
0660: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0670: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
0680: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 35 20  .  }.} {1 2 4 5 
0690: 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  7 8}.do_test vie
06a0: 77 2d 31 2e 36 20 7b 0a 20 20 63 61 74 63 68 73  w-1.6 {.  catchs
06b0: 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41  ql {.    DROP TA
06c0: 42 4c 45 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  BLE t1;.    SELE
06d0: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
06e0: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
06f0: 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c 65  1 {no such table
0700: 3a 20 6d 61 69 6e 2e 74 31 7d 7d 0a 64 6f 5f 74  : main.t1}}.do_t
0710: 65 73 74 20 76 69 65 77 2d 31 2e 37 20 7b 0a 20  est view-1.7 {. 
0720: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
0730: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 78  REATE TABLE t1(x
0740: 2c 61 2c 62 2c 63 29 3b 0a 20 20 20 20 49 4e 53  ,a,b,c);.    INS
0750: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
0760: 45 53 28 31 2c 32 2c 33 2c 34 29 3b 0a 20 20 20  ES(1,2,3,4);.   
0770: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0780: 56 41 4c 55 45 53 28 34 2c 35 2c 36 2c 37 29 3b  VALUES(4,5,6,7);
0790: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
07a0: 20 74 31 20 56 41 4c 55 45 53 28 37 2c 38 2c 39   t1 VALUES(7,8,9
07b0: 2c 31 30 29 3b 0a 20 20 20 20 53 45 4c 45 43 54  ,10);.    SELECT
07c0: 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45 52   * FROM v1 ORDER
07d0: 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 32 20   BY a;.  }.} {2 
07e0: 33 20 35 20 36 20 38 20 39 7d 0a 64 6f 5f 74 65  3 5 6 8 9}.do_te
07f0: 73 74 20 76 69 65 77 2d 31 2e 38 20 7b 0a 20 20  st view-1.8 {.  
0800: 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74  db close.  sqlit
0810: 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20  e3 db test.db.  
0820: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
0830: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f  LECT * FROM v1 O
0840: 52 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d  RDER BY a;.  }.}
0850: 20 7b 32 20 33 20 35 20 36 20 38 20 39 7d 0a 0a   {2 3 5 6 8 9}..
0860: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 31  do_test view-2.1
0870: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
0880: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
0890: 32 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52  2 AS SELECT * FR
08a0: 4f 4d 20 74 31 20 57 48 45 52 45 20 61 3e 35 0a  OM t1 WHERE a>5.
08b0: 20 20 7d 3b 20 20 23 20 4e 6f 20 73 65 6d 69 63    };  # No semic
08c0: 6f 6c 6f 6e 0a 20 20 65 78 65 63 73 71 6c 32 20  olon.  execsql2 
08d0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
08e0: 52 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 78  ROM v2;.  }.} {x
08f0: 20 37 20 61 20 38 20 62 20 39 20 63 20 31 30 7d   7 a 8 b 9 c 10}
0900: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e  .do_test view-2.
0910: 32 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  2 {.  catchsql {
0920: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0930: 20 76 32 20 56 41 4c 55 45 53 28 31 2c 32 2c 33   v2 VALUES(1,2,3
0940: 2c 34 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 63  ,4);.  }.} {1 {c
0950: 61 6e 6e 6f 74 20 6d 6f 64 69 66 79 20 76 32 20  annot modify v2 
0960: 62 65 63 61 75 73 65 20 69 74 20 69 73 20 61 20  because it is a 
0970: 76 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76  view}}.do_test v
0980: 69 65 77 2d 32 2e 33 20 7b 0a 20 20 63 61 74 63  iew-2.3 {.  catc
0990: 68 73 71 6c 20 7b 0a 20 20 20 20 55 50 44 41 54  hsql {.    UPDAT
09a0: 45 20 76 32 20 53 45 54 20 61 3d 31 30 20 57 48  E v2 SET a=10 WH
09b0: 45 52 45 20 61 3d 35 3b 0a 20 20 7d 0a 7d 20 7b  ERE a=5;.  }.} {
09c0: 31 20 7b 63 61 6e 6e 6f 74 20 6d 6f 64 69 66 79  1 {cannot modify
09d0: 20 76 32 20 62 65 63 61 75 73 65 20 69 74 20 69   v2 because it i
09e0: 73 20 61 20 76 69 65 77 7d 7d 0a 64 6f 5f 74 65  s a view}}.do_te
09f0: 73 74 20 76 69 65 77 2d 32 2e 34 20 7b 0a 20 20  st view-2.4 {.  
0a00: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 44  catchsql {.    D
0a10: 45 4c 45 54 45 20 46 52 4f 4d 20 76 32 3b 0a 20  ELETE FROM v2;. 
0a20: 20 7d 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20   }.} {1 {cannot 
0a30: 6d 6f 64 69 66 79 20 76 32 20 62 65 63 61 75 73  modify v2 becaus
0a40: 65 20 69 74 20 69 73 20 61 20 76 69 65 77 7d 7d  e it is a view}}
0a50: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e  .do_test view-2.
0a60: 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  5 {.  execsql {.
0a70: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0a80: 74 31 20 56 41 4c 55 45 53 28 31 31 2c 31 32 2c  t1 VALUES(11,12,
0a90: 31 33 2c 31 34 29 3b 0a 20 20 20 20 53 45 4c 45  13,14);.    SELE
0aa0: 43 54 20 2a 20 46 52 4f 4d 20 76 32 20 4f 52 44  CT * FROM v2 ORD
0ab0: 45 52 20 42 59 20 78 3b 0a 20 20 7d 0a 7d 20 7b  ER BY x;.  }.} {
0ac0: 37 20 38 20 39 20 31 30 20 31 31 20 31 32 20 31  7 8 9 10 11 12 1
0ad0: 33 20 31 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69  3 14}.do_test vi
0ae0: 65 77 2d 32 2e 36 20 7b 0a 20 20 65 78 65 63 73  ew-2.6 {.  execs
0af0: 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  ql {.    SELECT 
0b00: 78 20 46 52 4f 4d 20 76 32 20 57 48 45 52 45 20  x FROM v2 WHERE 
0b10: 61 3e 31 30 0a 20 20 7d 0a 7d 20 7b 31 31 7d 0a  a>10.  }.} {11}.
0b20: 0a 23 20 54 65 73 74 20 74 68 61 74 20 63 6f 6c  .# Test that col
0b30: 75 6d 6e 20 6e 61 6d 65 20 6f 66 20 76 69 65 77  umn name of view
0b40: 73 20 61 72 65 20 67 65 6e 65 72 61 74 65 64 20  s are generated 
0b50: 63 6f 72 72 65 63 74 6c 79 2e 0a 23 0a 64 6f 5f  correctly..#.do_
0b60: 74 65 73 74 20 76 69 65 77 2d 33 2e 31 20 7b 0a  test view-3.1 {.
0b70: 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20    execsql2 {.   
0b80: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
0b90: 31 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a 7d 20  1 LIMIT 1.  }.} 
0ba0: 7b 61 20 32 20 62 20 33 7d 0a 64 6f 5f 74 65 73  {a 2 b 3}.do_tes
0bb0: 74 20 76 69 65 77 2d 33 2e 32 20 7b 0a 20 20 65  t view-3.2 {.  e
0bc0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45  xecsql2 {.    SE
0bd0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 20 4c  LECT * FROM v2 L
0be0: 49 4d 49 54 20 31 0a 20 20 7d 0a 7d 20 7b 78 20  IMIT 1.  }.} {x 
0bf0: 37 20 61 20 38 20 62 20 39 20 63 20 31 30 7d 0a  7 a 8 b 9 c 10}.
0c00: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33 2e 33  do_test view-3.3
0c10: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20  .1 {.  execsql2 
0c20: 7b 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20  {.    DROP VIEW 
0c30: 76 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56  v1;.    CREATE V
0c40: 49 45 57 20 76 31 20 41 53 20 53 45 4c 45 43 54  IEW v1 AS SELECT
0c50: 20 61 20 41 53 20 27 78 79 7a 27 2c 20 62 2b 63   a AS 'xyz', b+c
0c60: 20 41 53 20 27 70 71 72 27 2c 20 63 2d 62 20 46   AS 'pqr', c-b F
0c70: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  ROM t1;.    SELE
0c80: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4c 49 4d  CT * FROM v1 LIM
0c90: 49 54 20 31 0a 20 20 7d 0a 7d 20 7b 78 79 7a 20  IT 1.  }.} {xyz 
0ca0: 32 20 70 71 72 20 37 20 63 2d 62 20 31 7d 0a 64  2 pqr 7 c-b 1}.d
0cb0: 6f 5f 74 65 73 74 20 76 69 65 77 2d 33 2e 33 2e  o_test view-3.3.
0cc0: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20 7b  2 {.  execsql2 {
0cd0: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
0ce0: 20 76 31 62 20 41 53 20 53 45 4c 45 43 54 20 74   v1b AS SELECT t
0cf0: 31 2e 61 2c 20 62 2b 63 2c 20 74 31 2e 63 20 46  1.a, b+c, t1.c F
0d00: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  ROM t1;.    SELE
0d10: 43 54 20 2a 20 46 52 4f 4d 20 76 31 62 20 4c 49  CT * FROM v1b LI
0d20: 4d 49 54 20 31 0a 20 20 7d 0a 7d 20 7b 61 20 32  MIT 1.  }.} {a 2
0d30: 20 62 2b 63 20 37 20 63 20 34 7d 0a 0a 69 66 63   b+c 7 c 4}..ifc
0d40: 61 70 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64 20  apable compound 
0d50: 7b 0a 64 6f 5f 74 65 73 74 20 20 76 69 65 77 2d  {.do_test  view-
0d60: 33 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 32  3.4 {.  execsql2
0d70: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
0d80: 45 57 20 76 33 20 41 53 20 53 45 4c 45 43 54 20  EW v3 AS SELECT 
0d90: 61 20 46 52 4f 4d 20 74 31 20 55 4e 49 4f 4e 20  a FROM t1 UNION 
0da0: 53 45 4c 45 43 54 20 62 20 46 52 4f 4d 20 74 31  SELECT b FROM t1
0db0: 20 4f 52 44 45 52 20 42 59 20 62 3b 0a 20 20 20   ORDER BY b;.   
0dc0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
0dd0: 33 20 4c 49 4d 49 54 20 34 3b 0a 20 20 7d 0a 7d  3 LIMIT 4;.  }.}
0de0: 20 7b 61 20 32 20 61 20 33 20 61 20 35 20 61 20   {a 2 a 3 a 5 a 
0df0: 36 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  6}.do_test view-
0e00: 33 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 32  3.5 {.  execsql2
0e10: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
0e20: 45 57 20 76 34 20 41 53 20 0a 20 20 20 20 20 20  EW v4 AS .      
0e30: 53 45 4c 45 43 54 20 61 2c 20 62 20 46 52 4f 4d  SELECT a, b FROM
0e40: 20 74 31 20 0a 20 20 20 20 20 20 55 4e 49 4f 4e   t1 .      UNION
0e50: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 62 20  .      SELECT b 
0e60: 41 53 20 27 78 27 2c 20 61 20 41 53 20 27 79 27  AS 'x', a AS 'y'
0e70: 20 46 52 4f 4d 20 74 31 0a 20 20 20 20 20 20 4f   FROM t1.      O
0e80: 52 44 45 52 20 42 59 20 78 2c 20 79 3b 0a 20 20  RDER BY x, y;.  
0e90: 20 20 53 45 4c 45 43 54 20 62 20 46 52 4f 4d 20    SELECT b FROM 
0ea0: 76 34 20 4f 52 44 45 52 20 42 59 20 62 20 4c 49  v4 ORDER BY b LI
0eb0: 4d 49 54 20 34 3b 0a 20 20 7d 0a 7d 20 7b 62 20  MIT 4;.  }.} {b 
0ec0: 32 20 62 20 33 20 62 20 35 20 62 20 36 7d 0a 7d  2 b 3 b 5 b 6}.}
0ed0: 20 3b 23 20 69 66 63 61 70 61 62 6c 65 20 63 6f   ;# ifcapable co
0ee0: 6d 70 6f 75 6e 64 0a 0a 0a 64 6f 5f 74 65 73 74  mpound...do_test
0ef0: 20 76 69 65 77 2d 34 2e 31 20 7b 0a 20 20 63 61   view-4.1 {.  ca
0f00: 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f  tchsql {.    DRO
0f10: 50 20 56 49 45 57 20 74 31 3b 0a 20 20 7d 0a 7d  P VIEW t1;.  }.}
0f20: 20 7b 31 20 7b 75 73 65 20 44 52 4f 50 20 54 41   {1 {use DROP TA
0f30: 42 4c 45 20 74 6f 20 64 65 6c 65 74 65 20 74 61  BLE to delete ta
0f40: 62 6c 65 20 74 31 7d 7d 0a 64 6f 5f 74 65 73 74  ble t1}}.do_test
0f50: 20 76 69 65 77 2d 34 2e 32 20 7b 0a 20 20 65 78   view-4.2 {.  ex
0f60: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
0f70: 43 54 20 31 20 46 52 4f 4d 20 74 31 20 4c 49 4d  CT 1 FROM t1 LIM
0f80: 49 54 20 31 3b 0a 20 20 7d 0a 7d 20 31 0a 64 6f  IT 1;.  }.} 1.do
0f90: 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 33 20 7b  _test view-4.3 {
0fa0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
0fb0: 20 20 44 52 4f 50 20 54 41 42 4c 45 20 76 31 3b    DROP TABLE v1;
0fc0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73 65 20 44  .  }.} {1 {use D
0fd0: 52 4f 50 20 56 49 45 57 20 74 6f 20 64 65 6c 65  ROP VIEW to dele
0fe0: 74 65 20 76 69 65 77 20 76 31 7d 7d 0a 64 6f 5f  te view v1}}.do_
0ff0: 74 65 73 74 20 76 69 65 77 2d 34 2e 34 20 7b 0a  test view-4.4 {.
1000: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1010: 20 53 45 4c 45 43 54 20 31 20 46 52 4f 4d 20 76   SELECT 1 FROM v
1020: 31 20 4c 49 4d 49 54 20 31 3b 0a 20 20 7d 0a 7d  1 LIMIT 1;.  }.}
1030: 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65   {1}.do_test vie
1040: 77 2d 34 2e 35 20 7b 0a 20 20 63 61 74 63 68 73  w-4.5 {.  catchs
1050: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
1060: 49 4e 44 45 58 20 69 31 76 31 20 4f 4e 20 76 31  INDEX i1v1 ON v1
1070: 28 78 79 7a 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20  (xyz);.  }.} {1 
1080: 7b 76 69 65 77 73 20 6d 61 79 20 6e 6f 74 20 62  {views may not b
1090: 65 20 69 6e 64 65 78 65 64 7d 7d 0a 0a 64 6f 5f  e indexed}}..do_
10a0: 74 65 73 74 20 76 69 65 77 2d 35 2e 31 20 7b 0a  test view-5.1 {.
10b0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
10c0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
10d0: 79 2c 61 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  y,a);.    INSERT
10e0: 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28   INTO t2 VALUES(
10f0: 32 32 2c 32 29 3b 0a 20 20 20 20 49 4e 53 45 52  22,2);.    INSER
1100: 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53  T INTO t2 VALUES
1110: 28 33 33 2c 33 29 3b 0a 20 20 20 20 49 4e 53 45  (33,3);.    INSE
1120: 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45  RT INTO t2 VALUE
1130: 53 28 34 34 2c 34 29 3b 0a 20 20 20 20 49 4e 53  S(44,4);.    INS
1140: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
1150: 45 53 28 35 35 2c 35 29 3b 0a 20 20 20 20 53 45  ES(55,5);.    SE
1160: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a  LECT * FROM t2;.
1170: 20 20 7d 0a 7d 20 7b 32 32 20 32 20 33 33 20 33    }.} {22 2 33 3
1180: 20 34 34 20 34 20 35 35 20 35 7d 0a 64 6f 5f 74   44 4 55 5}.do_t
1190: 65 73 74 20 76 69 65 77 2d 35 2e 32 20 7b 0a 20  est view-5.2 {. 
11a0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
11b0: 52 45 41 54 45 20 56 49 45 57 20 76 35 20 41 53  REATE VIEW v5 AS
11c0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 74 31  .      SELECT t1
11d0: 2e 78 20 41 53 20 76 2c 20 74 32 2e 79 20 41 53  .x AS v, t2.y AS
11e0: 20 77 20 46 52 4f 4d 20 74 31 20 4a 4f 49 4e 20   w FROM t1 JOIN 
11f0: 74 32 20 55 53 49 4e 47 28 61 29 3b 0a 20 20 20  t2 USING(a);.   
1200: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
1210: 35 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 32 20 34  5;.  }.} {1 22 4
1220: 20 35 35 7d 0a 0a 23 20 56 65 72 69 66 79 20 74   55}..# Verify t
1230: 68 61 74 20 74 68 65 20 76 69 65 77 20 76 35 20  hat the view v5 
1240: 67 65 74 73 20 66 6c 61 74 74 65 6e 65 64 2e 20  gets flattened. 
1250: 20 73 65 65 20 73 71 6c 69 74 65 46 6c 61 74 74   see sqliteFlatt
1260: 65 6e 53 75 62 71 75 65 72 79 28 29 2e 0a 23 20  enSubquery()..# 
1270: 54 68 69 73 20 77 69 6c 6c 20 6f 6e 6c 79 20 77  This will only w
1280: 6f 72 6b 20 69 66 20 45 58 50 4c 41 49 4e 20 69  ork if EXPLAIN i
1290: 73 20 65 6e 61 62 6c 65 64 2e 0a 23 20 54 69 63  s enabled..# Tic
12a0: 6b 65 74 20 23 32 37 32 0a 23 0a 69 66 63 61 70  ket #272.#.ifcap
12b0: 61 62 6c 65 20 7b 65 78 70 6c 61 69 6e 7d 20 7b  able {explain} {
12c0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e  .do_test view-5.
12d0: 33 20 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b 65  3 {.  lsearch [e
12e0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 45 58 50  xecsql {.    EXP
12f0: 4c 41 49 4e 20 53 45 4c 45 43 54 20 2a 20 46 52  LAIN SELECT * FR
1300: 4f 4d 20 76 35 3b 0a 20 20 7d 5d 20 4f 70 65 6e  OM v5;.  }] Open
1310: 45 70 68 65 6d 65 72 61 6c 0a 7d 20 7b 2d 31 7d  Ephemeral.} {-1}
1320: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e  .do_test view-5.
1330: 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  4 {.  execsql {.
1340: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1350: 4d 20 76 35 20 41 53 20 61 2c 20 74 32 20 41 53  M v5 AS a, t2 AS
1360: 20 62 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79   b WHERE a.w=b.y
1370: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 32 20 32 32  ;.  }.} {1 22 22
1380: 20 32 20 34 20 35 35 20 35 35 20 35 7d 0a 64 6f   2 4 55 55 5}.do
1390: 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 35 20 7b  _test view-5.5 {
13a0: 0a 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65 63  .  lsearch [exec
13b0: 73 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41 49  sql {.    EXPLAI
13c0: 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  N SELECT * FROM 
13d0: 76 35 20 41 53 20 61 2c 20 74 32 20 41 53 20 62  v5 AS a, t2 AS b
13e0: 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b 0a   WHERE a.w=b.y;.
13f0: 20 20 7d 5d 20 4f 70 65 6e 45 70 68 65 6d 65 72    }] OpenEphemer
1400: 61 6c 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65 73  al.} {-1}.do_tes
1410: 74 20 76 69 65 77 2d 35 2e 36 20 7b 0a 20 20 65  t view-5.6 {.  e
1420: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1430: 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 41 53  ECT * FROM t2 AS
1440: 20 62 2c 20 76 35 20 41 53 20 61 20 57 48 45 52   b, v5 AS a WHER
1450: 45 20 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 0a 7d  E a.w=b.y;.  }.}
1460: 20 7b 32 32 20 32 20 31 20 32 32 20 35 35 20 35   {22 2 1 22 55 5
1470: 20 34 20 35 35 7d 0a 64 6f 5f 74 65 73 74 20 76   4 55}.do_test v
1480: 69 65 77 2d 35 2e 37 20 7b 0a 20 20 6c 73 65 61  iew-5.7 {.  lsea
1490: 72 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20  rch [execsql {. 
14a0: 20 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43     EXPLAIN SELEC
14b0: 54 20 2a 20 46 52 4f 4d 20 74 32 20 41 53 20 62  T * FROM t2 AS b
14c0: 2c 20 76 35 20 41 53 20 61 20 57 48 45 52 45 20  , v5 AS a WHERE 
14d0: 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 5d 20 4f 70  a.w=b.y;.  }] Op
14e0: 65 6e 45 70 68 65 6d 65 72 61 6c 0a 7d 20 7b 2d  enEphemeral.} {-
14f0: 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  1}.do_test view-
1500: 35 2e 38 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  5.8 {.  execsql 
1510: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
1520: 52 4f 4d 20 74 31 20 41 53 20 61 2c 20 76 35 20  ROM t1 AS a, v5 
1530: 41 53 20 62 2c 20 74 32 20 41 53 20 63 20 57 48  AS b, t2 AS c WH
1540: 45 52 45 20 61 2e 78 3d 62 2e 76 20 41 4e 44 20  ERE a.x=b.v AND 
1550: 62 2e 77 3d 63 2e 79 3b 0a 20 20 7d 0a 7d 20 7b  b.w=c.y;.  }.} {
1560: 31 20 32 20 33 20 34 20 31 20 32 32 20 32 32 20  1 2 3 4 1 22 22 
1570: 32 20 34 20 35 20 36 20 37 20 34 20 35 35 20 35  2 4 5 6 7 4 55 5
1580: 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  5 5}.do_test vie
1590: 77 2d 35 2e 39 20 7b 0a 20 20 6c 73 65 61 72 63  w-5.9 {.  lsearc
15a0: 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  h [execsql {.   
15b0: 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43 54 20   EXPLAIN SELECT 
15c0: 2a 20 46 52 4f 4d 20 74 31 20 41 53 20 61 2c 20  * FROM t1 AS a, 
15d0: 76 35 20 41 53 20 62 2c 20 74 32 20 41 53 20 63  v5 AS b, t2 AS c
15e0: 20 57 48 45 52 45 20 61 2e 78 3d 62 2e 76 20 41   WHERE a.x=b.v A
15f0: 4e 44 20 62 2e 77 3d 63 2e 79 3b 0a 20 20 7d 5d  ND b.w=c.y;.  }]
1600: 20 4f 70 65 6e 45 70 68 65 6d 65 72 61 6c 0a 7d   OpenEphemeral.}
1610: 20 7b 2d 31 7d 0a 7d 20 3b 23 20 65 6e 64 69 66   {-1}.} ;# endif
1620: 20 65 78 70 6c 61 69 6e 0a 0a 64 6f 5f 74 65 73   explain..do_tes
1630: 74 20 76 69 65 77 2d 36 2e 31 20 7b 0a 20 20 65  t view-6.1 {.  e
1640: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1650: 45 43 54 20 6d 69 6e 28 78 29 2c 20 6d 69 6e 28  ECT min(x), min(
1660: 61 29 2c 20 6d 69 6e 28 62 29 2c 20 6d 69 6e 28  a), min(b), min(
1670: 63 29 2c 20 6d 69 6e 28 61 2b 62 2b 63 29 20 46  c), min(a+b+c) F
1680: 52 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 37  ROM v2;.  }.} {7
1690: 20 38 20 39 20 31 30 20 32 37 7d 0a 64 6f 5f 74   8 9 10 27}.do_t
16a0: 65 73 74 20 76 69 65 77 2d 36 2e 32 20 7b 0a 20  est view-6.2 {. 
16b0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
16c0: 45 4c 45 43 54 20 6d 61 78 28 78 29 2c 20 6d 61  ELECT max(x), ma
16d0: 78 28 61 29 2c 20 6d 61 78 28 62 29 2c 20 6d 61  x(a), max(b), ma
16e0: 78 28 63 29 2c 20 6d 61 78 28 61 2b 62 2b 63 29  x(c), max(a+b+c)
16f0: 20 46 52 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20   FROM v2;.  }.} 
1700: 7b 31 31 20 31 32 20 31 33 20 31 34 20 33 39 7d  {11 12 13 14 39}
1710: 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37  ..do_test view-7
1720: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .1 {.  execsql {
1730: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
1740: 45 20 74 65 73 74 31 28 69 64 20 69 6e 74 65 67  E test1(id integ
1750: 65 72 20 70 72 69 6d 61 72 79 20 6b 65 79 2c 20  er primary key, 
1760: 61 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  a);.    CREATE T
1770: 41 42 4c 45 20 74 65 73 74 32 28 69 64 20 69 6e  ABLE test2(id in
1780: 74 65 67 65 72 2c 20 62 29 3b 0a 20 20 20 20 49  teger, b);.    I
1790: 4e 53 45 52 54 20 49 4e 54 4f 20 74 65 73 74 31  NSERT INTO test1
17a0: 20 56 41 4c 55 45 53 28 31 2c 32 29 3b 0a 20 20   VALUES(1,2);.  
17b0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 65    INSERT INTO te
17c0: 73 74 32 20 56 41 4c 55 45 53 28 31 2c 33 29 3b  st2 VALUES(1,3);
17d0: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
17e0: 20 74 65 73 74 20 41 53 0a 20 20 20 20 20 20 53   test AS.      S
17f0: 45 4c 45 43 54 20 74 65 73 74 31 2e 69 64 2c 20  ELECT test1.id, 
1800: 61 2c 20 62 0a 20 20 20 20 20 20 46 52 4f 4d 20  a, b.      FROM 
1810: 74 65 73 74 31 20 4a 4f 49 4e 20 74 65 73 74 32  test1 JOIN test2
1820: 20 4f 4e 20 74 65 73 74 32 2e 69 64 3d 74 65 73   ON test2.id=tes
1830: 74 31 2e 69 64 3b 0a 20 20 20 20 53 45 4c 45 43  t1.id;.    SELEC
1840: 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20  T * FROM test;. 
1850: 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f   }.} {1 2 3}.do_
1860: 74 65 73 74 20 76 69 65 77 2d 37 2e 32 20 7b 0a  test view-7.2 {.
1870: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c    db close.  sql
1880: 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a  ite3 db test.db.
1890: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
18a0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65  SELECT * FROM te
18b0: 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  st;.  }.} {1 2 3
18c0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37  }.do_test view-7
18d0: 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .3 {.  execsql {
18e0: 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20 74  .    DROP VIEW t
18f0: 65 73 74 3b 0a 20 20 20 20 43 52 45 41 54 45 20  est;.    CREATE 
1900: 56 49 45 57 20 74 65 73 74 20 41 53 0a 20 20 20  VIEW test AS.   
1910: 20 20 20 53 45 4c 45 43 54 20 74 65 73 74 31 2e     SELECT test1.
1920: 69 64 2c 20 61 2c 20 62 0a 20 20 20 20 20 20 46  id, a, b.      F
1930: 52 4f 4d 20 74 65 73 74 31 20 4a 4f 49 4e 20 74  ROM test1 JOIN t
1940: 65 73 74 32 20 55 53 49 4e 47 28 69 64 29 3b 0a  est2 USING(id);.
1950: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1960: 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31  M test;.  }.} {1
1970: 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69   2 3}.do_test vi
1980: 65 77 2d 37 2e 34 20 7b 0a 20 20 64 62 20 63 6c  ew-7.4 {.  db cl
1990: 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62  ose.  sqlite3 db
19a0: 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73   test.db.  execs
19b0: 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  ql {.    SELECT 
19c0: 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d  * FROM test;.  }
19d0: 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65  .} {1 2 3}.do_te
19e0: 73 74 20 76 69 65 77 2d 37 2e 35 20 7b 0a 20 20  st view-7.5 {.  
19f0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52  execsql {.    DR
1a00: 4f 50 20 56 49 45 57 20 74 65 73 74 3b 0a 20 20  OP VIEW test;.  
1a10: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 74 65    CREATE VIEW te
1a20: 73 74 20 41 53 0a 20 20 20 20 20 20 53 45 4c 45  st AS.      SELE
1a30: 43 54 20 74 65 73 74 31 2e 69 64 2c 20 61 2c 20  CT test1.id, a, 
1a40: 62 0a 20 20 20 20 20 20 46 52 4f 4d 20 74 65 73  b.      FROM tes
1a50: 74 31 20 4e 41 54 55 52 41 4c 20 4a 4f 49 4e 20  t1 NATURAL JOIN 
1a60: 74 65 73 74 32 3b 0a 20 20 20 20 53 45 4c 45 43  test2;.    SELEC
1a70: 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20  T * FROM test;. 
1a80: 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f   }.} {1 2 3}.do_
1a90: 74 65 73 74 20 76 69 65 77 2d 37 2e 36 20 7b 0a  test view-7.6 {.
1aa0: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c    db close.  sql
1ab0: 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a  ite3 db test.db.
1ac0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1ad0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65  SELECT * FROM te
1ae0: 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  st;.  }.} {1 2 3
1af0: 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }..do_test view-
1b00: 38 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  8.1 {.  execsql 
1b10: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
1b20: 57 20 76 36 20 41 53 20 53 45 4c 45 43 54 20 70  W v6 AS SELECT p
1b30: 71 72 2c 20 78 79 7a 20 46 52 4f 4d 20 76 31 3b  qr, xyz FROM v1;
1b40: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
1b50: 4f 4d 20 76 36 20 4f 52 44 45 52 20 42 59 20 78  OM v6 ORDER BY x
1b60: 79 7a 3b 0a 20 20 7d 0a 7d 20 7b 37 20 32 20 31  yz;.  }.} {7 2 1
1b70: 33 20 35 20 31 39 20 38 20 32 37 20 31 32 7d 0a  3 5 19 8 27 12}.
1b80: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e 32  do_test view-8.2
1b90: 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20   {.  db close.  
1ba0: 73 71 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e  sqlite3 db test.
1bb0: 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  db.  execsql {. 
1bc0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
1bd0: 20 76 36 20 4f 52 44 45 52 20 42 59 20 78 79 7a   v6 ORDER BY xyz
1be0: 3b 0a 20 20 7d 0a 7d 20 7b 37 20 32 20 31 33 20  ;.  }.} {7 2 13 
1bf0: 35 20 31 39 20 38 20 32 37 20 31 32 7d 0a 64 6f  5 19 8 27 12}.do
1c00: 5f 74 65 73 74 20 76 69 65 77 2d 38 2e 33 20 7b  _test view-8.3 {
1c10: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1c20: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 37 20   CREATE VIEW v7 
1c30: 41 53 20 53 45 4c 45 43 54 20 70 71 72 2b 78 79  AS SELECT pqr+xy
1c40: 7a 20 41 53 20 61 20 46 52 4f 4d 20 76 36 3b 0a  z AS a FROM v6;.
1c50: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1c60: 4d 20 76 37 20 4f 52 44 45 52 20 42 59 20 61 3b  M v7 ORDER BY a;
1c70: 0a 20 20 7d 0a 7d 20 7b 39 20 31 38 20 32 37 20  .  }.} {9 18 27 
1c80: 33 39 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 73  39}..ifcapable s
1c90: 75 62 71 75 65 72 79 20 7b 0a 20 20 64 6f 5f 74  ubquery {.  do_t
1ca0: 65 73 74 20 76 69 65 77 2d 38 2e 34 20 7b 0a 20  est view-8.4 {. 
1cb0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
1cc0: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
1cd0: 38 20 41 53 20 53 45 4c 45 43 54 20 6d 61 78 28  8 AS SELECT max(
1ce0: 63 6e 74 29 20 41 53 20 6d 78 20 46 52 4f 4d 0a  cnt) AS mx FROM.
1cf0: 20 20 20 20 20 20 20 20 28 53 45 4c 45 43 54 20          (SELECT 
1d00: 61 25 32 20 41 53 20 65 6f 2c 20 63 6f 75 6e 74  a%2 AS eo, count
1d10: 28 2a 29 20 41 53 20 63 6e 74 20 46 52 4f 4d 20  (*) AS cnt FROM 
1d20: 74 31 20 47 52 4f 55 50 20 42 59 20 65 6f 29 3b  t1 GROUP BY eo);
1d30: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20  .      SELECT * 
1d40: 46 52 4f 4d 20 76 38 3b 0a 20 20 20 20 7d 0a 20  FROM v8;.    }. 
1d50: 20 7d 20 33 0a 20 20 64 6f 5f 74 65 73 74 20 76   } 3.  do_test v
1d60: 69 65 77 2d 38 2e 35 20 7b 0a 20 20 20 20 65 78  iew-8.5 {.    ex
1d70: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45  ecsql {.      SE
1d80: 4c 45 43 54 20 6d 78 2b 31 30 2c 20 6d 78 2a 32  LECT mx+10, mx*2
1d90: 20 46 52 4f 4d 20 76 38 3b 0a 20 20 20 20 7d 0a   FROM v8;.    }.
1da0: 20 20 7d 20 7b 31 33 20 36 7d 0a 20 20 64 6f 5f    } {13 6}.  do_
1db0: 74 65 73 74 20 76 69 65 77 2d 38 2e 36 20 7b 0a  test view-8.6 {.
1dc0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20      execsql {.  
1dd0: 20 20 20 20 53 45 4c 45 43 54 20 6d 78 2b 31 30      SELECT mx+10
1de0: 2c 20 70 71 72 20 46 52 4f 4d 20 76 36 2c 20 76  , pqr FROM v6, v
1df0: 38 20 57 48 45 52 45 20 78 79 7a 3d 32 3b 0a 20  8 WHERE xyz=2;. 
1e00: 20 20 20 7d 0a 20 20 7d 20 7b 31 33 20 37 7d 0a     }.  } {13 7}.
1e10: 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38    do_test view-8
1e20: 2e 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .7 {.    execsql
1e30: 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20   {.      SELECT 
1e40: 6d 78 2b 31 30 2c 20 70 71 72 20 46 52 4f 4d 20  mx+10, pqr FROM 
1e50: 76 36 2c 20 76 38 20 57 48 45 52 45 20 78 79 7a  v6, v8 WHERE xyz
1e60: 3e 32 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31  >2;.    }.  } {1
1e70: 33 20 31 33 20 31 33 20 31 39 20 31 33 20 32 37  3 13 13 19 13 27
1e80: 7d 0a 7d 20 3b 23 20 69 66 63 61 70 61 62 6c 65  }.} ;# ifcapable
1e90: 20 73 75 62 71 75 65 72 79 0a 0a 23 20 54 65 73   subquery..# Tes
1ea0: 74 73 20 66 6f 72 20 61 20 62 75 67 20 66 6f 75  ts for a bug fou
1eb0: 6e 64 20 62 79 20 4d 69 63 68 69 65 6c 20 64 65  nd by Michiel de
1ec0: 20 57 69 74 20 69 6e 76 6f 6c 76 69 6e 67 20 4f   Wit involving O
1ed0: 52 44 45 52 20 42 59 20 69 6e 20 61 20 56 49 45  RDER BY in a VIE
1ee0: 57 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65  W..#.do_test vie
1ef0: 77 2d 39 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  w-9.1 {.  execsq
1f00: 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l {.    INSERT I
1f10: 4e 54 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20  NTO t2 SELECT * 
1f20: 46 52 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c  FROM t2 WHERE a<
1f30: 35 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  5;.    INSERT IN
1f40: 54 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46  TO t2 SELECT * F
1f50: 52 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c 34  ROM t2 WHERE a<4
1f60: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
1f70: 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52  O t2 SELECT * FR
1f80: 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c 33 3b  OM t2 WHERE a<3;
1f90: 0a 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54  .    SELECT DIST
1fa0: 49 4e 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52  INCT count(*) FR
1fb0: 4f 4d 20 74 32 20 47 52 4f 55 50 20 42 59 20 61  OM t2 GROUP BY a
1fc0: 20 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20 7d   ORDER BY 1;.  }
1fd0: 0a 7d 20 7b 31 20 32 20 34 20 38 7d 0a 64 6f 5f  .} {1 2 4 8}.do_
1fe0: 74 65 73 74 20 76 69 65 77 2d 39 2e 32 20 7b 0a  test view-9.2 {.
1ff0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
2000: 53 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20  SELECT DISTINCT 
2010: 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32  count(*) FROM t2
2020: 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52 44 45   GROUP BY a ORDE
2030: 52 20 42 59 20 31 20 4c 49 4d 49 54 20 33 3b 0a  R BY 1 LIMIT 3;.
2040: 20 20 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f    }.} {1 2 4}.do
2050: 5f 74 65 73 74 20 76 69 65 77 2d 39 2e 33 20 7b  _test view-9.3 {
2060: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
2070: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 39 20   CREATE VIEW v9 
2080: 41 53 20 0a 20 20 20 20 20 20 20 53 45 4c 45 43  AS .       SELEC
2090: 54 20 44 49 53 54 49 4e 43 54 20 63 6f 75 6e 74  T DISTINCT count
20a0: 28 2a 29 20 46 52 4f 4d 20 74 32 20 47 52 4f 55  (*) FROM t2 GROU
20b0: 50 20 42 59 20 61 20 4f 52 44 45 52 20 42 59 20  P BY a ORDER BY 
20c0: 31 20 4c 49 4d 49 54 20 33 3b 0a 20 20 20 20 53  1 LIMIT 3;.    S
20d0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 39 3b  ELECT * FROM v9;
20e0: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64  .  }.} {1 2 4}.d
20f0: 6f 5f 74 65 73 74 20 76 69 65 77 2d 39 2e 34 20  o_test view-9.4 
2100: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
2110: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2120: 76 39 20 4f 52 44 45 52 20 42 59 20 31 20 44 45  v9 ORDER BY 1 DE
2130: 53 43 3b 0a 20 20 7d 0a 7d 20 7b 34 20 32 20 31  SC;.  }.} {4 2 1
2140: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 39  }.do_test view-9
2150: 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .5 {.  execsql {
2160: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
2170: 20 76 31 30 20 41 53 20 0a 20 20 20 20 20 20 20   v10 AS .       
2180: 53 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20  SELECT DISTINCT 
2190: 61 2c 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d  a, count(*) FROM
21a0: 20 74 32 20 47 52 4f 55 50 20 42 59 20 61 20 4f   t2 GROUP BY a O
21b0: 52 44 45 52 20 42 59 20 32 20 4c 49 4d 49 54 20  RDER BY 2 LIMIT 
21c0: 33 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  3;.    SELECT * 
21d0: 46 52 4f 4d 20 76 31 30 3b 0a 20 20 7d 0a 7d 20  FROM v10;.  }.} 
21e0: 7b 35 20 31 20 34 20 32 20 33 20 34 7d 0a 64 6f  {5 1 4 2 3 4}.do
21f0: 5f 74 65 73 74 20 76 69 65 77 2d 39 2e 36 20 7b  _test view-9.6 {
2200: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
2210: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
2220: 31 30 20 4f 52 44 45 52 20 42 59 20 31 3b 0a 20  10 ORDER BY 1;. 
2230: 20 7d 0a 7d 20 7b 33 20 34 20 34 20 32 20 35 20   }.} {3 4 4 2 5 
2240: 31 7d 0a 0a 23 20 54 61 62 6c 65 73 20 77 69 74  1}..# Tables wit
2250: 68 20 63 6f 6c 75 6d 6e 73 20 68 61 76 69 6e 67  h columns having
2260: 20 70 65 63 75 6c 69 61 72 20 71 75 6f 74 65 64   peculiar quoted
2270: 20 6e 61 6d 65 73 20 75 73 65 64 20 69 6e 20 76   names used in v
2280: 69 65 77 73 0a 23 20 54 69 63 6b 65 74 20 23 37  iews.# Ticket #7
2290: 35 36 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69  56..#.do_test vi
22a0: 65 77 2d 31 30 2e 31 20 7b 0a 20 20 65 78 65 63  ew-10.1 {.  exec
22b0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
22c0: 20 54 41 42 4c 45 20 74 33 28 22 39 22 20 69 6e   TABLE t3("9" in
22d0: 74 65 67 65 72 2c 20 5b 34 5d 20 74 65 78 74 29  teger, [4] text)
22e0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
22f0: 4f 20 74 33 20 56 41 4c 55 45 53 28 31 2c 32 29  O t3 VALUES(1,2)
2300: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
2310: 57 20 76 5f 74 33 5f 61 20 41 53 20 53 45 4c 45  W v_t3_a AS SELE
2320: 43 54 20 61 2e 5b 39 5d 20 46 52 4f 4d 20 74 33  CT a.[9] FROM t3
2330: 20 41 53 20 61 3b 0a 20 20 20 20 43 52 45 41 54   AS a;.    CREAT
2340: 45 20 56 49 45 57 20 76 5f 74 33 5f 62 20 41 53  E VIEW v_t3_b AS
2350: 20 53 45 4c 45 43 54 20 22 34 22 20 46 52 4f 4d   SELECT "4" FROM
2360: 20 74 33 3b 0a 20 20 20 20 53 45 4c 45 43 54 20   t3;.    SELECT 
2370: 2a 20 46 52 4f 4d 20 76 5f 74 33 5f 61 3b 0a 20  * FROM v_t3_a;. 
2380: 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74   }.} {1}.do_test
2390: 20 76 69 65 77 2d 31 30 2e 32 20 7b 0a 20 20 65   view-10.2 {.  e
23a0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
23b0: 45 43 54 20 2a 20 46 52 4f 4d 20 76 5f 74 33 5f  ECT * FROM v_t3_
23c0: 62 3b 0a 20 20 7d 0a 7d 20 7b 32 7d 0a 0a 64 6f  b;.  }.} {2}..do
23d0: 5f 74 65 73 74 20 76 69 65 77 2d 31 31 2e 31 20  _test view-11.1 
23e0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
23f0: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
2400: 34 28 61 20 43 4f 4c 4c 41 54 45 20 4e 4f 43 41  4(a COLLATE NOCA
2410: 53 45 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  SE);.    INSERT 
2420: 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53 28 27  INTO t4 VALUES('
2430: 54 68 69 73 27 29 3b 0a 20 20 20 20 49 4e 53 45  This');.    INSE
2440: 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55 45  RT INTO t4 VALUE
2450: 53 28 27 74 68 69 73 27 29 3b 0a 20 20 20 20 49  S('this');.    I
2460: 4e 53 45 52 54 20 49 4e 54 4f 20 74 34 20 56 41  NSERT INTO t4 VA
2470: 4c 55 45 53 28 27 54 48 49 53 27 29 3b 0a 20 20  LUES('THIS');.  
2480: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2490: 74 34 20 57 48 45 52 45 20 61 20 3d 20 27 54 48  t4 WHERE a = 'TH
24a0: 49 53 27 3b 0a 20 20 7d 0a 7d 20 7b 54 68 69 73  IS';.  }.} {This
24b0: 20 74 68 69 73 20 54 48 49 53 7d 0a 69 66 63 61   this THIS}.ifca
24c0: 70 61 62 6c 65 20 73 75 62 71 75 65 72 79 20 7b  pable subquery {
24d0: 0a 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  .  do_test view-
24e0: 31 31 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73  11.2 {.    execs
24f0: 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43  ql {.      SELEC
2500: 54 20 2a 20 46 52 4f 4d 20 28 53 45 4c 45 43 54  T * FROM (SELECT
2510: 20 2a 20 46 52 4f 4d 20 74 34 29 20 57 48 45 52   * FROM t4) WHER
2520: 45 20 61 20 3d 20 27 54 48 49 53 27 3b 0a 20 20  E a = 'THIS';.  
2530: 20 20 7d 0a 20 20 7d 20 7b 54 68 69 73 20 74 68    }.  } {This th
2540: 69 73 20 54 48 49 53 7d 0a 7d 0a 64 6f 5f 74 65  is THIS}.}.do_te
2550: 73 74 20 76 69 65 77 2d 31 31 2e 33 20 7b 0a 20  st view-11.3 {. 
2560: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
2570: 52 45 41 54 45 20 56 49 45 57 20 76 31 31 20 41  REATE VIEW v11 A
2580: 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  S SELECT * FROM 
2590: 74 34 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t4;.    SELECT *
25a0: 20 46 52 4f 4d 20 76 31 31 20 57 48 45 52 45 20   FROM v11 WHERE 
25b0: 61 20 3d 20 27 54 48 49 53 27 3b 0a 20 20 7d 0a  a = 'THIS';.  }.
25c0: 7d 20 7b 54 68 69 73 20 74 68 69 73 20 54 48 49  } {This this THI
25d0: 53 7d 0a 0a 23 20 54 69 63 6b 65 74 20 23 31 32  S}..# Ticket #12
25e0: 37 30 3a 20 20 44 6f 20 6e 6f 74 20 61 6c 6c 6f  70:  Do not allo
25f0: 77 20 70 61 72 61 6d 65 74 65 72 73 20 69 6e 20  w parameters in 
2600: 76 69 65 77 20 64 65 66 69 6e 69 74 69 6f 6e 73  view definitions
2610: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  ..#.do_test view
2620: 2d 31 32 2e 31 20 7b 0a 20 20 63 61 74 63 68 73  -12.1 {.  catchs
2630: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
2640: 56 49 45 57 20 76 31 32 20 41 53 20 53 45 4c 45  VIEW v12 AS SELE
2650: 43 54 20 61 20 46 52 4f 4d 20 74 31 20 57 48 45  CT a FROM t1 WHE
2660: 52 45 20 62 3d 3f 0a 20 20 7d 0a 7d 20 7b 31 20  RE b=?.  }.} {1 
2670: 7b 70 61 72 61 6d 65 74 65 72 73 20 61 72 65 20  {parameters are 
2680: 6e 6f 74 20 61 6c 6c 6f 77 65 64 20 69 6e 20 76  not allowed in v
2690: 69 65 77 73 7d 7d 0a 0a 69 66 63 61 70 61 62 6c  iews}}..ifcapabl
26a0: 65 20 61 74 74 61 63 68 20 7b 0a 20 20 64 6f 5f  e attach {.  do_
26b0: 74 65 73 74 20 76 69 65 77 2d 31 33 2e 31 20 7b  test view-13.1 {
26c0: 0a 20 20 20 20 66 6f 72 63 65 64 65 6c 65 74 65  .    forcedelete
26d0: 20 74 65 73 74 32 2e 64 62 0a 20 20 20 20 63 61   test2.db.    ca
26e0: 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 20 20 41  tchsql {.      A
26f0: 54 54 41 43 48 20 27 74 65 73 74 32 2e 64 62 27  TTACH 'test2.db'
2700: 20 41 53 20 74 77 6f 3b 0a 20 20 20 20 20 20 43   AS two;.      C
2710: 52 45 41 54 45 20 54 41 42 4c 45 20 74 77 6f 2e  REATE TABLE two.
2720: 74 32 28 78 2c 79 29 3b 0a 20 20 20 20 20 20 43  t2(x,y);.      C
2730: 52 45 41 54 45 20 56 49 45 57 20 76 31 33 20 41  REATE VIEW v13 A
2740: 53 20 53 45 4c 45 43 54 20 79 20 46 52 4f 4d 20  S SELECT y FROM 
2750: 74 77 6f 2e 74 32 3b 0a 20 20 20 20 7d 0a 20 20  two.t2;.    }.  
2760: 7d 20 7b 31 20 7b 76 69 65 77 20 76 31 33 20 63  } {1 {view v13 c
2770: 61 6e 6e 6f 74 20 72 65 66 65 72 65 6e 63 65 20  annot reference 
2780: 6f 62 6a 65 63 74 73 20 69 6e 20 64 61 74 61 62  objects in datab
2790: 61 73 65 20 74 77 6f 7d 7d 0a 7d 0a 0a 23 20 54  ase two}}.}..# T
27a0: 69 63 6b 65 74 20 23 31 36 35 38 0a 23 0a 64 6f  icket #1658.#.do
27b0: 5f 74 65 73 74 20 76 69 65 77 2d 31 34 2e 31 20  _test view-14.1 
27c0: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
27d0: 20 20 20 43 52 45 41 54 45 20 54 45 4d 50 20 56     CREATE TEMP V
27e0: 49 45 57 20 74 31 20 41 53 20 53 45 4c 45 43 54  IEW t1 AS SELECT
27f0: 20 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20   a,b FROM t1;.  
2800: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2810: 74 65 6d 70 2e 74 31 3b 0a 20 20 7d 0a 7d 20 7b  temp.t1;.  }.} {
2820: 31 20 7b 76 69 65 77 20 74 31 20 69 73 20 63 69  1 {view t1 is ci
2830: 72 63 75 6c 61 72 6c 79 20 64 65 66 69 6e 65 64  rcularly defined
2840: 7d 7d 0a 0a 23 20 54 69 63 6b 65 74 73 20 23 31  }}..# Tickets #1
2850: 36 38 38 2c 20 23 31 37 30 39 0a 23 0a 64 6f 5f  688, #1709.#.do_
2860: 74 65 73 74 20 76 69 65 77 2d 31 35 2e 31 20 7b  test view-15.1 {
2870: 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20  .  execsql2 {.  
2880: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31    CREATE VIEW v1
2890: 35 20 41 53 20 53 45 4c 45 43 54 20 61 20 41 53  5 AS SELECT a AS
28a0: 20 78 2c 20 62 20 41 53 20 79 20 46 52 4f 4d 20   x, b AS y FROM 
28b0: 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t1;.    SELECT *
28c0: 20 46 52 4f 4d 20 76 31 35 20 4c 49 4d 49 54 20   FROM v15 LIMIT 
28d0: 31 3b 0a 20 20 7d 0a 7d 20 7b 78 20 32 20 79 20  1;.  }.} {x 2 y 
28e0: 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  3}.do_test view-
28f0: 31 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c  15.2 {.  execsql
2900: 32 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 78  2 {.    SELECT x
2910: 2c 20 79 20 46 52 4f 4d 20 76 31 35 20 4c 49 4d  , y FROM v15 LIM
2920: 49 54 20 31 0a 20 20 7d 0a 7d 20 7b 78 20 32 20  IT 1.  }.} {x 2 
2930: 79 20 33 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69  y 3}..do_test vi
2940: 65 77 2d 31 36 2e 31 20 7b 0a 20 20 63 61 74 63  ew-16.1 {.  catc
2950: 68 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  hsql {.    CREAT
2960: 45 20 56 49 45 57 20 49 46 20 4e 4f 54 20 45 58  E VIEW IF NOT EX
2970: 49 53 54 53 20 76 31 20 41 53 20 53 45 4c 45 43  ISTS v1 AS SELEC
2980: 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  T * FROM t1;.  }
2990: 0a 7d 20 7b 30 20 7b 7d 7d 0a 64 6f 5f 74 65 73  .} {0 {}}.do_tes
29a0: 74 20 76 69 65 77 2d 31 36 2e 32 20 7b 0a 20 20  t view-16.2 {.  
29b0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
29c0: 4c 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 73 71  LECT sql FROM sq
29d0: 6c 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52  lite_master WHER
29e0: 45 20 6e 61 6d 65 3d 27 76 31 27 0a 20 20 7d 0a  E name='v1'.  }.
29f0: 7d 20 7b 7b 43 52 45 41 54 45 20 56 49 45 57 20  } {{CREATE VIEW 
2a00: 76 31 20 41 53 20 53 45 4c 45 43 54 20 61 20 41  v1 AS SELECT a A
2a10: 53 20 27 78 79 7a 27 2c 20 62 2b 63 20 41 53 20  S 'xyz', b+c AS 
2a20: 27 70 71 72 27 2c 20 63 2d 62 20 46 52 4f 4d 20  'pqr', c-b FROM 
2a30: 74 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  t1}}.do_test vie
2a40: 77 2d 31 36 2e 33 20 7b 0a 20 20 63 61 74 63 68  w-16.3 {.  catch
2a50: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56  sql {.    DROP V
2a60: 49 45 57 20 49 46 20 45 58 49 53 54 53 20 6e 6f  IEW IF EXISTS no
2a70: 73 75 63 68 76 69 65 77 0a 20 20 7d 0a 7d 20 7b  suchview.  }.} {
2a80: 30 20 7b 7d 7d 0a 0a 23 20 63 6f 72 72 65 63 74  0 {}}..# correct
2a90: 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 77   error message w
2aa0: 68 65 6e 20 61 74 74 65 6d 70 74 69 6e 67 20 74  hen attempting t
2ab0: 6f 20 64 72 6f 70 20 61 20 76 69 65 77 20 74 68  o drop a view th
2ac0: 61 74 20 64 6f 65 73 20 6e 6f 74 0a 23 20 65 78  at does not.# ex
2ad0: 69 73 74 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76  ist..#.do_test v
2ae0: 69 65 77 2d 31 37 2e 31 20 7b 0a 20 20 63 61 74  iew-17.1 {.  cat
2af0: 63 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50  chsql {.    DROP
2b00: 20 56 49 45 57 20 6e 6f 73 75 63 68 76 69 65 77   VIEW nosuchview
2b10: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75  .  }.} {1 {no su
2b20: 63 68 20 76 69 65 77 3a 20 6e 6f 73 75 63 68 76  ch view: nosuchv
2b30: 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69  iew}}.do_test vi
2b40: 65 77 2d 31 37 2e 32 20 7b 0a 20 20 63 61 74 63  ew-17.2 {.  catc
2b50: 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  hsql {.    DROP 
2b60: 56 49 45 57 20 6d 61 69 6e 2e 6e 6f 73 75 63 68  VIEW main.nosuch
2b70: 76 69 65 77 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e  view.  }.} {1 {n
2b80: 6f 20 73 75 63 68 20 76 69 65 77 3a 20 6d 61 69  o such view: mai
2b90: 6e 2e 6e 6f 73 75 63 68 76 69 65 77 7d 7d 0a 0a  n.nosuchview}}..
2ba0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 38 2e  do_test view-18.
2bb0: 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  1 {.  execsql {.
2bc0: 20 20 20 20 44 52 4f 50 20 56 49 45 57 20 74 31      DROP VIEW t1
2bd0: 3b 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45  ;.    DROP TABLE
2be0: 20 74 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20   t1;.    CREATE 
2bf0: 54 41 42 4c 45 20 74 31 28 61 2c 20 62 2c 20 63  TABLE t1(a, b, c
2c00: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
2c10: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c 20  TO t1 VALUES(1, 
2c20: 32 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52  2, 3);.    INSER
2c30: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
2c40: 28 34 2c 20 35 2c 20 36 29 3b 0a 0a 20 20 20 20  (4, 5, 6);..    
2c50: 43 52 45 41 54 45 20 56 49 45 57 20 76 76 31 20  CREATE VIEW vv1 
2c60: 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  AS SELECT * FROM
2c70: 20 74 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20   t1;.    CREATE 
2c80: 56 49 45 57 20 76 76 32 20 41 53 20 53 45 4c 45  VIEW vv2 AS SELE
2c90: 43 54 20 2a 20 46 52 4f 4d 20 76 76 31 3b 0a 20  CT * FROM vv1;. 
2ca0: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
2cb0: 76 33 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46  v3 AS SELECT * F
2cc0: 52 4f 4d 20 76 76 32 3b 0a 20 20 20 20 43 52 45  ROM vv2;.    CRE
2cd0: 41 54 45 20 56 49 45 57 20 76 76 34 20 41 53 20  ATE VIEW vv4 AS 
2ce0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 76  SELECT * FROM vv
2cf0: 33 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49  3;.    CREATE VI
2d00: 45 57 20 76 76 35 20 41 53 20 53 45 4c 45 43 54  EW vv5 AS SELECT
2d10: 20 2a 20 46 52 4f 4d 20 76 76 34 3b 0a 0a 20 20   * FROM vv4;..  
2d20: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2d30: 76 76 35 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  vv5;.  }.} {1 2 
2d40: 33 20 34 20 35 20 36 7d 0a 0a 23 20 54 69 63 6b  3 4 5 6}..# Tick
2d50: 65 74 20 23 33 33 30 38 0a 23 20 4d 61 6b 65 20  et #3308.# Make 
2d60: 73 75 72 65 20 22 72 6f 77 69 64 22 20 63 6f 6c  sure "rowid" col
2d70: 75 6d 6e 73 20 69 6e 20 61 20 76 69 65 77 20 61  umns in a view a
2d80: 72 65 20 6e 61 6d 65 64 20 63 6f 72 72 65 63 74  re named correct
2d90: 6c 79 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69  ly..#.do_test vi
2da0: 65 77 2d 31 39 2e 31 20 7b 0a 20 20 65 78 65 63  ew-19.1 {.  exec
2db0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
2dc0: 20 56 49 45 57 20 76 33 33 30 38 61 20 41 53 20   VIEW v3308a AS 
2dd0: 53 45 4c 45 43 54 20 72 6f 77 69 64 2c 20 2a 20  SELECT rowid, * 
2de0: 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 65  FROM t1;.  }.  e
2df0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45  xecsql2 {.    SE
2e00: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 33 33 30  LECT * FROM v330
2e10: 38 61 0a 20 20 7d 0a 7d 20 7b 72 6f 77 69 64 20  8a.  }.} {rowid 
2e20: 31 20 61 20 31 20 62 20 32 20 63 20 33 20 72 6f  1 a 1 b 2 c 3 ro
2e30: 77 69 64 20 32 20 61 20 34 20 62 20 35 20 63 20  wid 2 a 4 b 5 c 
2e40: 36 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  6}.do_test view-
2e50: 31 39 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c  19.2 {.  execsql
2e60: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
2e70: 45 57 20 76 33 33 30 38 62 20 41 53 20 53 45 4c  EW v3308b AS SEL
2e80: 45 43 54 20 74 31 2e 72 6f 77 69 64 2c 20 74 31  ECT t1.rowid, t1
2e90: 2e 61 2c 20 74 31 2e 62 2b 74 31 2e 63 20 46 52  .a, t1.b+t1.c FR
2ea0: 4f 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 65 78 65  OM t1;.  }.  exe
2eb0: 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45  csql2 {.    SELE
2ec0: 43 54 20 2a 20 46 52 4f 4d 20 76 33 33 30 38 62  CT * FROM v3308b
2ed0: 0a 20 20 7d 0a 7d 20 7b 72 6f 77 69 64 20 31 20  .  }.} {rowid 1 
2ee0: 61 20 31 20 74 31 2e 62 2b 74 31 2e 63 20 35 20  a 1 t1.b+t1.c 5 
2ef0: 72 6f 77 69 64 20 32 20 61 20 34 20 74 31 2e 62  rowid 2 a 4 t1.b
2f00: 2b 74 31 2e 63 20 31 31 7d 0a 64 6f 5f 74 65 73  +t1.c 11}.do_tes
2f10: 74 20 76 69 65 77 2d 31 39 2e 33 20 7b 0a 20 20  t view-19.3 {.  
2f20: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
2f30: 45 41 54 45 20 56 49 45 57 20 76 33 33 30 38 63  EATE VIEW v3308c
2f40: 20 41 53 20 53 45 4c 45 43 54 20 74 31 2e 6f 69   AS SELECT t1.oi
2f50: 64 2c 20 41 2c 20 74 31 2e 62 2b 74 31 2e 63 20  d, A, t1.b+t1.c 
2f60: 41 53 20 78 20 46 52 4f 4d 20 74 31 3b 0a 20 20  AS x FROM t1;.  
2f70: 7d 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20  }.  execsql2 {. 
2f80: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
2f90: 20 76 33 33 30 38 63 0a 20 20 7d 0a 7d 20 7b 72   v3308c.  }.} {r
2fa0: 6f 77 69 64 20 31 20 61 20 31 20 78 20 35 20 72  owid 1 a 1 x 5 r
2fb0: 6f 77 69 64 20 32 20 61 20 34 20 78 20 31 31 7d  owid 2 a 4 x 11}
2fc0: 0a 0a 23 20 54 69 63 6b 65 74 20 23 33 35 33 39  ..# Ticket #3539
2fd0: 20 68 61 64 20 74 68 69 73 20 63 72 61 73 68 69   had this crashi
2fe0: 6e 67 20 28 73 65 65 20 63 6f 6d 6d 69 74 20 5b  ng (see commit [
2ff0: 35 39 34 30 5d 29 2e 0a 64 6f 5f 74 65 73 74 20  5940])..do_test 
3000: 76 69 65 77 2d 32 30 2e 31 20 7b 0a 20 20 65 78  view-20.1 {.  ex
3010: 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50  ecsql {.    DROP
3020: 20 54 41 42 4c 45 20 49 46 20 45 58 49 53 54 53   TABLE IF EXISTS
3030: 20 74 31 3b 0a 20 20 20 20 44 52 4f 50 20 56 49   t1;.    DROP VI
3040: 45 57 20 49 46 20 45 58 49 53 54 53 20 76 31 3b  EW IF EXISTS v1;
3050: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
3060: 45 20 74 31 28 63 31 29 3b 0a 20 20 20 20 43 52  E t1(c1);.    CR
3070: 45 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20  EATE VIEW v1 AS 
3080: 53 45 4c 45 43 54 20 63 31 20 46 52 4f 4d 20 28  SELECT c1 FROM (
3090: 53 45 4c 45 43 54 20 74 31 2e 63 31 20 46 52 4f  SELECT t1.c1 FRO
30a0: 4d 20 74 31 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a  M t1);.  }.} {}.
30b0: 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a           .finish_test.