/ Hex Artifact Content
Login

Artifact 765802c7a66d37fabd5ac8e2f2dbe572b43eb9ab:


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 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
0870: 76 69 65 77 2d 31 2e 31 30 20 7b 0a 20 20 43 52  view-1.10 {.  CR
0880: 45 41 54 45 20 54 41 42 4c 45 20 74 39 28 78 20  EATE TABLE t9(x 
0890: 49 4e 54 45 47 45 52 29 3b 0a 20 20 43 52 45 41  INTEGER);.  CREA
08a0: 54 45 20 56 49 45 57 20 76 39 61 20 41 53 20 53  TE VIEW v9a AS S
08b0: 45 4c 45 43 54 20 78 20 46 52 4f 4d 20 74 39 3b  ELECT x FROM t9;
08c0: 0a 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76  .  CREATE VIEW v
08d0: 39 62 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46  9b AS SELECT * F
08e0: 52 4f 4d 20 74 39 3b 0a 20 20 43 52 45 41 54 45  ROM t9;.  CREATE
08f0: 20 56 49 45 57 20 76 39 63 28 78 29 20 41 53 20   VIEW v9c(x) AS 
0900: 53 45 4c 45 43 54 20 78 20 46 52 4f 4d 20 74 39  SELECT x FROM t9
0910: 3b 0a 20 20 43 52 45 41 54 45 20 56 49 45 57 20  ;.  CREATE VIEW 
0920: 76 39 64 28 78 29 20 41 53 20 53 45 4c 45 43 54  v9d(x) AS SELECT
0930: 20 2a 20 46 52 4f 4d 20 74 39 3b 0a 7d 20 7b 7d   * FROM t9;.} {}
0940: 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74  .do_execsql_test
0950: 20 76 69 65 77 2d 31 2e 31 31 20 7b 0a 20 20 50   view-1.11 {.  P
0960: 52 41 47 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f  RAGMA table_info
0970: 28 76 39 61 29 3b 0a 7d 20 7b 30 20 78 20 49 4e  (v9a);.} {0 x IN
0980: 54 45 47 45 52 20 30 20 7b 7d 20 30 7d 0a 64 6f  TEGER 0 {} 0}.do
0990: 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 76 69  _execsql_test vi
09a0: 65 77 2d 31 2e 31 32 20 7b 0a 20 20 50 52 41 47  ew-1.12 {.  PRAG
09b0: 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f 28 76 39  MA table_info(v9
09c0: 62 29 3b 0a 7d 20 7b 30 20 78 20 49 4e 54 45 47  b);.} {0 x INTEG
09d0: 45 52 20 30 20 7b 7d 20 30 7d 0a 64 6f 5f 65 78  ER 0 {} 0}.do_ex
09e0: 65 63 73 71 6c 5f 74 65 73 74 20 76 69 65 77 2d  ecsql_test view-
09f0: 31 2e 31 33 20 7b 0a 20 20 50 52 41 47 4d 41 20  1.13 {.  PRAGMA 
0a00: 74 61 62 6c 65 5f 69 6e 66 6f 28 76 39 63 29 3b  table_info(v9c);
0a10: 0a 7d 20 7b 30 20 78 20 49 4e 54 45 47 45 52 20  .} {0 x INTEGER 
0a20: 30 20 7b 7d 20 30 7d 0a 64 6f 5f 65 78 65 63 73  0 {} 0}.do_execs
0a30: 71 6c 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 31  ql_test view-1.1
0a40: 34 20 7b 0a 20 20 50 52 41 47 4d 41 20 74 61 62  4 {.  PRAGMA tab
0a50: 6c 65 5f 69 6e 66 6f 28 76 39 64 29 3b 0a 7d 20  le_info(v9d);.} 
0a60: 7b 30 20 78 20 49 4e 54 45 47 45 52 20 30 20 7b  {0 x INTEGER 0 {
0a70: 7d 20 30 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69  } 0}..do_test vi
0a80: 65 77 2d 32 2e 31 20 7b 0a 20 20 65 78 65 63 73  ew-2.1 {.  execs
0a90: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
0aa0: 56 49 45 57 20 76 32 20 41 53 20 53 45 4c 45 43  VIEW v2 AS SELEC
0ab0: 54 20 2a 20 46 52 4f 4d 20 74 31 20 57 48 45 52  T * FROM t1 WHER
0ac0: 45 20 61 3e 35 0a 20 20 7d 3b 20 20 23 20 4e 6f  E a>5.  };  # No
0ad0: 20 73 65 6d 69 63 6f 6c 6f 6e 0a 20 20 65 78 65   semicolon.  exe
0ae0: 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45  csql2 {.    SELE
0af0: 43 54 20 2a 20 46 52 4f 4d 20 76 32 3b 0a 20 20  CT * FROM v2;.  
0b00: 7d 0a 7d 20 7b 78 20 37 20 61 20 38 20 62 20 39  }.} {x 7 a 8 b 9
0b10: 20 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74 20 76   c 10}.do_test v
0b20: 69 65 77 2d 32 2e 32 20 7b 0a 20 20 63 61 74 63  iew-2.2 {.  catc
0b30: 68 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52  hsql {.    INSER
0b40: 54 20 49 4e 54 4f 20 76 32 20 56 41 4c 55 45 53  T INTO v2 VALUES
0b50: 28 31 2c 32 2c 33 2c 34 29 3b 0a 20 20 7d 0a 7d  (1,2,3,4);.  }.}
0b60: 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 6d 6f 64 69   {1 {cannot modi
0b70: 66 79 20 76 32 20 62 65 63 61 75 73 65 20 69 74  fy v2 because it
0b80: 20 69 73 20 61 20 76 69 65 77 7d 7d 0a 64 6f 5f   is a view}}.do_
0b90: 74 65 73 74 20 76 69 65 77 2d 32 2e 33 20 7b 0a  test view-2.3 {.
0ba0: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
0bb0: 20 55 50 44 41 54 45 20 76 32 20 53 45 54 20 61   UPDATE v2 SET a
0bc0: 3d 31 30 20 57 48 45 52 45 20 61 3d 35 3b 0a 20  =10 WHERE a=5;. 
0bd0: 20 7d 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20   }.} {1 {cannot 
0be0: 6d 6f 64 69 66 79 20 76 32 20 62 65 63 61 75 73  modify v2 becaus
0bf0: 65 20 69 74 20 69 73 20 61 20 76 69 65 77 7d 7d  e it is a view}}
0c00: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e  .do_test view-2.
0c10: 34 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b  4 {.  catchsql {
0c20: 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d  .    DELETE FROM
0c30: 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 63   v2;.  }.} {1 {c
0c40: 61 6e 6e 6f 74 20 6d 6f 64 69 66 79 20 76 32 20  annot modify v2 
0c50: 62 65 63 61 75 73 65 20 69 74 20 69 73 20 61 20  because it is a 
0c60: 76 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76  view}}.do_test v
0c70: 69 65 77 2d 32 2e 35 20 7b 0a 20 20 65 78 65 63  iew-2.5 {.  exec
0c80: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
0c90: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
0ca0: 31 31 2c 31 32 2c 31 33 2c 31 34 29 3b 0a 20 20  11,12,13,14);.  
0cb0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0cc0: 76 32 20 4f 52 44 45 52 20 42 59 20 78 3b 0a 20  v2 ORDER BY x;. 
0cd0: 20 7d 0a 7d 20 7b 37 20 38 20 39 20 31 30 20 31   }.} {7 8 9 10 1
0ce0: 31 20 31 32 20 31 33 20 31 34 7d 0a 64 6f 5f 74  1 12 13 14}.do_t
0cf0: 65 73 74 20 76 69 65 77 2d 32 2e 36 20 7b 0a 20  est view-2.6 {. 
0d00: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
0d10: 45 4c 45 43 54 20 78 20 46 52 4f 4d 20 76 32 20  ELECT x FROM v2 
0d20: 57 48 45 52 45 20 61 3e 31 30 0a 20 20 7d 0a 7d  WHERE a>10.  }.}
0d30: 20 7b 31 31 7d 0a 0a 23 20 54 65 73 74 20 74 68   {11}..# Test th
0d40: 61 74 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 20 6f  at column name o
0d50: 66 20 76 69 65 77 73 20 61 72 65 20 67 65 6e 65  f views are gene
0d60: 72 61 74 65 64 20 63 6f 72 72 65 63 74 6c 79 2e  rated correctly.
0d70: 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  .#.do_test view-
0d80: 33 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 32  3.1 {.  execsql2
0d90: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
0da0: 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54 20 31 0a  FROM v1 LIMIT 1.
0db0: 20 20 7d 0a 7d 20 7b 61 20 32 20 62 20 33 7d 0a    }.} {a 2 b 3}.
0dc0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33 2e 32  do_test view-3.2
0dd0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a   {.  execsql2 {.
0de0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0df0: 4d 20 76 32 20 4c 49 4d 49 54 20 31 0a 20 20 7d  M v2 LIMIT 1.  }
0e00: 0a 7d 20 7b 78 20 37 20 61 20 38 20 62 20 39 20  .} {x 7 a 8 b 9 
0e10: 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74 20 76 69  c 10}.do_test vi
0e20: 65 77 2d 33 2e 33 2e 31 20 7b 0a 20 20 65 78 65  ew-3.3.1 {.  exe
0e30: 63 73 71 6c 32 20 7b 0a 20 20 20 20 44 52 4f 50  csql2 {.    DROP
0e40: 20 56 49 45 57 20 76 31 3b 0a 20 20 20 20 43 52   VIEW v1;.    CR
0e50: 45 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20  EATE VIEW v1 AS 
0e60: 53 45 4c 45 43 54 20 61 20 41 53 20 27 78 79 7a  SELECT a AS 'xyz
0e70: 27 2c 20 62 2b 63 20 41 53 20 27 70 71 72 27 2c  ', b+c AS 'pqr',
0e80: 20 63 2d 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20   c-b FROM t1;.  
0e90: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0ea0: 76 31 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a 7d  v1 LIMIT 1.  }.}
0eb0: 20 7b 78 79 7a 20 32 20 70 71 72 20 37 20 63 2d   {xyz 2 pqr 7 c-
0ec0: 62 20 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  b 1}.do_test vie
0ed0: 77 2d 33 2e 33 2e 32 20 7b 0a 20 20 65 78 65 63  w-3.3.2 {.  exec
0ee0: 73 71 6c 32 20 7b 0a 20 20 20 20 43 52 45 41 54  sql2 {.    CREAT
0ef0: 45 20 56 49 45 57 20 76 31 62 20 41 53 20 53 45  E VIEW v1b AS SE
0f00: 4c 45 43 54 20 74 31 2e 61 2c 20 62 2b 63 2c 20  LECT t1.a, b+c, 
0f10: 74 31 2e 63 20 46 52 4f 4d 20 74 31 3b 0a 20 20  t1.c FROM t1;.  
0f20: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0f30: 76 31 62 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a  v1b LIMIT 1.  }.
0f40: 7d 20 7b 61 20 32 20 62 2b 63 20 37 20 63 20 34  } {a 2 b+c 7 c 4
0f50: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33  }.do_test view-3
0f60: 2e 33 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c  .3.3 {.  execsql
0f70: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
0f80: 49 45 57 20 76 31 63 28 78 2c 79 2c 7a 29 20 41  IEW v1c(x,y,z) A
0f90: 53 20 53 45 4c 45 43 54 20 61 2c 20 62 2b 63 2c  S SELECT a, b+c,
0fa0: 20 63 2d 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20   c-b FROM t1;.  
0fb0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0fc0: 76 31 63 20 4c 49 4d 49 54 20 31 3b 0a 20 20 7d  v1c LIMIT 1;.  }
0fd0: 0a 7d 20 7b 78 20 32 20 79 20 37 20 7a 20 31 7d  .} {x 2 y 7 z 1}
0fe0: 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74 65 73  .do_catchsql_tes
0ff0: 74 20 76 69 65 77 2d 33 2e 33 2e 34 20 7b 0a 20  t view-3.3.4 {. 
1000: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 65   CREATE VIEW v1e
1010: 72 72 28 78 2c 79 20 44 45 53 43 2c 7a 29 20 41  rr(x,y DESC,z) A
1020: 53 20 53 45 4c 45 43 54 20 61 2c 20 62 2b 63 2c  S SELECT a, b+c,
1030: 20 63 2d 62 20 46 52 4f 4d 20 74 31 3b 0a 7d 20   c-b FROM t1;.} 
1040: 7b 31 20 7b 73 79 6e 74 61 78 20 65 72 72 6f 72  {1 {syntax error
1050: 20 61 66 74 65 72 20 63 6f 6c 75 6d 6e 20 6e 61   after column na
1060: 6d 65 20 22 79 22 7d 7d 0a 64 6f 5f 63 61 74 63  me "y"}}.do_catc
1070: 68 73 71 6c 5f 74 65 73 74 20 76 69 65 77 2d 33  hsql_test view-3
1080: 2e 33 2e 35 20 7b 0a 20 20 44 52 4f 50 20 56 49  .3.5 {.  DROP VI
1090: 45 57 20 49 46 20 45 58 49 53 54 53 20 76 31 65  EW IF EXISTS v1e
10a0: 72 72 3b 0a 20 20 43 52 45 41 54 45 20 56 49 45  rr;.  CREATE VIE
10b0: 57 20 76 31 65 72 72 28 78 2c 79 29 20 41 53 20  W v1err(x,y) AS 
10c0: 53 45 4c 45 43 54 20 61 2c 20 62 2b 63 2c 20 63  SELECT a, b+c, c
10d0: 2d 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20 53 45  -b FROM t1;.  SE
10e0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 65 72  LECT * FROM v1er
10f0: 72 3b 0a 7d 20 7b 31 20 7b 65 78 70 65 63 74 65  r;.} {1 {expecte
1100: 64 20 32 20 63 6f 6c 75 6d 6e 73 20 66 6f 72 20  d 2 columns for 
1110: 27 76 31 65 72 72 27 20 62 75 74 20 67 6f 74 20  'v1err' but got 
1120: 33 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f  3}}.do_catchsql_
1130: 74 65 73 74 20 76 69 65 77 2d 33 2e 33 2e 36 20  test view-3.3.6 
1140: 7b 0a 20 20 44 52 4f 50 20 56 49 45 57 20 49 46  {.  DROP VIEW IF
1150: 20 45 58 49 53 54 53 20 76 31 65 72 72 3b 0a 20   EXISTS v1err;. 
1160: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 65   CREATE VIEW v1e
1170: 72 72 28 77 2c 78 2c 79 2c 7a 29 20 41 53 20 53  rr(w,x,y,z) AS S
1180: 45 4c 45 43 54 20 61 2c 20 62 2b 63 2c 20 63 2d  ELECT a, b+c, c-
1190: 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20 53 45 4c  b FROM t1;.  SEL
11a0: 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 65 72 72  ECT * FROM v1err
11b0: 3b 0a 7d 20 7b 31 20 7b 65 78 70 65 63 74 65 64  ;.} {1 {expected
11c0: 20 34 20 63 6f 6c 75 6d 6e 73 20 66 6f 72 20 27   4 columns for '
11d0: 76 31 65 72 72 27 20 62 75 74 20 67 6f 74 20 33  v1err' but got 3
11e0: 7d 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 63 6f  }}..ifcapable co
11f0: 6d 70 6f 75 6e 64 20 7b 0a 64 6f 5f 74 65 73 74  mpound {.do_test
1200: 20 20 76 69 65 77 2d 33 2e 34 20 7b 0a 20 20 65    view-3.4 {.  e
1210: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 43 52  xecsql2 {.    CR
1220: 45 41 54 45 20 56 49 45 57 20 76 33 20 41 53 20  EATE VIEW v3 AS 
1230: 53 45 4c 45 43 54 20 61 20 46 52 4f 4d 20 74 31  SELECT a FROM t1
1240: 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 62 20   UNION SELECT b 
1250: 46 52 4f 4d 20 74 31 20 4f 52 44 45 52 20 42 59  FROM t1 ORDER BY
1260: 20 62 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a   b;.    SELECT *
1270: 20 46 52 4f 4d 20 76 33 20 4c 49 4d 49 54 20 34   FROM v3 LIMIT 4
1280: 3b 0a 20 20 7d 0a 7d 20 7b 61 20 32 20 61 20 33  ;.  }.} {a 2 a 3
1290: 20 61 20 35 20 61 20 36 7d 0a 64 6f 5f 74 65 73   a 5 a 6}.do_tes
12a0: 74 20 76 69 65 77 2d 33 2e 35 20 7b 0a 20 20 65  t view-3.5 {.  e
12b0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 43 52  xecsql2 {.    CR
12c0: 45 41 54 45 20 56 49 45 57 20 76 34 20 41 53 20  EATE VIEW v4 AS 
12d0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 61 2c  .      SELECT a,
12e0: 20 62 20 46 52 4f 4d 20 74 31 20 0a 20 20 20 20   b FROM t1 .    
12f0: 20 20 55 4e 49 4f 4e 0a 20 20 20 20 20 20 53 45    UNION.      SE
1300: 4c 45 43 54 20 62 20 41 53 20 27 78 27 2c 20 61  LECT b AS 'x', a
1310: 20 41 53 20 27 79 27 20 46 52 4f 4d 20 74 31 0a   AS 'y' FROM t1.
1320: 20 20 20 20 20 20 4f 52 44 45 52 20 42 59 20 78        ORDER BY x
1330: 2c 20 79 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  , y;.    SELECT 
1340: 62 20 46 52 4f 4d 20 76 34 20 4f 52 44 45 52 20  b FROM v4 ORDER 
1350: 42 59 20 62 20 4c 49 4d 49 54 20 34 3b 0a 20 20  BY b LIMIT 4;.  
1360: 7d 0a 7d 20 7b 62 20 32 20 62 20 33 20 62 20 35  }.} {b 2 b 3 b 5
1370: 20 62 20 36 7d 0a 7d 20 3b 23 20 69 66 63 61 70   b 6}.} ;# ifcap
1380: 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64 0a 0a 0a  able compound...
1390: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 31  do_test view-4.1
13a0: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a   {.  catchsql {.
13b0: 20 20 20 20 44 52 4f 50 20 56 49 45 57 20 74 31      DROP VIEW t1
13c0: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73 65 20  ;.  }.} {1 {use 
13d0: 44 52 4f 50 20 54 41 42 4c 45 20 74 6f 20 64 65  DROP TABLE to de
13e0: 6c 65 74 65 20 74 61 62 6c 65 20 74 31 7d 7d 0a  lete table t1}}.
13f0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 32  do_test view-4.2
1400: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
1410: 20 20 20 53 45 4c 45 43 54 20 31 20 46 52 4f 4d     SELECT 1 FROM
1420: 20 74 31 20 4c 49 4d 49 54 20 31 3b 0a 20 20 7d   t1 LIMIT 1;.  }
1430: 0a 7d 20 31 0a 64 6f 5f 74 65 73 74 20 76 69 65  .} 1.do_test vie
1440: 77 2d 34 2e 33 20 7b 0a 20 20 63 61 74 63 68 73  w-4.3 {.  catchs
1450: 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41  ql {.    DROP TA
1460: 42 4c 45 20 76 31 3b 0a 20 20 7d 0a 7d 20 7b 31  BLE v1;.  }.} {1
1470: 20 7b 75 73 65 20 44 52 4f 50 20 56 49 45 57 20   {use DROP VIEW 
1480: 74 6f 20 64 65 6c 65 74 65 20 76 69 65 77 20 76  to delete view v
1490: 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  1}}.do_test view
14a0: 2d 34 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  -4.4 {.  execsql
14b0: 20 7b 0a 20 20 20 20 20 53 45 4c 45 43 54 20 31   {.     SELECT 1
14c0: 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54 20 31   FROM v1 LIMIT 1
14d0: 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74  ;.  }.} {1}.do_t
14e0: 65 73 74 20 76 69 65 77 2d 34 2e 35 20 7b 0a 20  est view-4.5 {. 
14f0: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
1500: 43 52 45 41 54 45 20 49 4e 44 45 58 20 69 31 76  CREATE INDEX i1v
1510: 31 20 4f 4e 20 76 31 28 78 79 7a 29 3b 0a 20 20  1 ON v1(xyz);.  
1520: 7d 0a 7d 20 7b 31 20 7b 76 69 65 77 73 20 6d 61  }.} {1 {views ma
1530: 79 20 6e 6f 74 20 62 65 20 69 6e 64 65 78 65 64  y not be indexed
1540: 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  }}..do_test view
1550: 2d 35 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -5.1 {.  execsql
1560: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
1570: 42 4c 45 20 74 32 28 79 2c 61 29 3b 0a 20 20 20  BLE t2(y,a);.   
1580: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20   INSERT INTO t2 
1590: 56 41 4c 55 45 53 28 32 32 2c 32 29 3b 0a 20 20  VALUES(22,2);.  
15a0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
15b0: 20 56 41 4c 55 45 53 28 33 33 2c 33 29 3b 0a 20   VALUES(33,3);. 
15c0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
15d0: 32 20 56 41 4c 55 45 53 28 34 34 2c 34 29 3b 0a  2 VALUES(44,4);.
15e0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
15f0: 74 32 20 56 41 4c 55 45 53 28 35 35 2c 35 29 3b  t2 VALUES(55,5);
1600: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
1610: 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 32 32  OM t2;.  }.} {22
1620: 20 32 20 33 33 20 33 20 34 34 20 34 20 35 35 20   2 33 3 44 4 55 
1630: 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  5}.do_test view-
1640: 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  5.2 {.  execsql 
1650: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
1660: 57 20 76 35 20 41 53 0a 20 20 20 20 20 20 53 45  W v5 AS.      SE
1670: 4c 45 43 54 20 74 31 2e 78 20 41 53 20 76 2c 20  LECT t1.x AS v, 
1680: 74 32 2e 79 20 41 53 20 77 20 46 52 4f 4d 20 74  t2.y AS w FROM t
1690: 31 20 4a 4f 49 4e 20 74 32 20 55 53 49 4e 47 28  1 JOIN t2 USING(
16a0: 61 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  a);.    SELECT *
16b0: 20 46 52 4f 4d 20 76 35 3b 0a 20 20 7d 0a 7d 20   FROM v5;.  }.} 
16c0: 7b 31 20 32 32 20 34 20 35 35 7d 0a 0a 23 20 56  {1 22 4 55}..# V
16d0: 65 72 69 66 79 20 74 68 61 74 20 74 68 65 20 76  erify that the v
16e0: 69 65 77 20 76 35 20 67 65 74 73 20 66 6c 61 74  iew v5 gets flat
16f0: 74 65 6e 65 64 2e 20 20 73 65 65 20 73 71 6c 69  tened.  see sqli
1700: 74 65 46 6c 61 74 74 65 6e 53 75 62 71 75 65 72  teFlattenSubquer
1710: 79 28 29 2e 0a 23 20 54 68 69 73 20 77 69 6c 6c  y()..# This will
1720: 20 6f 6e 6c 79 20 77 6f 72 6b 20 69 66 20 45 58   only work if EX
1730: 50 4c 41 49 4e 20 69 73 20 65 6e 61 62 6c 65 64  PLAIN is enabled
1740: 2e 0a 23 20 54 69 63 6b 65 74 20 23 32 37 32 0a  ..# Ticket #272.
1750: 23 0a 69 66 63 61 70 61 62 6c 65 20 7b 65 78 70  #.ifcapable {exp
1760: 6c 61 69 6e 7d 20 7b 0a 64 6f 5f 74 65 73 74 20  lain} {.do_test 
1770: 76 69 65 77 2d 35 2e 33 20 7b 0a 20 20 6c 73 65  view-5.3 {.  lse
1780: 61 72 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a  arch [execsql {.
1790: 20 20 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45      EXPLAIN SELE
17a0: 43 54 20 2a 20 46 52 4f 4d 20 76 35 3b 0a 20 20  CT * FROM v5;.  
17b0: 7d 5d 20 4f 70 65 6e 45 70 68 65 6d 65 72 61 6c  }] OpenEphemeral
17c0: 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65 73 74 20  .} {-1}.do_test 
17d0: 76 69 65 77 2d 35 2e 34 20 7b 0a 20 20 65 78 65  view-5.4 {.  exe
17e0: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
17f0: 54 20 2a 20 46 52 4f 4d 20 76 35 20 41 53 20 61  T * FROM v5 AS a
1800: 2c 20 74 32 20 41 53 20 62 20 57 48 45 52 45 20  , t2 AS b WHERE 
1810: 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 0a 7d 20 7b  a.w=b.y;.  }.} {
1820: 31 20 32 32 20 32 32 20 32 20 34 20 35 35 20 35  1 22 22 2 4 55 5
1830: 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  5 5}.do_test vie
1840: 77 2d 35 2e 35 20 7b 0a 20 20 6c 73 65 61 72 63  w-5.5 {.  lsearc
1850: 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  h [execsql {.   
1860: 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43 54 20   EXPLAIN SELECT 
1870: 2a 20 46 52 4f 4d 20 76 35 20 41 53 20 61 2c 20  * FROM v5 AS a, 
1880: 74 32 20 41 53 20 62 20 57 48 45 52 45 20 61 2e  t2 AS b WHERE a.
1890: 77 3d 62 2e 79 3b 0a 20 20 7d 5d 20 4f 70 65 6e  w=b.y;.  }] Open
18a0: 45 70 68 65 6d 65 72 61 6c 0a 7d 20 7b 2d 31 7d  Ephemeral.} {-1}
18b0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e  .do_test view-5.
18c0: 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  6 {.  execsql {.
18d0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
18e0: 4d 20 74 32 20 41 53 20 62 2c 20 76 35 20 41 53  M t2 AS b, v5 AS
18f0: 20 61 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79   a WHERE a.w=b.y
1900: 3b 0a 20 20 7d 0a 7d 20 7b 32 32 20 32 20 31 20  ;.  }.} {22 2 1 
1910: 32 32 20 35 35 20 35 20 34 20 35 35 7d 0a 64 6f  22 55 5 4 55}.do
1920: 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 37 20 7b  _test view-5.7 {
1930: 0a 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65 63  .  lsearch [exec
1940: 73 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41 49  sql {.    EXPLAI
1950: 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  N SELECT * FROM 
1960: 74 32 20 41 53 20 62 2c 20 76 35 20 41 53 20 61  t2 AS b, v5 AS a
1970: 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b 0a   WHERE a.w=b.y;.
1980: 20 20 7d 5d 20 4f 70 65 6e 45 70 68 65 6d 65 72    }] OpenEphemer
1990: 61 6c 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65 73  al.} {-1}.do_tes
19a0: 74 20 76 69 65 77 2d 35 2e 38 20 7b 0a 20 20 65  t view-5.8 {.  e
19b0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
19c0: 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 41 53  ECT * FROM t1 AS
19d0: 20 61 2c 20 76 35 20 41 53 20 62 2c 20 74 32 20   a, v5 AS b, t2 
19e0: 41 53 20 63 20 57 48 45 52 45 20 61 2e 78 3d 62  AS c WHERE a.x=b
19f0: 2e 76 20 41 4e 44 20 62 2e 77 3d 63 2e 79 3b 0a  .v AND b.w=c.y;.
1a00: 20 20 7d 0a 7d 20 7b 31 20 32 20 33 20 34 20 31    }.} {1 2 3 4 1
1a10: 20 32 32 20 32 32 20 32 20 34 20 35 20 36 20 37   22 22 2 4 5 6 7
1a20: 20 34 20 35 35 20 35 35 20 35 7d 0a 64 6f 5f 74   4 55 55 5}.do_t
1a30: 65 73 74 20 76 69 65 77 2d 35 2e 39 20 7b 0a 20  est view-5.9 {. 
1a40: 20 6c 73 65 61 72 63 68 20 5b 65 78 65 63 73 71   lsearch [execsq
1a50: 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41 49 4e 20  l {.    EXPLAIN 
1a60: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31  SELECT * FROM t1
1a70: 20 41 53 20 61 2c 20 76 35 20 41 53 20 62 2c 20   AS a, v5 AS b, 
1a80: 74 32 20 41 53 20 63 20 57 48 45 52 45 20 61 2e  t2 AS c WHERE a.
1a90: 78 3d 62 2e 76 20 41 4e 44 20 62 2e 77 3d 63 2e  x=b.v AND b.w=c.
1aa0: 79 3b 0a 20 20 7d 5d 20 4f 70 65 6e 45 70 68 65  y;.  }] OpenEphe
1ab0: 6d 65 72 61 6c 0a 7d 20 7b 2d 31 7d 0a 7d 20 3b  meral.} {-1}.} ;
1ac0: 23 20 65 6e 64 69 66 20 65 78 70 6c 61 69 6e 0a  # endif explain.
1ad0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 36 2e  .do_test view-6.
1ae0: 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  1 {.  execsql {.
1af0: 20 20 20 20 53 45 4c 45 43 54 20 6d 69 6e 28 78      SELECT min(x
1b00: 29 2c 20 6d 69 6e 28 61 29 2c 20 6d 69 6e 28 62  ), min(a), min(b
1b10: 29 2c 20 6d 69 6e 28 63 29 2c 20 6d 69 6e 28 61  ), min(c), min(a
1b20: 2b 62 2b 63 29 20 46 52 4f 4d 20 76 32 3b 0a 20  +b+c) FROM v2;. 
1b30: 20 7d 0a 7d 20 7b 37 20 38 20 39 20 31 30 20 32   }.} {7 8 9 10 2
1b40: 37 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  7}.do_test view-
1b50: 36 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  6.2 {.  execsql 
1b60: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 6d 61 78  {.    SELECT max
1b70: 28 78 29 2c 20 6d 61 78 28 61 29 2c 20 6d 61 78  (x), max(a), max
1b80: 28 62 29 2c 20 6d 61 78 28 63 29 2c 20 6d 61 78  (b), max(c), max
1b90: 28 61 2b 62 2b 63 29 20 46 52 4f 4d 20 76 32 3b  (a+b+c) FROM v2;
1ba0: 0a 20 20 7d 0a 7d 20 7b 31 31 20 31 32 20 31 33  .  }.} {11 12 13
1bb0: 20 31 34 20 33 39 7d 0a 0a 64 6f 5f 74 65 73 74   14 39}..do_test
1bc0: 20 76 69 65 77 2d 37 2e 31 20 7b 0a 20 20 65 78   view-7.1 {.  ex
1bd0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  ecsql {.    CREA
1be0: 54 45 20 54 41 42 4c 45 20 74 65 73 74 31 28 69  TE TABLE test1(i
1bf0: 64 20 69 6e 74 65 67 65 72 20 70 72 69 6d 61 72  d integer primar
1c00: 79 20 6b 65 79 2c 20 61 29 3b 0a 20 20 20 20 43  y key, a);.    C
1c10: 52 45 41 54 45 20 54 41 42 4c 45 20 74 65 73 74  REATE TABLE test
1c20: 32 28 69 64 20 69 6e 74 65 67 65 72 2c 20 62 29  2(id integer, b)
1c30: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
1c40: 4f 20 74 65 73 74 31 20 56 41 4c 55 45 53 28 31  O test1 VALUES(1
1c50: 2c 32 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  ,2);.    INSERT 
1c60: 49 4e 54 4f 20 74 65 73 74 32 20 56 41 4c 55 45  INTO test2 VALUE
1c70: 53 28 31 2c 33 29 3b 0a 20 20 20 20 43 52 45 41  S(1,3);.    CREA
1c80: 54 45 20 56 49 45 57 20 74 65 73 74 20 41 53 0a  TE VIEW test AS.
1c90: 20 20 20 20 20 20 53 45 4c 45 43 54 20 74 65 73        SELECT tes
1ca0: 74 31 2e 69 64 2c 20 61 2c 20 62 0a 20 20 20 20  t1.id, a, b.    
1cb0: 20 20 46 52 4f 4d 20 74 65 73 74 31 20 4a 4f 49    FROM test1 JOI
1cc0: 4e 20 74 65 73 74 32 20 4f 4e 20 74 65 73 74 32  N test2 ON test2
1cd0: 2e 69 64 3d 74 65 73 74 31 2e 69 64 3b 0a 20 20  .id=test1.id;.  
1ce0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1cf0: 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  test;.  }.} {1 2
1d00: 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   3}.do_test view
1d10: 2d 37 2e 32 20 7b 0a 20 20 64 62 20 63 6c 6f 73  -7.2 {.  db clos
1d20: 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20 74  e.  sqlite3 db t
1d30: 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c  est.db.  execsql
1d40: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
1d50: 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d  FROM test;.  }.}
1d60: 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74   {1 2 3}.do_test
1d70: 20 76 69 65 77 2d 37 2e 33 20 7b 0a 20 20 65 78   view-7.3 {.  ex
1d80: 65 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50  ecsql {.    DROP
1d90: 20 56 49 45 57 20 74 65 73 74 3b 0a 20 20 20 20   VIEW test;.    
1da0: 43 52 45 41 54 45 20 56 49 45 57 20 74 65 73 74  CREATE VIEW test
1db0: 20 41 53 0a 20 20 20 20 20 20 53 45 4c 45 43 54   AS.      SELECT
1dc0: 20 74 65 73 74 31 2e 69 64 2c 20 61 2c 20 62 0a   test1.id, a, b.
1dd0: 20 20 20 20 20 20 46 52 4f 4d 20 74 65 73 74 31        FROM test1
1de0: 20 4a 4f 49 4e 20 74 65 73 74 32 20 55 53 49 4e   JOIN test2 USIN
1df0: 47 28 69 64 29 3b 0a 20 20 20 20 53 45 4c 45 43  G(id);.    SELEC
1e00: 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20  T * FROM test;. 
1e10: 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f   }.} {1 2 3}.do_
1e20: 74 65 73 74 20 76 69 65 77 2d 37 2e 34 20 7b 0a  test view-7.4 {.
1e30: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c    db close.  sql
1e40: 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a  ite3 db test.db.
1e50: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1e60: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65  SELECT * FROM te
1e70: 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  st;.  }.} {1 2 3
1e80: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37  }.do_test view-7
1e90: 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .5 {.  execsql {
1ea0: 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20 74  .    DROP VIEW t
1eb0: 65 73 74 3b 0a 20 20 20 20 43 52 45 41 54 45 20  est;.    CREATE 
1ec0: 56 49 45 57 20 74 65 73 74 20 41 53 0a 20 20 20  VIEW test AS.   
1ed0: 20 20 20 53 45 4c 45 43 54 20 74 65 73 74 31 2e     SELECT test1.
1ee0: 69 64 2c 20 61 2c 20 62 0a 20 20 20 20 20 20 46  id, a, b.      F
1ef0: 52 4f 4d 20 74 65 73 74 31 20 4e 41 54 55 52 41  ROM test1 NATURA
1f00: 4c 20 4a 4f 49 4e 20 74 65 73 74 32 3b 0a 20 20  L JOIN test2;.  
1f10: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1f20: 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  test;.  }.} {1 2
1f30: 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   3}.do_test view
1f40: 2d 37 2e 36 20 7b 0a 20 20 64 62 20 63 6c 6f 73  -7.6 {.  db clos
1f50: 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20 74  e.  sqlite3 db t
1f60: 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c  est.db.  execsql
1f70: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
1f80: 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d  FROM test;.  }.}
1f90: 20 7b 31 20 32 20 33 7d 0a 0a 64 6f 5f 74 65 73   {1 2 3}..do_tes
1fa0: 74 20 76 69 65 77 2d 38 2e 31 20 7b 0a 20 20 65  t view-8.1 {.  e
1fb0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
1fc0: 41 54 45 20 56 49 45 57 20 76 36 20 41 53 20 53  ATE VIEW v6 AS S
1fd0: 45 4c 45 43 54 20 70 71 72 2c 20 78 79 7a 20 46  ELECT pqr, xyz F
1fe0: 52 4f 4d 20 76 31 3b 0a 20 20 20 20 53 45 4c 45  ROM v1;.    SELE
1ff0: 43 54 20 2a 20 46 52 4f 4d 20 76 36 20 4f 52 44  CT * FROM v6 ORD
2000: 45 52 20 42 59 20 78 79 7a 3b 0a 20 20 7d 0a 7d  ER BY xyz;.  }.}
2010: 20 7b 37 20 32 20 31 33 20 35 20 31 39 20 38 20   {7 2 13 5 19 8 
2020: 32 37 20 31 32 7d 0a 64 6f 5f 74 65 73 74 20 76  27 12}.do_test v
2030: 69 65 77 2d 38 2e 32 20 7b 0a 20 20 64 62 20 63  iew-8.2 {.  db c
2040: 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64  lose.  sqlite3 d
2050: 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63  b test.db.  exec
2060: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
2070: 20 2a 20 46 52 4f 4d 20 76 36 20 4f 52 44 45 52   * FROM v6 ORDER
2080: 20 42 59 20 78 79 7a 3b 0a 20 20 7d 0a 7d 20 7b   BY xyz;.  }.} {
2090: 37 20 32 20 31 33 20 35 20 31 39 20 38 20 32 37  7 2 13 5 19 8 27
20a0: 20 31 32 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65   12}.do_test vie
20b0: 77 2d 38 2e 33 20 7b 0a 20 20 65 78 65 63 73 71  w-8.3 {.  execsq
20c0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  l {.    CREATE V
20d0: 49 45 57 20 76 37 28 61 29 20 41 53 20 53 45 4c  IEW v7(a) AS SEL
20e0: 45 43 54 20 70 71 72 2b 78 79 7a 20 46 52 4f 4d  ECT pqr+xyz FROM
20f0: 20 76 36 3b 0a 20 20 20 20 53 45 4c 45 43 54 20   v6;.    SELECT 
2100: 2a 20 46 52 4f 4d 20 76 37 20 4f 52 44 45 52 20  * FROM v7 ORDER 
2110: 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 39 20 31  BY a;.  }.} {9 1
2120: 38 20 32 37 20 33 39 7d 0a 0a 69 66 63 61 70 61  8 27 39}..ifcapa
2130: 62 6c 65 20 73 75 62 71 75 65 72 79 20 7b 0a 20  ble subquery {. 
2140: 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e   do_test view-8.
2150: 34 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  4 {.    execsql 
2160: 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 56  {.      CREATE V
2170: 49 45 57 20 76 38 20 41 53 20 53 45 4c 45 43 54  IEW v8 AS SELECT
2180: 20 6d 61 78 28 63 6e 74 29 20 41 53 20 6d 78 20   max(cnt) AS mx 
2190: 46 52 4f 4d 0a 20 20 20 20 20 20 20 20 28 53 45  FROM.        (SE
21a0: 4c 45 43 54 20 61 25 32 20 41 53 20 65 6f 2c 20  LECT a%2 AS eo, 
21b0: 63 6f 75 6e 74 28 2a 29 20 41 53 20 63 6e 74 20  count(*) AS cnt 
21c0: 46 52 4f 4d 20 74 31 20 47 52 4f 55 50 20 42 59  FROM t1 GROUP BY
21d0: 20 65 6f 29 3b 0a 20 20 20 20 20 20 53 45 4c 45   eo);.      SELE
21e0: 43 54 20 2a 20 46 52 4f 4d 20 76 38 3b 0a 20 20  CT * FROM v8;.  
21f0: 20 20 7d 0a 20 20 7d 20 33 0a 20 20 64 6f 5f 74    }.  } 3.  do_t
2200: 65 73 74 20 76 69 65 77 2d 38 2e 35 20 7b 0a 20  est view-8.5 {. 
2210: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
2220: 20 20 20 53 45 4c 45 43 54 20 6d 78 2b 31 30 2c     SELECT mx+10,
2230: 20 6d 78 2a 32 20 46 52 4f 4d 20 76 38 3b 0a 20   mx*2 FROM v8;. 
2240: 20 20 20 7d 0a 20 20 7d 20 7b 31 33 20 36 7d 0a     }.  } {13 6}.
2250: 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38    do_test view-8
2260: 2e 36 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .6 {.    execsql
2270: 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20   {.      SELECT 
2280: 6d 78 2b 31 30 2c 20 70 71 72 20 46 52 4f 4d 20  mx+10, pqr FROM 
2290: 76 36 2c 20 76 38 20 57 48 45 52 45 20 78 79 7a  v6, v8 WHERE xyz
22a0: 3d 32 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31  =2;.    }.  } {1
22b0: 33 20 37 7d 0a 20 20 64 6f 5f 74 65 73 74 20 76  3 7}.  do_test v
22c0: 69 65 77 2d 38 2e 37 20 7b 0a 20 20 20 20 65 78  iew-8.7 {.    ex
22d0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45  ecsql {.      SE
22e0: 4c 45 43 54 20 6d 78 2b 31 30 2c 20 70 71 72 20  LECT mx+10, pqr 
22f0: 46 52 4f 4d 20 76 36 2c 20 76 38 20 57 48 45 52  FROM v6, v8 WHER
2300: 45 20 78 79 7a 3e 32 3b 0a 20 20 20 20 7d 0a 20  E xyz>2;.    }. 
2310: 20 7d 20 7b 31 33 20 31 33 20 31 33 20 31 39 20   } {13 13 13 19 
2320: 31 33 20 32 37 7d 0a 7d 20 3b 23 20 69 66 63 61  13 27}.} ;# ifca
2330: 70 61 62 6c 65 20 73 75 62 71 75 65 72 79 0a 0a  pable subquery..
2340: 23 20 54 65 73 74 73 20 66 6f 72 20 61 20 62 75  # Tests for a bu
2350: 67 20 66 6f 75 6e 64 20 62 79 20 4d 69 63 68 69  g found by Michi
2360: 65 6c 20 64 65 20 57 69 74 20 69 6e 76 6f 6c 76  el de Wit involv
2370: 69 6e 67 20 4f 52 44 45 52 20 42 59 20 69 6e 20  ing ORDER BY in 
2380: 61 20 56 49 45 57 2e 0a 23 0a 64 6f 5f 74 65 73  a VIEW..#.do_tes
2390: 74 20 76 69 65 77 2d 39 2e 31 20 7b 0a 20 20 65  t view-9.1 {.  e
23a0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
23b0: 45 52 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45  ERT INTO t2 SELE
23c0: 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 57 48 45  CT * FROM t2 WHE
23d0: 52 45 20 61 3c 35 3b 0a 20 20 20 20 49 4e 53 45  RE a<5;.    INSE
23e0: 52 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45 43  RT INTO t2 SELEC
23f0: 54 20 2a 20 46 52 4f 4d 20 74 32 20 57 48 45 52  T * FROM t2 WHER
2400: 45 20 61 3c 34 3b 0a 20 20 20 20 49 4e 53 45 52  E a<4;.    INSER
2410: 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45 43 54  T INTO t2 SELECT
2420: 20 2a 20 46 52 4f 4d 20 74 32 20 57 48 45 52 45   * FROM t2 WHERE
2430: 20 61 3c 33 3b 0a 20 20 20 20 53 45 4c 45 43 54   a<3;.    SELECT
2440: 20 44 49 53 54 49 4e 43 54 20 63 6f 75 6e 74 28   DISTINCT count(
2450: 2a 29 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50  *) FROM t2 GROUP
2460: 20 42 59 20 61 20 4f 52 44 45 52 20 42 59 20 31   BY a ORDER BY 1
2470: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 38  ;.  }.} {1 2 4 8
2480: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 39  }.do_test view-9
2490: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
24a0: 0a 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54  .    SELECT DIST
24b0: 49 4e 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52  INCT count(*) FR
24c0: 4f 4d 20 74 32 20 47 52 4f 55 50 20 42 59 20 61  OM t2 GROUP BY a
24d0: 20 4f 52 44 45 52 20 42 59 20 31 20 4c 49 4d 49   ORDER BY 1 LIMI
24e0: 54 20 33 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  T 3;.  }.} {1 2 
24f0: 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  4}.do_test view-
2500: 39 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  9.3 {.  execsql 
2510: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
2520: 57 20 76 39 20 41 53 20 0a 20 20 20 20 20 20 20  W v9 AS .       
2530: 53 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20  SELECT DISTINCT 
2540: 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32  count(*) FROM t2
2550: 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52 44 45   GROUP BY a ORDE
2560: 52 20 42 59 20 31 20 4c 49 4d 49 54 20 33 3b 0a  R BY 1 LIMIT 3;.
2570: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
2580: 4d 20 76 39 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  M v9;.  }.} {1 2
2590: 20 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   4}.do_test view
25a0: 2d 39 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  -9.4 {.  execsql
25b0: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
25c0: 46 52 4f 4d 20 76 39 20 4f 52 44 45 52 20 42 59  FROM v9 ORDER BY
25d0: 20 31 20 44 45 53 43 3b 0a 20 20 7d 0a 7d 20 7b   1 DESC;.  }.} {
25e0: 34 20 32 20 31 7d 0a 64 6f 5f 74 65 73 74 20 76  4 2 1}.do_test v
25f0: 69 65 77 2d 39 2e 35 20 7b 0a 20 20 65 78 65 63  iew-9.5 {.  exec
2600: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
2610: 20 56 49 45 57 20 76 31 30 20 41 53 20 0a 20 20   VIEW v10 AS .  
2620: 20 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54       SELECT DIST
2630: 49 4e 43 54 20 61 2c 20 63 6f 75 6e 74 28 2a 29  INCT a, count(*)
2640: 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50 20 42   FROM t2 GROUP B
2650: 59 20 61 20 4f 52 44 45 52 20 42 59 20 32 20 4c  Y a ORDER BY 2 L
2660: 49 4d 49 54 20 33 3b 0a 20 20 20 20 53 45 4c 45  IMIT 3;.    SELE
2670: 43 54 20 2a 20 46 52 4f 4d 20 76 31 30 3b 0a 20  CT * FROM v10;. 
2680: 20 7d 0a 7d 20 7b 35 20 31 20 34 20 32 20 33 20   }.} {5 1 4 2 3 
2690: 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  4}.do_test view-
26a0: 39 2e 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  9.6 {.  execsql 
26b0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
26c0: 52 4f 4d 20 76 31 30 20 4f 52 44 45 52 20 42 59  ROM v10 ORDER BY
26d0: 20 31 3b 0a 20 20 7d 0a 7d 20 7b 33 20 34 20 34   1;.  }.} {3 4 4
26e0: 20 32 20 35 20 31 7d 0a 0a 23 20 54 61 62 6c 65   2 5 1}..# Table
26f0: 73 20 77 69 74 68 20 63 6f 6c 75 6d 6e 73 20 68  s with columns h
2700: 61 76 69 6e 67 20 70 65 63 75 6c 69 61 72 20 71  aving peculiar q
2710: 75 6f 74 65 64 20 6e 61 6d 65 73 20 75 73 65 64  uoted names used
2720: 20 69 6e 20 76 69 65 77 73 0a 23 20 54 69 63 6b   in views.# Tick
2730: 65 74 20 23 37 35 36 2e 0a 23 0a 64 6f 5f 74 65  et #756..#.do_te
2740: 73 74 20 76 69 65 77 2d 31 30 2e 31 20 7b 0a 20  st view-10.1 {. 
2750: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
2760: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 22  REATE TABLE t3("
2770: 39 22 20 69 6e 74 65 67 65 72 2c 20 5b 34 5d 20  9" integer, [4] 
2780: 74 65 78 74 29 3b 0a 20 20 20 20 49 4e 53 45 52  text);.    INSER
2790: 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55 45 53  T INTO t3 VALUES
27a0: 28 31 2c 32 29 3b 0a 20 20 20 20 43 52 45 41 54  (1,2);.    CREAT
27b0: 45 20 56 49 45 57 20 76 5f 74 33 5f 61 20 41 53  E VIEW v_t3_a AS
27c0: 20 53 45 4c 45 43 54 20 61 2e 5b 39 5d 20 46 52   SELECT a.[9] FR
27d0: 4f 4d 20 74 33 20 41 53 20 61 3b 0a 20 20 20 20  OM t3 AS a;.    
27e0: 43 52 45 41 54 45 20 56 49 45 57 20 76 5f 74 33  CREATE VIEW v_t3
27f0: 5f 62 20 41 53 20 53 45 4c 45 43 54 20 22 34 22  _b AS SELECT "4"
2800: 20 46 52 4f 4d 20 74 33 3b 0a 20 20 20 20 53 45   FROM t3;.    SE
2810: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 5f 74 33  LECT * FROM v_t3
2820: 5f 61 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f  _a;.  }.} {1}.do
2830: 5f 74 65 73 74 20 76 69 65 77 2d 31 30 2e 32 20  _test view-10.2 
2840: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
2850: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2860: 76 5f 74 33 5f 62 3b 0a 20 20 7d 0a 7d 20 7b 32  v_t3_b;.  }.} {2
2870: 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }..do_test view-
2880: 31 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  11.1 {.  execsql
2890: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
28a0: 42 4c 45 20 74 34 28 61 20 43 4f 4c 4c 41 54 45  BLE t4(a COLLATE
28b0: 20 4e 4f 43 41 53 45 29 3b 0a 20 20 20 20 49 4e   NOCASE);.    IN
28c0: 53 45 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c  SERT INTO t4 VAL
28d0: 55 45 53 28 27 54 68 69 73 27 29 3b 0a 20 20 20  UES('This');.   
28e0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 34 20   INSERT INTO t4 
28f0: 56 41 4c 55 45 53 28 27 74 68 69 73 27 29 3b 0a  VALUES('this');.
2900: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
2910: 74 34 20 56 41 4c 55 45 53 28 27 54 48 49 53 27  t4 VALUES('THIS'
2920: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  );.    SELECT * 
2930: 46 52 4f 4d 20 74 34 20 57 48 45 52 45 20 61 20  FROM t4 WHERE a 
2940: 3d 20 27 54 48 49 53 27 3b 0a 20 20 7d 0a 7d 20  = 'THIS';.  }.} 
2950: 7b 54 68 69 73 20 74 68 69 73 20 54 48 49 53 7d  {This this THIS}
2960: 0a 69 66 63 61 70 61 62 6c 65 20 73 75 62 71 75  .ifcapable subqu
2970: 65 72 79 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  ery {.  do_test 
2980: 76 69 65 77 2d 31 31 2e 32 20 7b 0a 20 20 20 20  view-11.2 {.    
2990: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20  execsql {.      
29a0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 28 53  SELECT * FROM (S
29b0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 34 29  ELECT * FROM t4)
29c0: 20 57 48 45 52 45 20 61 20 3d 20 27 54 48 49 53   WHERE a = 'THIS
29d0: 27 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 54 68  ';.    }.  } {Th
29e0: 69 73 20 74 68 69 73 20 54 48 49 53 7d 0a 7d 0a  is this THIS}.}.
29f0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 31 2e  do_test view-11.
2a00: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  3 {.  execsql {.
2a10: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
2a20: 76 31 31 20 41 53 20 53 45 4c 45 43 54 20 2a 20  v11 AS SELECT * 
2a30: 46 52 4f 4d 20 74 34 3b 0a 20 20 20 20 53 45 4c  FROM t4;.    SEL
2a40: 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 31 20 57  ECT * FROM v11 W
2a50: 48 45 52 45 20 61 20 3d 20 27 54 48 49 53 27 3b  HERE a = 'THIS';
2a60: 0a 20 20 7d 0a 7d 20 7b 54 68 69 73 20 74 68 69  .  }.} {This thi
2a70: 73 20 54 48 49 53 7d 0a 0a 23 20 54 69 63 6b 65  s THIS}..# Ticke
2a80: 74 20 23 31 32 37 30 3a 20 20 44 6f 20 6e 6f 74  t #1270:  Do not
2a90: 20 61 6c 6c 6f 77 20 70 61 72 61 6d 65 74 65 72   allow parameter
2aa0: 73 20 69 6e 20 76 69 65 77 20 64 65 66 69 6e 69  s in view defini
2ab0: 74 69 6f 6e 73 2e 0a 23 0a 64 6f 5f 74 65 73 74  tions..#.do_test
2ac0: 20 76 69 65 77 2d 31 32 2e 31 20 7b 0a 20 20 63   view-12.1 {.  c
2ad0: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52  atchsql {.    CR
2ae0: 45 41 54 45 20 56 49 45 57 20 76 31 32 20 41 53  EATE VIEW v12 AS
2af0: 20 53 45 4c 45 43 54 20 61 20 46 52 4f 4d 20 74   SELECT a FROM t
2b00: 31 20 57 48 45 52 45 20 62 3d 3f 0a 20 20 7d 0a  1 WHERE b=?.  }.
2b10: 7d 20 7b 31 20 7b 70 61 72 61 6d 65 74 65 72 73  } {1 {parameters
2b20: 20 61 72 65 20 6e 6f 74 20 61 6c 6c 6f 77 65 64   are not allowed
2b30: 20 69 6e 20 76 69 65 77 73 7d 7d 0a 64 6f 5f 74   in views}}.do_t
2b40: 65 73 74 20 76 69 65 77 2d 31 32 2e 32 20 7b 0a  est view-12.2 {.
2b50: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
2b60: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 32   CREATE VIEW v12
2b70: 28 78 29 20 41 53 20 53 45 4c 45 43 54 20 61 20  (x) AS SELECT a 
2b80: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3d  FROM t1 WHERE b=
2b90: 3f 0a 20 20 7d 0a 7d 20 7b 31 20 7b 70 61 72 61  ?.  }.} {1 {para
2ba0: 6d 65 74 65 72 73 20 61 72 65 20 6e 6f 74 20 61  meters are not a
2bb0: 6c 6c 6f 77 65 64 20 69 6e 20 76 69 65 77 73 7d  llowed in views}
2bc0: 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 61 74 74  }..ifcapable att
2bd0: 61 63 68 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  ach {.  do_test 
2be0: 76 69 65 77 2d 31 33 2e 31 20 7b 0a 20 20 20 20  view-13.1 {.    
2bf0: 66 6f 72 63 65 64 65 6c 65 74 65 20 74 65 73 74  forcedelete test
2c00: 32 2e 64 62 0a 20 20 20 20 63 61 74 63 68 73 71  2.db.    catchsq
2c10: 6c 20 7b 0a 20 20 20 20 20 20 41 54 54 41 43 48  l {.      ATTACH
2c20: 20 27 74 65 73 74 32 2e 64 62 27 20 41 53 20 74   'test2.db' AS t
2c30: 77 6f 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45  wo;.      CREATE
2c40: 20 54 41 42 4c 45 20 74 77 6f 2e 74 32 28 78 2c   TABLE two.t2(x,
2c50: 79 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45  y);.      CREATE
2c60: 20 56 49 45 57 20 76 31 33 20 41 53 20 53 45 4c   VIEW v13 AS SEL
2c70: 45 43 54 20 79 20 46 52 4f 4d 20 74 77 6f 2e 74  ECT y FROM two.t
2c80: 32 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 20  2;.    }.  } {1 
2c90: 7b 76 69 65 77 20 76 31 33 20 63 61 6e 6e 6f 74  {view v13 cannot
2ca0: 20 72 65 66 65 72 65 6e 63 65 20 6f 62 6a 65 63   reference objec
2cb0: 74 73 20 69 6e 20 64 61 74 61 62 61 73 65 20 74  ts in database t
2cc0: 77 6f 7d 7d 0a 7d 0a 0a 23 20 54 69 63 6b 65 74  wo}}.}..# Ticket
2cd0: 20 23 31 36 35 38 0a 23 0a 64 6f 5f 74 65 73 74   #1658.#.do_test
2ce0: 20 76 69 65 77 2d 31 34 2e 31 20 7b 0a 20 20 63   view-14.1 {.  c
2cf0: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52  atchsql {.    CR
2d00: 45 41 54 45 20 54 45 4d 50 20 56 49 45 57 20 74  EATE TEMP VIEW t
2d10: 31 20 41 53 20 53 45 4c 45 43 54 20 61 2c 62 20  1 AS SELECT a,b 
2d20: 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c  FROM t1;.    SEL
2d30: 45 43 54 20 2a 20 46 52 4f 4d 20 74 65 6d 70 2e  ECT * FROM temp.
2d40: 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 76 69  t1;.  }.} {1 {vi
2d50: 65 77 20 74 31 20 69 73 20 63 69 72 63 75 6c 61  ew t1 is circula
2d60: 72 6c 79 20 64 65 66 69 6e 65 64 7d 7d 0a 64 6f  rly defined}}.do
2d70: 5f 74 65 73 74 20 76 69 65 77 2d 31 34 2e 32 20  _test view-14.2 
2d80: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
2d90: 20 20 20 44 52 4f 50 20 56 49 45 57 20 49 46 20     DROP VIEW IF 
2da0: 45 58 49 53 54 53 20 74 65 6d 70 2e 74 31 3b 0a  EXISTS temp.t1;.
2db0: 20 20 20 20 43 52 45 41 54 45 20 54 45 4d 50 20      CREATE TEMP 
2dc0: 56 49 45 57 20 74 31 28 61 2c 62 29 20 41 53 20  VIEW t1(a,b) AS 
2dd0: 53 45 4c 45 43 54 20 61 2c 62 20 46 52 4f 4d 20  SELECT a,b FROM 
2de0: 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t1;.    SELECT *
2df0: 20 46 52 4f 4d 20 74 65 6d 70 2e 74 31 3b 0a 20   FROM temp.t1;. 
2e00: 20 7d 0a 7d 20 7b 31 20 7b 76 69 65 77 20 74 31   }.} {1 {view t1
2e10: 20 69 73 20 63 69 72 63 75 6c 61 72 6c 79 20 64   is circularly d
2e20: 65 66 69 6e 65 64 7d 7d 0a 0a 23 20 54 69 63 6b  efined}}..# Tick
2e30: 65 74 73 20 23 31 36 38 38 2c 20 23 31 37 30 39  ets #1688, #1709
2e40: 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  .#.do_test view-
2e50: 31 35 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  15.1 {.  execsql
2e60: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
2e70: 49 45 57 20 76 31 35 20 41 53 20 53 45 4c 45 43  IEW v15 AS SELEC
2e80: 54 20 61 20 41 53 20 78 2c 20 62 20 41 53 20 79  T a AS x, b AS y
2e90: 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45   FROM t1;.    SE
2ea0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 35 20  LECT * FROM v15 
2eb0: 4c 49 4d 49 54 20 31 3b 0a 20 20 7d 0a 7d 20 7b  LIMIT 1;.  }.} {
2ec0: 78 20 32 20 79 20 33 7d 0a 64 6f 5f 74 65 73 74  x 2 y 3}.do_test
2ed0: 20 76 69 65 77 2d 31 35 2e 32 20 7b 0a 20 20 65   view-15.2 {.  e
2ee0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45  xecsql2 {.    SE
2ef0: 4c 45 43 54 20 78 2c 20 79 20 46 52 4f 4d 20 76  LECT x, y FROM v
2f00: 31 35 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a 7d  15 LIMIT 1.  }.}
2f10: 20 7b 78 20 32 20 79 20 33 7d 0a 0a 64 6f 5f 74   {x 2 y 3}..do_t
2f20: 65 73 74 20 76 69 65 77 2d 31 36 2e 31 20 7b 0a  est view-16.1 {.
2f30: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
2f40: 20 43 52 45 41 54 45 20 56 49 45 57 20 49 46 20   CREATE VIEW IF 
2f50: 4e 4f 54 20 45 58 49 53 54 53 20 76 31 20 41 53  NOT EXISTS v1 AS
2f60: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
2f70: 31 3b 0a 20 20 7d 0a 7d 20 7b 30 20 7b 7d 7d 0a  1;.  }.} {0 {}}.
2f80: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 36 2e  do_test view-16.
2f90: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  2 {.  execsql {.
2fa0: 20 20 20 20 53 45 4c 45 43 54 20 73 71 6c 20 46      SELECT sql F
2fb0: 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65  ROM sqlite_maste
2fc0: 72 20 57 48 45 52 45 20 6e 61 6d 65 3d 27 76 31  r WHERE name='v1
2fd0: 27 0a 20 20 7d 0a 7d 20 7b 7b 43 52 45 41 54 45  '.  }.} {{CREATE
2fe0: 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c 45   VIEW v1 AS SELE
2ff0: 43 54 20 61 20 41 53 20 27 78 79 7a 27 2c 20 62  CT a AS 'xyz', b
3000: 2b 63 20 41 53 20 27 70 71 72 27 2c 20 63 2d 62  +c AS 'pqr', c-b
3010: 20 46 52 4f 4d 20 74 31 7d 7d 0a 64 6f 5f 74 65   FROM t1}}.do_te
3020: 73 74 20 76 69 65 77 2d 31 36 2e 33 20 7b 0a 20  st view-16.3 {. 
3030: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
3040: 44 52 4f 50 20 56 49 45 57 20 49 46 20 45 58 49  DROP VIEW IF EXI
3050: 53 54 53 20 6e 6f 73 75 63 68 76 69 65 77 0a 20  STS nosuchview. 
3060: 20 7d 0a 7d 20 7b 30 20 7b 7d 7d 0a 0a 23 20 63   }.} {0 {}}..# c
3070: 6f 72 72 65 63 74 20 65 72 72 6f 72 20 6d 65 73  orrect error mes
3080: 73 61 67 65 20 77 68 65 6e 20 61 74 74 65 6d 70  sage when attemp
3090: 74 69 6e 67 20 74 6f 20 64 72 6f 70 20 61 20 76  ting to drop a v
30a0: 69 65 77 20 74 68 61 74 20 64 6f 65 73 20 6e 6f  iew that does no
30b0: 74 0a 23 20 65 78 69 73 74 2e 0a 23 0a 64 6f 5f  t.# exist..#.do_
30c0: 74 65 73 74 20 76 69 65 77 2d 31 37 2e 31 20 7b  test view-17.1 {
30d0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
30e0: 20 20 44 52 4f 50 20 56 49 45 57 20 6e 6f 73 75    DROP VIEW nosu
30f0: 63 68 76 69 65 77 0a 20 20 7d 0a 7d 20 7b 31 20  chview.  }.} {1 
3100: 7b 6e 6f 20 73 75 63 68 20 76 69 65 77 3a 20 6e  {no such view: n
3110: 6f 73 75 63 68 76 69 65 77 7d 7d 0a 64 6f 5f 74  osuchview}}.do_t
3120: 65 73 74 20 76 69 65 77 2d 31 37 2e 32 20 7b 0a  est view-17.2 {.
3130: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
3140: 20 44 52 4f 50 20 56 49 45 57 20 6d 61 69 6e 2e   DROP VIEW main.
3150: 6e 6f 73 75 63 68 76 69 65 77 0a 20 20 7d 0a 7d  nosuchview.  }.}
3160: 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 76 69 65   {1 {no such vie
3170: 77 3a 20 6d 61 69 6e 2e 6e 6f 73 75 63 68 76 69  w: main.nosuchvi
3180: 65 77 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69  ew}}..do_test vi
3190: 65 77 2d 31 38 2e 31 20 7b 0a 20 20 65 78 65 63  ew-18.1 {.  exec
31a0: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56  sql {.    DROP V
31b0: 49 45 57 20 74 31 3b 0a 20 20 20 20 44 52 4f 50  IEW t1;.    DROP
31c0: 20 54 41 42 4c 45 20 74 31 3b 0a 20 20 20 20 43   TABLE t1;.    C
31d0: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61  REATE TABLE t1(a
31e0: 2c 20 62 2c 20 63 29 3b 0a 20 20 20 20 49 4e 53  , b, c);.    INS
31f0: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
3200: 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a 20 20 20  ES(1, 2, 3);.   
3210: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
3220: 56 41 4c 55 45 53 28 34 2c 20 35 2c 20 36 29 3b  VALUES(4, 5, 6);
3230: 0a 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ..    CREATE VIE
3240: 57 20 76 76 31 20 41 53 20 53 45 4c 45 43 54 20  W vv1 AS SELECT 
3250: 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 43  * FROM t1;.    C
3260: 52 45 41 54 45 20 56 49 45 57 20 76 76 32 20 41  REATE VIEW vv2 A
3270: 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  S SELECT * FROM 
3280: 76 76 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20  vv1;.    CREATE 
3290: 56 49 45 57 20 76 76 33 20 41 53 20 53 45 4c 45  VIEW vv3 AS SELE
32a0: 43 54 20 2a 20 46 52 4f 4d 20 76 76 32 3b 0a 20  CT * FROM vv2;. 
32b0: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
32c0: 76 34 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46  v4 AS SELECT * F
32d0: 52 4f 4d 20 76 76 33 3b 0a 20 20 20 20 43 52 45  ROM vv3;.    CRE
32e0: 41 54 45 20 56 49 45 57 20 76 76 35 20 41 53 20  ATE VIEW vv5 AS 
32f0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 76  SELECT * FROM vv
3300: 34 3b 0a 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  4;..    SELECT *
3310: 20 46 52 4f 4d 20 76 76 35 3b 0a 20 20 7d 0a 7d   FROM vv5;.  }.}
3320: 20 7b 31 20 32 20 33 20 34 20 35 20 36 7d 0a 0a   {1 2 3 4 5 6}..
3330: 23 20 54 69 63 6b 65 74 20 23 33 33 30 38 0a 23  # Ticket #3308.#
3340: 20 4d 61 6b 65 20 73 75 72 65 20 22 72 6f 77 69   Make sure "rowi
3350: 64 22 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 61 20  d" columns in a 
3360: 76 69 65 77 20 61 72 65 20 6e 61 6d 65 64 20 63  view are named c
3370: 6f 72 72 65 63 74 6c 79 2e 0a 23 0a 64 6f 5f 74  orrectly..#.do_t
3380: 65 73 74 20 76 69 65 77 2d 31 39 2e 31 20 7b 0a  est view-19.1 {.
3390: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
33a0: 43 52 45 41 54 45 20 56 49 45 57 20 76 33 33 30  CREATE VIEW v330
33b0: 38 61 20 41 53 20 53 45 4c 45 43 54 20 72 6f 77  8a AS SELECT row
33c0: 69 64 2c 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20  id, * FROM t1;. 
33d0: 20 7d 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a   }.  execsql2 {.
33e0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
33f0: 4d 20 76 33 33 30 38 61 0a 20 20 7d 0a 7d 20 7b  M v3308a.  }.} {
3400: 72 6f 77 69 64 20 31 20 61 20 31 20 62 20 32 20  rowid 1 a 1 b 2 
3410: 63 20 33 20 72 6f 77 69 64 20 32 20 61 20 34 20  c 3 rowid 2 a 4 
3420: 62 20 35 20 63 20 36 7d 0a 64 6f 5f 74 65 73 74  b 5 c 6}.do_test
3430: 20 76 69 65 77 2d 31 39 2e 32 20 7b 0a 20 20 65   view-19.2 {.  e
3440: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
3450: 41 54 45 20 56 49 45 57 20 76 33 33 30 38 62 20  ATE VIEW v3308b 
3460: 41 53 20 53 45 4c 45 43 54 20 74 31 2e 72 6f 77  AS SELECT t1.row
3470: 69 64 2c 20 74 31 2e 61 2c 20 74 31 2e 62 2b 74  id, t1.a, t1.b+t
3480: 31 2e 63 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  1.c FROM t1;.  }
3490: 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20  .  execsql2 {.  
34a0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
34b0: 76 33 33 30 38 62 0a 20 20 7d 0a 7d 20 7b 72 6f  v3308b.  }.} {ro
34c0: 77 69 64 20 31 20 61 20 31 20 74 31 2e 62 2b 74  wid 1 a 1 t1.b+t
34d0: 31 2e 63 20 35 20 72 6f 77 69 64 20 32 20 61 20  1.c 5 rowid 2 a 
34e0: 34 20 74 31 2e 62 2b 74 31 2e 63 20 31 31 7d 0a  4 t1.b+t1.c 11}.
34f0: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 39 2e  do_test view-19.
3500: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  3 {.  execsql {.
3510: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
3520: 76 33 33 30 38 63 20 41 53 20 53 45 4c 45 43 54  v3308c AS SELECT
3530: 20 74 31 2e 6f 69 64 2c 20 41 2c 20 74 31 2e 62   t1.oid, A, t1.b
3540: 2b 74 31 2e 63 20 41 53 20 78 20 46 52 4f 4d 20  +t1.c AS x FROM 
3550: 74 31 3b 0a 20 20 7d 0a 20 20 65 78 65 63 73 71  t1;.  }.  execsq
3560: 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  l2 {.    SELECT 
3570: 2a 20 46 52 4f 4d 20 76 33 33 30 38 63 0a 20 20  * FROM v3308c.  
3580: 7d 0a 7d 20 7b 72 6f 77 69 64 20 31 20 61 20 31  }.} {rowid 1 a 1
3590: 20 78 20 35 20 72 6f 77 69 64 20 32 20 61 20 34   x 5 rowid 2 a 4
35a0: 20 78 20 31 31 7d 0a 0a 23 20 54 69 63 6b 65 74   x 11}..# Ticket
35b0: 20 23 33 35 33 39 20 68 61 64 20 74 68 69 73 20   #3539 had this 
35c0: 63 72 61 73 68 69 6e 67 20 28 73 65 65 20 63 6f  crashing (see co
35d0: 6d 6d 69 74 20 5b 35 39 34 30 5d 29 2e 0a 64 6f  mmit [5940])..do
35e0: 5f 74 65 73 74 20 76 69 65 77 2d 32 30 2e 31 20  _test view-20.1 
35f0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
3600: 20 20 44 52 4f 50 20 54 41 42 4c 45 20 49 46 20    DROP TABLE IF 
3610: 45 58 49 53 54 53 20 74 31 3b 0a 20 20 20 20 44  EXISTS t1;.    D
3620: 52 4f 50 20 56 49 45 57 20 49 46 20 45 58 49 53  ROP VIEW IF EXIS
3630: 54 53 20 76 31 3b 0a 20 20 20 20 43 52 45 41 54  TS v1;.    CREAT
3640: 45 20 54 41 42 4c 45 20 74 31 28 63 31 29 3b 0a  E TABLE t1(c1);.
3650: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
3660: 76 31 20 41 53 20 53 45 4c 45 43 54 20 63 31 20  v1 AS SELECT c1 
3670: 46 52 4f 4d 20 28 53 45 4c 45 43 54 20 74 31 2e  FROM (SELECT t1.
3680: 63 31 20 46 52 4f 4d 20 74 31 29 3b 0a 20 20 7d  c1 FROM t1);.  }
3690: 0a 7d 20 7b 7d 0a 0a 23 20 54 69 63 6b 65 74 20  .} {}..# Ticket 
36a0: 5b 64 35 38 63 63 62 62 33 66 31 62 5d 3a 20 50  [d58ccbb3f1b]: P
36b0: 72 65 76 65 6e 74 20 54 61 62 6c 65 2e 6e 52 65  revent Table.nRe
36c0: 66 20 6f 76 65 72 66 6c 6f 77 2e 0a 64 62 20 63  f overflow..db c
36d0: 6c 6f 73 65 0a 73 71 6c 69 74 65 33 20 64 62 20  lose.sqlite3 db 
36e0: 3a 6d 65 6d 6f 72 79 3a 0a 64 6f 5f 74 65 73 74  :memory:.do_test
36f0: 20 76 69 65 77 2d 32 31 2e 31 20 7b 0a 20 20 63   view-21.1 {.  c
3700: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52  atchsql {.    CR
3710: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 78 29  EATE TABLE t1(x)
3720: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
3730: 4f 20 74 31 20 56 41 4c 55 45 53 28 35 29 3b 0a  O t1 VALUES(5);.
3740: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
3750: 76 31 20 41 53 20 53 45 4c 45 43 54 20 78 2a 32  v1 AS SELECT x*2
3760: 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 43 52   FROM t1;.    CR
3770: 45 41 54 45 20 56 49 45 57 20 76 32 20 41 53 20  EATE VIEW v2 AS 
3780: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
3790: 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20   UNION SELECT * 
37a0: 46 52 4f 4d 20 76 31 3b 0a 20 20 20 20 43 52 45  FROM v1;.    CRE
37b0: 41 54 45 20 56 49 45 57 20 76 34 20 41 53 20 53  ATE VIEW v4 AS S
37c0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 20  ELECT * FROM v2 
37d0: 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46  UNION SELECT * F
37e0: 52 4f 4d 20 76 32 3b 0a 20 20 20 20 43 52 45 41  ROM v2;.    CREA
37f0: 54 45 20 56 49 45 57 20 76 38 20 41 53 20 53 45  TE VIEW v8 AS SE
3800: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 34 20 55  LECT * FROM v4 U
3810: 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52  NION SELECT * FR
3820: 4f 4d 20 76 34 3b 0a 20 20 20 20 43 52 45 41 54  OM v4;.    CREAT
3830: 45 20 56 49 45 57 20 76 31 36 20 41 53 20 53 45  E VIEW v16 AS SE
3840: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 38 20 55  LECT * FROM v8 U
3850: 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52  NION SELECT * FR
3860: 4f 4d 20 76 38 3b 0a 20 20 20 20 43 52 45 41 54  OM v8;.    CREAT
3870: 45 20 56 49 45 57 20 76 33 32 20 41 53 20 53 45  E VIEW v32 AS SE
3880: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 36 20  LECT * FROM v16 
3890: 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46  UNION SELECT * F
38a0: 52 4f 4d 20 76 31 36 3b 0a 20 20 20 20 43 52 45  ROM v16;.    CRE
38b0: 41 54 45 20 56 49 45 57 20 76 36 34 20 41 53 20  ATE VIEW v64 AS 
38c0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 33  SELECT * FROM v3
38d0: 32 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a  2 UNION SELECT *
38e0: 20 46 52 4f 4d 20 76 33 32 3b 0a 20 20 20 20 43   FROM v32;.    C
38f0: 52 45 41 54 45 20 56 49 45 57 20 76 31 32 38 20  REATE VIEW v128 
3900: 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  AS SELECT * FROM
3910: 20 76 36 34 20 55 4e 49 4f 4e 20 53 45 4c 45 43   v64 UNION SELEC
3920: 54 20 2a 20 46 52 4f 4d 20 76 36 34 3b 0a 20 20  T * FROM v64;.  
3930: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 32    CREATE VIEW v2
3940: 35 36 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46  56 AS SELECT * F
3950: 52 4f 4d 20 76 31 32 38 20 55 4e 49 4f 4e 20 53  ROM v128 UNION S
3960: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 32  ELECT * FROM v12
3970: 38 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49  8;.    CREATE VI
3980: 45 57 20 76 35 31 32 20 41 53 20 53 45 4c 45 43  EW v512 AS SELEC
3990: 54 20 2a 20 46 52 4f 4d 20 76 32 35 36 20 55 4e  T * FROM v256 UN
39a0: 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  ION SELECT * FRO
39b0: 4d 20 76 32 35 36 3b 0a 20 20 20 20 43 52 45 41  M v256;.    CREA
39c0: 54 45 20 56 49 45 57 20 76 31 30 32 34 20 41 53  TE VIEW v1024 AS
39d0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
39e0: 35 31 32 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54  512 UNION SELECT
39f0: 20 2a 20 46 52 4f 4d 20 76 35 31 32 3b 0a 20 20   * FROM v512;.  
3a00: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 32    CREATE VIEW v2
3a10: 30 34 38 20 41 53 20 53 45 4c 45 43 54 20 2a 20  048 AS SELECT * 
3a20: 46 52 4f 4d 20 76 31 30 32 34 20 55 4e 49 4f 4e  FROM v1024 UNION
3a30: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
3a40: 31 30 32 34 3b 0a 20 20 20 20 43 52 45 41 54 45  1024;.    CREATE
3a50: 20 56 49 45 57 20 76 34 30 39 36 20 41 53 20 53   VIEW v4096 AS S
3a60: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 30  ELECT * FROM v20
3a70: 34 38 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20  48 UNION SELECT 
3a80: 2a 20 46 52 4f 4d 20 76 32 30 34 38 3b 0a 20 20  * FROM v2048;.  
3a90: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 38    CREATE VIEW v8
3aa0: 31 39 32 20 41 53 20 53 45 4c 45 43 54 20 2a 20  192 AS SELECT * 
3ab0: 46 52 4f 4d 20 76 34 30 39 36 20 55 4e 49 4f 4e  FROM v4096 UNION
3ac0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
3ad0: 34 30 39 36 3b 0a 20 20 20 20 43 52 45 41 54 45  4096;.    CREATE
3ae0: 20 56 49 45 57 20 76 31 36 33 38 34 20 41 53 20   VIEW v16384 AS 
3af0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 38  SELECT * FROM v8
3b00: 31 39 32 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54  192 UNION SELECT
3b10: 20 2a 20 46 52 4f 4d 20 76 38 31 39 32 3b 0a 20   * FROM v8192;. 
3b20: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
3b30: 33 32 37 36 38 20 41 53 20 53 45 4c 45 43 54 20  32768 AS SELECT 
3b40: 2a 20 46 52 4f 4d 20 76 31 36 33 38 34 20 55 4e  * FROM v16384 UN
3b50: 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  ION SELECT * FRO
3b60: 4d 20 76 31 36 33 38 34 3b 0a 20 20 20 20 53 45  M v16384;.    SE
3b70: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 33 32 37  LECT * FROM v327
3b80: 36 38 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20  68 UNION SELECT 
3b90: 2a 20 46 52 4f 4d 20 76 33 32 37 36 38 3b 0a 20  * FROM v32768;. 
3ba0: 20 7d 0a 7d 20 7b 31 20 7b 74 6f 6f 20 6d 61 6e   }.} {1 {too man
3bb0: 79 20 72 65 66 65 72 65 6e 63 65 73 20 74 6f 20  y references to 
3bc0: 22 76 31 22 3a 20 6d 61 78 20 36 35 35 33 35 7d  "v1": max 65535}
3bd0: 7d 0a 69 66 63 61 70 61 62 6c 65 20 70 72 6f 67  }.ifcapable prog
3be0: 72 65 73 73 20 7b 0a 20 20 64 6f 5f 74 65 73 74  ress {.  do_test
3bf0: 20 76 69 65 77 2d 32 31 2e 32 20 7b 0a 20 20 20   view-21.2 {.   
3c00: 20 64 62 20 70 72 6f 67 72 65 73 73 20 31 30 30   db progress 100
3c10: 30 20 7b 65 78 70 72 20 31 7d 0a 20 20 20 20 63  0 {expr 1}.    c
3c20: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 20 20  atchsql {.      
3c30: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 33  SELECT * FROM v3
3c40: 32 37 36 38 3b 0a 20 20 20 20 7d 0a 20 20 7d 20  2768;.    }.  } 
3c50: 7b 31 20 69 6e 74 65 72 72 75 70 74 65 64 7d 0a  {1 interrupted}.
3c60: 7d 0a 0a 64 62 20 63 6c 6f 73 65 0a 73 71 6c 69  }..db close.sqli
3c70: 74 65 33 20 64 62 20 3a 6d 65 6d 6f 72 79 3a 0a  te3 db :memory:.
3c80: 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
3c90: 76 69 65 77 2d 32 32 2e 31 20 7b 0a 20 20 43 52  view-22.1 {.  CR
3ca0: 45 41 54 45 20 56 49 45 57 20 78 31 20 41 53 20  EATE VIEW x1 AS 
3cb0: 53 45 4c 45 43 54 20 31 32 33 20 41 53 20 27 27  SELECT 123 AS ''
3cc0: 2c 20 32 33 34 20 41 53 20 27 27 2c 20 33 34 35  , 234 AS '', 345
3cd0: 20 41 53 20 27 27 3b 0a 20 20 53 45 4c 45 43 54   AS '';.  SELECT
3ce0: 20 2a 20 46 52 4f 4d 20 78 31 3b 0a 7d 20 7b 31   * FROM x1;.} {1
3cf0: 32 33 20 32 33 34 20 33 34 35 7d 0a 64 6f 5f 74  23 234 345}.do_t
3d00: 65 73 74 20 76 69 65 77 2d 32 32 2e 32 20 7b 0a  est view-22.2 {.
3d10: 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c    unset -nocompl
3d20: 61 69 6e 20 78 0a 20 20 64 62 20 65 76 61 6c 20  ain x.  db eval 
3d30: 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 78  {SELECT * FROM x
3d40: 31 7d 20 78 20 62 72 65 61 6b 0a 20 20 6c 73 6f  1} x break.  lso
3d50: 72 74 20 5b 61 72 72 61 79 20 6e 61 6d 65 73 20  rt [array names 
3d60: 78 5d 0a 7d 20 7b 7b 7d 20 2a 20 3a 31 20 3a 32  x].} {{} * :1 :2
3d70: 7d 0a 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a  }...finish_test.