/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact bfdec45ad4b2ed5dd5fddbc3dcafcfca2ab23574:


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 64 6f 5f 74   b+c 7 c 4}.do_t
0d40: 65 73 74 20 76 69 65 77 2d 33 2e 33 2e 33 20 7b  est view-3.3.3 {
0d50: 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20  .  execsql2 {.  
0d60: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31    CREATE VIEW v1
0d70: 63 28 78 2c 79 2c 7a 29 20 41 53 20 53 45 4c 45  c(x,y,z) AS SELE
0d80: 43 54 20 61 2c 20 62 2b 63 2c 20 63 2d 62 20 46  CT a, b+c, c-b F
0d90: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  ROM t1;.    SELE
0da0: 43 54 20 2a 20 46 52 4f 4d 20 76 31 63 20 4c 49  CT * FROM v1c LI
0db0: 4d 49 54 20 31 3b 0a 20 20 7d 0a 7d 20 7b 78 20  MIT 1;.  }.} {x 
0dc0: 32 20 79 20 37 20 7a 20 31 7d 0a 64 6f 5f 63 61  2 y 7 z 1}.do_ca
0dd0: 74 63 68 73 71 6c 5f 74 65 73 74 20 76 69 65 77  tchsql_test view
0de0: 2d 33 2e 33 2e 34 20 7b 0a 20 20 43 52 45 41 54  -3.3.4 {.  CREAT
0df0: 45 20 56 49 45 57 20 76 31 65 72 72 28 78 2c 79  E VIEW v1err(x,y
0e00: 20 44 45 53 43 2c 7a 29 20 41 53 20 53 45 4c 45   DESC,z) AS SELE
0e10: 43 54 20 61 2c 20 62 2b 63 2c 20 63 2d 62 20 46  CT a, b+c, c-b F
0e20: 52 4f 4d 20 74 31 3b 0a 7d 20 7b 31 20 7b 73 79  ROM t1;.} {1 {sy
0e30: 6e 74 61 78 20 65 72 72 6f 72 20 61 66 74 65 72  ntax error after
0e40: 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 20 22 79 22   column name "y"
0e50: 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74  }}.do_catchsql_t
0e60: 65 73 74 20 76 69 65 77 2d 33 2e 33 2e 35 20 7b  est view-3.3.5 {
0e70: 0a 20 20 44 52 4f 50 20 56 49 45 57 20 49 46 20  .  DROP VIEW IF 
0e80: 45 58 49 53 54 53 20 76 31 65 72 72 3b 0a 20 20  EXISTS v1err;.  
0e90: 43 52 45 41 54 45 20 56 49 45 57 20 76 31 65 72  CREATE VIEW v1er
0ea0: 72 28 78 2c 79 29 20 41 53 20 53 45 4c 45 43 54  r(x,y) AS SELECT
0eb0: 20 61 2c 20 62 2b 63 2c 20 63 2d 62 20 46 52 4f   a, b+c, c-b FRO
0ec0: 4d 20 74 31 3b 0a 20 20 53 45 4c 45 43 54 20 2a  M t1;.  SELECT *
0ed0: 20 46 52 4f 4d 20 76 31 65 72 72 3b 0a 7d 20 7b   FROM v1err;.} {
0ee0: 31 20 7b 65 78 70 65 63 74 65 64 20 32 20 63 6f  1 {expected 2 co
0ef0: 6c 75 6d 6e 73 20 66 6f 72 20 27 76 31 65 72 72  lumns for 'v1err
0f00: 27 20 62 75 74 20 67 6f 74 20 33 7d 7d 0a 64 6f  ' but got 3}}.do
0f10: 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20 76  _catchsql_test v
0f20: 69 65 77 2d 33 2e 33 2e 36 20 7b 0a 20 20 44 52  iew-3.3.6 {.  DR
0f30: 4f 50 20 56 49 45 57 20 49 46 20 45 58 49 53 54  OP VIEW IF EXIST
0f40: 53 20 76 31 65 72 72 3b 0a 20 20 43 52 45 41 54  S v1err;.  CREAT
0f50: 45 20 56 49 45 57 20 76 31 65 72 72 28 77 2c 78  E VIEW v1err(w,x
0f60: 2c 79 2c 7a 29 20 41 53 20 53 45 4c 45 43 54 20  ,y,z) AS SELECT 
0f70: 61 2c 20 62 2b 63 2c 20 63 2d 62 20 46 52 4f 4d  a, b+c, c-b FROM
0f80: 20 74 31 3b 0a 20 20 53 45 4c 45 43 54 20 2a 20   t1;.  SELECT * 
0f90: 46 52 4f 4d 20 76 31 65 72 72 3b 0a 7d 20 7b 31  FROM v1err;.} {1
0fa0: 20 7b 65 78 70 65 63 74 65 64 20 34 20 63 6f 6c   {expected 4 col
0fb0: 75 6d 6e 73 20 66 6f 72 20 27 76 31 65 72 72 27  umns for 'v1err'
0fc0: 20 62 75 74 20 67 6f 74 20 33 7d 7d 0a 0a 69 66   but got 3}}..if
0fd0: 63 61 70 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64  capable compound
0fe0: 20 7b 0a 64 6f 5f 74 65 73 74 20 20 76 69 65 77   {.do_test  view
0ff0: 2d 33 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.4 {.  execsql
1000: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
1010: 49 45 57 20 76 33 20 41 53 20 53 45 4c 45 43 54  IEW v3 AS SELECT
1020: 20 61 20 46 52 4f 4d 20 74 31 20 55 4e 49 4f 4e   a FROM t1 UNION
1030: 20 53 45 4c 45 43 54 20 62 20 46 52 4f 4d 20 74   SELECT b FROM t
1040: 31 20 4f 52 44 45 52 20 42 59 20 62 3b 0a 20 20  1 ORDER BY b;.  
1050: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
1060: 76 33 20 4c 49 4d 49 54 20 34 3b 0a 20 20 7d 0a  v3 LIMIT 4;.  }.
1070: 7d 20 7b 61 20 32 20 61 20 33 20 61 20 35 20 61  } {a 2 a 3 a 5 a
1080: 20 36 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   6}.do_test view
1090: 2d 33 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.5 {.  execsql
10a0: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
10b0: 49 45 57 20 76 34 20 41 53 20 0a 20 20 20 20 20  IEW v4 AS .     
10c0: 20 53 45 4c 45 43 54 20 61 2c 20 62 20 46 52 4f   SELECT a, b FRO
10d0: 4d 20 74 31 20 0a 20 20 20 20 20 20 55 4e 49 4f  M t1 .      UNIO
10e0: 4e 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 62  N.      SELECT b
10f0: 20 41 53 20 27 78 27 2c 20 61 20 41 53 20 27 79   AS 'x', a AS 'y
1100: 27 20 46 52 4f 4d 20 74 31 0a 20 20 20 20 20 20  ' FROM t1.      
1110: 4f 52 44 45 52 20 42 59 20 78 2c 20 79 3b 0a 20  ORDER BY x, y;. 
1120: 20 20 20 53 45 4c 45 43 54 20 62 20 46 52 4f 4d     SELECT b FROM
1130: 20 76 34 20 4f 52 44 45 52 20 42 59 20 62 20 4c   v4 ORDER BY b L
1140: 49 4d 49 54 20 34 3b 0a 20 20 7d 0a 7d 20 7b 62  IMIT 4;.  }.} {b
1150: 20 32 20 62 20 33 20 62 20 35 20 62 20 36 7d 0a   2 b 3 b 5 b 6}.
1160: 7d 20 3b 23 20 69 66 63 61 70 61 62 6c 65 20 63  } ;# ifcapable c
1170: 6f 6d 70 6f 75 6e 64 0a 0a 0a 64 6f 5f 74 65 73  ompound...do_tes
1180: 74 20 76 69 65 77 2d 34 2e 31 20 7b 0a 20 20 63  t view-4.1 {.  c
1190: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 44 52  atchsql {.    DR
11a0: 4f 50 20 56 49 45 57 20 74 31 3b 0a 20 20 7d 0a  OP VIEW t1;.  }.
11b0: 7d 20 7b 31 20 7b 75 73 65 20 44 52 4f 50 20 54  } {1 {use DROP T
11c0: 41 42 4c 45 20 74 6f 20 64 65 6c 65 74 65 20 74  ABLE to delete t
11d0: 61 62 6c 65 20 74 31 7d 7d 0a 64 6f 5f 74 65 73  able t1}}.do_tes
11e0: 74 20 76 69 65 77 2d 34 2e 32 20 7b 0a 20 20 65  t view-4.2 {.  e
11f0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1200: 45 43 54 20 31 20 46 52 4f 4d 20 74 31 20 4c 49  ECT 1 FROM t1 LI
1210: 4d 49 54 20 31 3b 0a 20 20 7d 0a 7d 20 31 0a 64  MIT 1;.  }.} 1.d
1220: 6f 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 33 20  o_test view-4.3 
1230: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
1240: 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20 76 31     DROP TABLE v1
1250: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73 65 20  ;.  }.} {1 {use 
1260: 44 52 4f 50 20 56 49 45 57 20 74 6f 20 64 65 6c  DROP VIEW to del
1270: 65 74 65 20 76 69 65 77 20 76 31 7d 7d 0a 64 6f  ete view v1}}.do
1280: 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 34 20 7b  _test view-4.4 {
1290: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
12a0: 20 20 53 45 4c 45 43 54 20 31 20 46 52 4f 4d 20    SELECT 1 FROM 
12b0: 76 31 20 4c 49 4d 49 54 20 31 3b 0a 20 20 7d 0a  v1 LIMIT 1;.  }.
12c0: 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69  } {1}.do_test vi
12d0: 65 77 2d 34 2e 35 20 7b 0a 20 20 63 61 74 63 68  ew-4.5 {.  catch
12e0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
12f0: 20 49 4e 44 45 58 20 69 31 76 31 20 4f 4e 20 76   INDEX i1v1 ON v
1300: 31 28 78 79 7a 29 3b 0a 20 20 7d 0a 7d 20 7b 31  1(xyz);.  }.} {1
1310: 20 7b 76 69 65 77 73 20 6d 61 79 20 6e 6f 74 20   {views may not 
1320: 62 65 20 69 6e 64 65 78 65 64 7d 7d 0a 0a 64 6f  be indexed}}..do
1330: 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 31 20 7b  _test view-5.1 {
1340: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1350: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
1360: 28 79 2c 61 29 3b 0a 20 20 20 20 49 4e 53 45 52  (y,a);.    INSER
1370: 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53  T INTO t2 VALUES
1380: 28 32 32 2c 32 29 3b 0a 20 20 20 20 49 4e 53 45  (22,2);.    INSE
1390: 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45  RT INTO t2 VALUE
13a0: 53 28 33 33 2c 33 29 3b 0a 20 20 20 20 49 4e 53  S(33,3);.    INS
13b0: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
13c0: 45 53 28 34 34 2c 34 29 3b 0a 20 20 20 20 49 4e  ES(44,4);.    IN
13d0: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
13e0: 55 45 53 28 35 35 2c 35 29 3b 0a 20 20 20 20 53  UES(55,5);.    S
13f0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b  ELECT * FROM t2;
1400: 0a 20 20 7d 0a 7d 20 7b 32 32 20 32 20 33 33 20  .  }.} {22 2 33 
1410: 33 20 34 34 20 34 20 35 35 20 35 7d 0a 64 6f 5f  3 44 4 55 5}.do_
1420: 74 65 73 74 20 76 69 65 77 2d 35 2e 32 20 7b 0a  test view-5.2 {.
1430: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1440: 43 52 45 41 54 45 20 56 49 45 57 20 76 35 20 41  CREATE VIEW v5 A
1450: 53 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 74  S.      SELECT t
1460: 31 2e 78 20 41 53 20 76 2c 20 74 32 2e 79 20 41  1.x AS v, t2.y A
1470: 53 20 77 20 46 52 4f 4d 20 74 31 20 4a 4f 49 4e  S w FROM t1 JOIN
1480: 20 74 32 20 55 53 49 4e 47 28 61 29 3b 0a 20 20   t2 USING(a);.  
1490: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
14a0: 76 35 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 32 20  v5;.  }.} {1 22 
14b0: 34 20 35 35 7d 0a 0a 23 20 56 65 72 69 66 79 20  4 55}..# Verify 
14c0: 74 68 61 74 20 74 68 65 20 76 69 65 77 20 76 35  that the view v5
14d0: 20 67 65 74 73 20 66 6c 61 74 74 65 6e 65 64 2e   gets flattened.
14e0: 20 20 73 65 65 20 73 71 6c 69 74 65 46 6c 61 74    see sqliteFlat
14f0: 74 65 6e 53 75 62 71 75 65 72 79 28 29 2e 0a 23  tenSubquery()..#
1500: 20 54 68 69 73 20 77 69 6c 6c 20 6f 6e 6c 79 20   This will only 
1510: 77 6f 72 6b 20 69 66 20 45 58 50 4c 41 49 4e 20  work if EXPLAIN 
1520: 69 73 20 65 6e 61 62 6c 65 64 2e 0a 23 20 54 69  is enabled..# Ti
1530: 63 6b 65 74 20 23 32 37 32 0a 23 0a 69 66 63 61  cket #272.#.ifca
1540: 70 61 62 6c 65 20 7b 65 78 70 6c 61 69 6e 7d 20  pable {explain} 
1550: 7b 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35  {.do_test view-5
1560: 2e 33 20 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b  .3 {.  lsearch [
1570: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 45 58  execsql {.    EX
1580: 50 4c 41 49 4e 20 53 45 4c 45 43 54 20 2a 20 46  PLAIN SELECT * F
1590: 52 4f 4d 20 76 35 3b 0a 20 20 7d 5d 20 4f 70 65  ROM v5;.  }] Ope
15a0: 6e 45 70 68 65 6d 65 72 61 6c 0a 7d 20 7b 2d 31  nEphemeral.} {-1
15b0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35  }.do_test view-5
15c0: 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .4 {.  execsql {
15d0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
15e0: 4f 4d 20 76 35 20 41 53 20 61 2c 20 74 32 20 41  OM v5 AS a, t2 A
15f0: 53 20 62 20 57 48 45 52 45 20 61 2e 77 3d 62 2e  S b WHERE a.w=b.
1600: 79 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 32 20 32  y;.  }.} {1 22 2
1610: 32 20 32 20 34 20 35 35 20 35 35 20 35 7d 0a 64  2 2 4 55 55 5}.d
1620: 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 35 20  o_test view-5.5 
1630: 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65  {.  lsearch [exe
1640: 63 73 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41  csql {.    EXPLA
1650: 49 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  IN SELECT * FROM
1660: 20 76 35 20 41 53 20 61 2c 20 74 32 20 41 53 20   v5 AS a, t2 AS 
1670: 62 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b  b WHERE a.w=b.y;
1680: 0a 20 20 7d 5d 20 4f 70 65 6e 45 70 68 65 6d 65  .  }] OpenEpheme
1690: 72 61 6c 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65  ral.} {-1}.do_te
16a0: 73 74 20 76 69 65 77 2d 35 2e 36 20 7b 0a 20 20  st view-5.6 {.  
16b0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
16c0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 41  LECT * FROM t2 A
16d0: 53 20 62 2c 20 76 35 20 41 53 20 61 20 57 48 45  S b, v5 AS a WHE
16e0: 52 45 20 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 0a  RE a.w=b.y;.  }.
16f0: 7d 20 7b 32 32 20 32 20 31 20 32 32 20 35 35 20  } {22 2 1 22 55 
1700: 35 20 34 20 35 35 7d 0a 64 6f 5f 74 65 73 74 20  5 4 55}.do_test 
1710: 76 69 65 77 2d 35 2e 37 20 7b 0a 20 20 6c 73 65  view-5.7 {.  lse
1720: 61 72 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a  arch [execsql {.
1730: 20 20 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45      EXPLAIN SELE
1740: 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 41 53 20  CT * FROM t2 AS 
1750: 62 2c 20 76 35 20 41 53 20 61 20 57 48 45 52 45  b, v5 AS a WHERE
1760: 20 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 5d 20 4f   a.w=b.y;.  }] O
1770: 70 65 6e 45 70 68 65 6d 65 72 61 6c 0a 7d 20 7b  penEphemeral.} {
1780: 2d 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  -1}.do_test view
1790: 2d 35 2e 38 20 7b 0a 20 20 65 78 65 63 73 71 6c  -5.8 {.  execsql
17a0: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
17b0: 46 52 4f 4d 20 74 31 20 41 53 20 61 2c 20 76 35  FROM t1 AS a, v5
17c0: 20 41 53 20 62 2c 20 74 32 20 41 53 20 63 20 57   AS b, t2 AS c W
17d0: 48 45 52 45 20 61 2e 78 3d 62 2e 76 20 41 4e 44  HERE a.x=b.v AND
17e0: 20 62 2e 77 3d 63 2e 79 3b 0a 20 20 7d 0a 7d 20   b.w=c.y;.  }.} 
17f0: 7b 31 20 32 20 33 20 34 20 31 20 32 32 20 32 32  {1 2 3 4 1 22 22
1800: 20 32 20 34 20 35 20 36 20 37 20 34 20 35 35 20   2 4 5 6 7 4 55 
1810: 35 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69  55 5}.do_test vi
1820: 65 77 2d 35 2e 39 20 7b 0a 20 20 6c 73 65 61 72  ew-5.9 {.  lsear
1830: 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20 20  ch [execsql {.  
1840: 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43 54    EXPLAIN SELECT
1850: 20 2a 20 46 52 4f 4d 20 74 31 20 41 53 20 61 2c   * FROM t1 AS a,
1860: 20 76 35 20 41 53 20 62 2c 20 74 32 20 41 53 20   v5 AS b, t2 AS 
1870: 63 20 57 48 45 52 45 20 61 2e 78 3d 62 2e 76 20  c WHERE a.x=b.v 
1880: 41 4e 44 20 62 2e 77 3d 63 2e 79 3b 0a 20 20 7d  AND b.w=c.y;.  }
1890: 5d 20 4f 70 65 6e 45 70 68 65 6d 65 72 61 6c 0a  ] OpenEphemeral.
18a0: 7d 20 7b 2d 31 7d 0a 7d 20 3b 23 20 65 6e 64 69  } {-1}.} ;# endi
18b0: 66 20 65 78 70 6c 61 69 6e 0a 0a 64 6f 5f 74 65  f explain..do_te
18c0: 73 74 20 76 69 65 77 2d 36 2e 31 20 7b 0a 20 20  st view-6.1 {.  
18d0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
18e0: 4c 45 43 54 20 6d 69 6e 28 78 29 2c 20 6d 69 6e  LECT min(x), min
18f0: 28 61 29 2c 20 6d 69 6e 28 62 29 2c 20 6d 69 6e  (a), min(b), min
1900: 28 63 29 2c 20 6d 69 6e 28 61 2b 62 2b 63 29 20  (c), min(a+b+c) 
1910: 46 52 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b  FROM v2;.  }.} {
1920: 37 20 38 20 39 20 31 30 20 32 37 7d 0a 64 6f 5f  7 8 9 10 27}.do_
1930: 74 65 73 74 20 76 69 65 77 2d 36 2e 32 20 7b 0a  test view-6.2 {.
1940: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1950: 53 45 4c 45 43 54 20 6d 61 78 28 78 29 2c 20 6d  SELECT max(x), m
1960: 61 78 28 61 29 2c 20 6d 61 78 28 62 29 2c 20 6d  ax(a), max(b), m
1970: 61 78 28 63 29 2c 20 6d 61 78 28 61 2b 62 2b 63  ax(c), max(a+b+c
1980: 29 20 46 52 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d  ) FROM v2;.  }.}
1990: 20 7b 31 31 20 31 32 20 31 33 20 31 34 20 33 39   {11 12 13 14 39
19a0: 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }..do_test view-
19b0: 37 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  7.1 {.  execsql 
19c0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42  {.    CREATE TAB
19d0: 4c 45 20 74 65 73 74 31 28 69 64 20 69 6e 74 65  LE test1(id inte
19e0: 67 65 72 20 70 72 69 6d 61 72 79 20 6b 65 79 2c  ger primary key,
19f0: 20 61 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20   a);.    CREATE 
1a00: 54 41 42 4c 45 20 74 65 73 74 32 28 69 64 20 69  TABLE test2(id i
1a10: 6e 74 65 67 65 72 2c 20 62 29 3b 0a 20 20 20 20  nteger, b);.    
1a20: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 65 73 74  INSERT INTO test
1a30: 31 20 56 41 4c 55 45 53 28 31 2c 32 29 3b 0a 20  1 VALUES(1,2);. 
1a40: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
1a50: 65 73 74 32 20 56 41 4c 55 45 53 28 31 2c 33 29  est2 VALUES(1,3)
1a60: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
1a70: 57 20 74 65 73 74 20 41 53 0a 20 20 20 20 20 20  W test AS.      
1a80: 53 45 4c 45 43 54 20 74 65 73 74 31 2e 69 64 2c  SELECT test1.id,
1a90: 20 61 2c 20 62 0a 20 20 20 20 20 20 46 52 4f 4d   a, b.      FROM
1aa0: 20 74 65 73 74 31 20 4a 4f 49 4e 20 74 65 73 74   test1 JOIN test
1ab0: 32 20 4f 4e 20 74 65 73 74 32 2e 69 64 3d 74 65  2 ON test2.id=te
1ac0: 73 74 31 2e 69 64 3b 0a 20 20 20 20 53 45 4c 45  st1.id;.    SELE
1ad0: 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a  CT * FROM test;.
1ae0: 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f    }.} {1 2 3}.do
1af0: 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 32 20 7b  _test view-7.2 {
1b00: 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71  .  db close.  sq
1b10: 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62  lite3 db test.db
1b20: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1b30: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
1b40: 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  est;.  }.} {1 2 
1b50: 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  3}.do_test view-
1b60: 37 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  7.3 {.  execsql 
1b70: 7b 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20  {.    DROP VIEW 
1b80: 74 65 73 74 3b 0a 20 20 20 20 43 52 45 41 54 45  test;.    CREATE
1b90: 20 56 49 45 57 20 74 65 73 74 20 41 53 0a 20 20   VIEW test AS.  
1ba0: 20 20 20 20 53 45 4c 45 43 54 20 74 65 73 74 31      SELECT test1
1bb0: 2e 69 64 2c 20 61 2c 20 62 0a 20 20 20 20 20 20  .id, a, b.      
1bc0: 46 52 4f 4d 20 74 65 73 74 31 20 4a 4f 49 4e 20  FROM test1 JOIN 
1bd0: 74 65 73 74 32 20 55 53 49 4e 47 28 69 64 29 3b  test2 USING(id);
1be0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
1bf0: 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b  OM test;.  }.} {
1c00: 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76  1 2 3}.do_test v
1c10: 69 65 77 2d 37 2e 34 20 7b 0a 20 20 64 62 20 63  iew-7.4 {.  db c
1c20: 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64  lose.  sqlite3 d
1c30: 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63  b test.db.  exec
1c40: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
1c50: 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20   * FROM test;.  
1c60: 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74  }.} {1 2 3}.do_t
1c70: 65 73 74 20 76 69 65 77 2d 37 2e 35 20 7b 0a 20  est view-7.5 {. 
1c80: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 44   execsql {.    D
1c90: 52 4f 50 20 56 49 45 57 20 74 65 73 74 3b 0a 20  ROP VIEW test;. 
1ca0: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 74     CREATE VIEW t
1cb0: 65 73 74 20 41 53 0a 20 20 20 20 20 20 53 45 4c  est AS.      SEL
1cc0: 45 43 54 20 74 65 73 74 31 2e 69 64 2c 20 61 2c  ECT test1.id, a,
1cd0: 20 62 0a 20 20 20 20 20 20 46 52 4f 4d 20 74 65   b.      FROM te
1ce0: 73 74 31 20 4e 41 54 55 52 41 4c 20 4a 4f 49 4e  st1 NATURAL JOIN
1cf0: 20 74 65 73 74 32 3b 0a 20 20 20 20 53 45 4c 45   test2;.    SELE
1d00: 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a  CT * FROM test;.
1d10: 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f    }.} {1 2 3}.do
1d20: 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 36 20 7b  _test view-7.6 {
1d30: 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71  .  db close.  sq
1d40: 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62  lite3 db test.db
1d50: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1d60: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
1d70: 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  est;.  }.} {1 2 
1d80: 33 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  3}..do_test view
1d90: 2d 38 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -8.1 {.  execsql
1da0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
1db0: 45 57 20 76 36 20 41 53 20 53 45 4c 45 43 54 20  EW v6 AS SELECT 
1dc0: 70 71 72 2c 20 78 79 7a 20 46 52 4f 4d 20 76 31  pqr, xyz FROM v1
1dd0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
1de0: 52 4f 4d 20 76 36 20 4f 52 44 45 52 20 42 59 20  ROM v6 ORDER BY 
1df0: 78 79 7a 3b 0a 20 20 7d 0a 7d 20 7b 37 20 32 20  xyz;.  }.} {7 2 
1e00: 31 33 20 35 20 31 39 20 38 20 32 37 20 31 32 7d  13 5 19 8 27 12}
1e10: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e  .do_test view-8.
1e20: 32 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20  2 {.  db close. 
1e30: 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73 74   sqlite3 db test
1e40: 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  .db.  execsql {.
1e50: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1e60: 4d 20 76 36 20 4f 52 44 45 52 20 42 59 20 78 79  M v6 ORDER BY xy
1e70: 7a 3b 0a 20 20 7d 0a 7d 20 7b 37 20 32 20 31 33  z;.  }.} {7 2 13
1e80: 20 35 20 31 39 20 38 20 32 37 20 31 32 7d 0a 64   5 19 8 27 12}.d
1e90: 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e 33 20  o_test view-8.3 
1ea0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1eb0: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 37    CREATE VIEW v7
1ec0: 28 61 29 20 41 53 20 53 45 4c 45 43 54 20 70 71  (a) AS SELECT pq
1ed0: 72 2b 78 79 7a 20 46 52 4f 4d 20 76 36 3b 0a 20  r+xyz FROM v6;. 
1ee0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
1ef0: 20 76 37 20 4f 52 44 45 52 20 42 59 20 61 3b 0a   v7 ORDER BY a;.
1f00: 20 20 7d 0a 7d 20 7b 39 20 31 38 20 32 37 20 33    }.} {9 18 27 3
1f10: 39 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 73 75  9}..ifcapable su
1f20: 62 71 75 65 72 79 20 7b 0a 20 20 64 6f 5f 74 65  bquery {.  do_te
1f30: 73 74 20 76 69 65 77 2d 38 2e 34 20 7b 0a 20 20  st view-8.4 {.  
1f40: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1f50: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 38    CREATE VIEW v8
1f60: 20 41 53 20 53 45 4c 45 43 54 20 6d 61 78 28 63   AS SELECT max(c
1f70: 6e 74 29 20 41 53 20 6d 78 20 46 52 4f 4d 0a 20  nt) AS mx FROM. 
1f80: 20 20 20 20 20 20 20 28 53 45 4c 45 43 54 20 61         (SELECT a
1f90: 25 32 20 41 53 20 65 6f 2c 20 63 6f 75 6e 74 28  %2 AS eo, count(
1fa0: 2a 29 20 41 53 20 63 6e 74 20 46 52 4f 4d 20 74  *) AS cnt FROM t
1fb0: 31 20 47 52 4f 55 50 20 42 59 20 65 6f 29 3b 0a  1 GROUP BY eo);.
1fc0: 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46        SELECT * F
1fd0: 52 4f 4d 20 76 38 3b 0a 20 20 20 20 7d 0a 20 20  ROM v8;.    }.  
1fe0: 7d 20 33 0a 20 20 64 6f 5f 74 65 73 74 20 76 69  } 3.  do_test vi
1ff0: 65 77 2d 38 2e 35 20 7b 0a 20 20 20 20 65 78 65  ew-8.5 {.    exe
2000: 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c  csql {.      SEL
2010: 45 43 54 20 6d 78 2b 31 30 2c 20 6d 78 2a 32 20  ECT mx+10, mx*2 
2020: 46 52 4f 4d 20 76 38 3b 0a 20 20 20 20 7d 0a 20  FROM v8;.    }. 
2030: 20 7d 20 7b 31 33 20 36 7d 0a 20 20 64 6f 5f 74   } {13 6}.  do_t
2040: 65 73 74 20 76 69 65 77 2d 38 2e 36 20 7b 0a 20  est view-8.6 {. 
2050: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
2060: 20 20 20 53 45 4c 45 43 54 20 6d 78 2b 31 30 2c     SELECT mx+10,
2070: 20 70 71 72 20 46 52 4f 4d 20 76 36 2c 20 76 38   pqr FROM v6, v8
2080: 20 57 48 45 52 45 20 78 79 7a 3d 32 3b 0a 20 20   WHERE xyz=2;.  
2090: 20 20 7d 0a 20 20 7d 20 7b 31 33 20 37 7d 0a 20    }.  } {13 7}. 
20a0: 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e   do_test view-8.
20b0: 37 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  7 {.    execsql 
20c0: 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 6d  {.      SELECT m
20d0: 78 2b 31 30 2c 20 70 71 72 20 46 52 4f 4d 20 76  x+10, pqr FROM v
20e0: 36 2c 20 76 38 20 57 48 45 52 45 20 78 79 7a 3e  6, v8 WHERE xyz>
20f0: 32 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 33  2;.    }.  } {13
2100: 20 31 33 20 31 33 20 31 39 20 31 33 20 32 37 7d   13 13 19 13 27}
2110: 0a 7d 20 3b 23 20 69 66 63 61 70 61 62 6c 65 20  .} ;# ifcapable 
2120: 73 75 62 71 75 65 72 79 0a 0a 23 20 54 65 73 74  subquery..# Test
2130: 73 20 66 6f 72 20 61 20 62 75 67 20 66 6f 75 6e  s for a bug foun
2140: 64 20 62 79 20 4d 69 63 68 69 65 6c 20 64 65 20  d by Michiel de 
2150: 57 69 74 20 69 6e 76 6f 6c 76 69 6e 67 20 4f 52  Wit involving OR
2160: 44 45 52 20 42 59 20 69 6e 20 61 20 56 49 45 57  DER BY in a VIEW
2170: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  ..#.do_test view
2180: 2d 39 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -9.1 {.  execsql
2190: 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e   {.    INSERT IN
21a0: 54 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46  TO t2 SELECT * F
21b0: 52 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c 35  ROM t2 WHERE a<5
21c0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
21d0: 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52  O t2 SELECT * FR
21e0: 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c 34 3b  OM t2 WHERE a<4;
21f0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
2200: 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52 4f   t2 SELECT * FRO
2210: 4d 20 74 32 20 57 48 45 52 45 20 61 3c 33 3b 0a  M t2 WHERE a<3;.
2220: 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54 49      SELECT DISTI
2230: 4e 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f  NCT count(*) FRO
2240: 4d 20 74 32 20 47 52 4f 55 50 20 42 59 20 61 20  M t2 GROUP BY a 
2250: 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20 7d 0a  ORDER BY 1;.  }.
2260: 7d 20 7b 31 20 32 20 34 20 38 7d 0a 64 6f 5f 74  } {1 2 4 8}.do_t
2270: 65 73 74 20 76 69 65 77 2d 39 2e 32 20 7b 0a 20  est view-9.2 {. 
2280: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
2290: 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20 63  ELECT DISTINCT c
22a0: 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32 20  ount(*) FROM t2 
22b0: 47 52 4f 55 50 20 42 59 20 61 20 4f 52 44 45 52  GROUP BY a ORDER
22c0: 20 42 59 20 31 20 4c 49 4d 49 54 20 33 3b 0a 20   BY 1 LIMIT 3;. 
22d0: 20 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f 5f   }.} {1 2 4}.do_
22e0: 74 65 73 74 20 76 69 65 77 2d 39 2e 33 20 7b 0a  test view-9.3 {.
22f0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
2300: 43 52 45 41 54 45 20 56 49 45 57 20 76 39 20 41  CREATE VIEW v9 A
2310: 53 20 0a 20 20 20 20 20 20 20 53 45 4c 45 43 54  S .       SELECT
2320: 20 44 49 53 54 49 4e 43 54 20 63 6f 75 6e 74 28   DISTINCT count(
2330: 2a 29 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50  *) FROM t2 GROUP
2340: 20 42 59 20 61 20 4f 52 44 45 52 20 42 59 20 31   BY a ORDER BY 1
2350: 20 4c 49 4d 49 54 20 33 3b 0a 20 20 20 20 53 45   LIMIT 3;.    SE
2360: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 39 3b 0a  LECT * FROM v9;.
2370: 20 20 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f    }.} {1 2 4}.do
2380: 5f 74 65 73 74 20 76 69 65 77 2d 39 2e 34 20 7b  _test view-9.4 {
2390: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
23a0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
23b0: 39 20 4f 52 44 45 52 20 42 59 20 31 20 44 45 53  9 ORDER BY 1 DES
23c0: 43 3b 0a 20 20 7d 0a 7d 20 7b 34 20 32 20 31 7d  C;.  }.} {4 2 1}
23d0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 39 2e  .do_test view-9.
23e0: 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  5 {.  execsql {.
23f0: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
2400: 76 31 30 20 41 53 20 0a 20 20 20 20 20 20 20 53  v10 AS .       S
2410: 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20 61  ELECT DISTINCT a
2420: 2c 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20  , count(*) FROM 
2430: 74 32 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52  t2 GROUP BY a OR
2440: 44 45 52 20 42 59 20 32 20 4c 49 4d 49 54 20 33  DER BY 2 LIMIT 3
2450: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
2460: 52 4f 4d 20 76 31 30 3b 0a 20 20 7d 0a 7d 20 7b  ROM v10;.  }.} {
2470: 35 20 31 20 34 20 32 20 33 20 34 7d 0a 64 6f 5f  5 1 4 2 3 4}.do_
2480: 74 65 73 74 20 76 69 65 77 2d 39 2e 36 20 7b 0a  test view-9.6 {.
2490: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
24a0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
24b0: 30 20 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20  0 ORDER BY 1;.  
24c0: 7d 0a 7d 20 7b 33 20 34 20 34 20 32 20 35 20 31  }.} {3 4 4 2 5 1
24d0: 7d 0a 0a 23 20 54 61 62 6c 65 73 20 77 69 74 68  }..# Tables with
24e0: 20 63 6f 6c 75 6d 6e 73 20 68 61 76 69 6e 67 20   columns having 
24f0: 70 65 63 75 6c 69 61 72 20 71 75 6f 74 65 64 20  peculiar quoted 
2500: 6e 61 6d 65 73 20 75 73 65 64 20 69 6e 20 76 69  names used in vi
2510: 65 77 73 0a 23 20 54 69 63 6b 65 74 20 23 37 35  ews.# Ticket #75
2520: 36 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65  6..#.do_test vie
2530: 77 2d 31 30 2e 31 20 7b 0a 20 20 65 78 65 63 73  w-10.1 {.  execs
2540: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
2550: 54 41 42 4c 45 20 74 33 28 22 39 22 20 69 6e 74  TABLE t3("9" int
2560: 65 67 65 72 2c 20 5b 34 5d 20 74 65 78 74 29 3b  eger, [4] text);
2570: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
2580: 20 74 33 20 56 41 4c 55 45 53 28 31 2c 32 29 3b   t3 VALUES(1,2);
2590: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
25a0: 20 76 5f 74 33 5f 61 20 41 53 20 53 45 4c 45 43   v_t3_a AS SELEC
25b0: 54 20 61 2e 5b 39 5d 20 46 52 4f 4d 20 74 33 20  T a.[9] FROM t3 
25c0: 41 53 20 61 3b 0a 20 20 20 20 43 52 45 41 54 45  AS a;.    CREATE
25d0: 20 56 49 45 57 20 76 5f 74 33 5f 62 20 41 53 20   VIEW v_t3_b AS 
25e0: 53 45 4c 45 43 54 20 22 34 22 20 46 52 4f 4d 20  SELECT "4" FROM 
25f0: 74 33 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  t3;.    SELECT *
2600: 20 46 52 4f 4d 20 76 5f 74 33 5f 61 3b 0a 20 20   FROM v_t3_a;.  
2610: 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20  }.} {1}.do_test 
2620: 76 69 65 77 2d 31 30 2e 32 20 7b 0a 20 20 65 78  view-10.2 {.  ex
2630: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
2640: 43 54 20 2a 20 46 52 4f 4d 20 76 5f 74 33 5f 62  CT * FROM v_t3_b
2650: 3b 0a 20 20 7d 0a 7d 20 7b 32 7d 0a 0a 64 6f 5f  ;.  }.} {2}..do_
2660: 74 65 73 74 20 76 69 65 77 2d 31 31 2e 31 20 7b  test view-11.1 {
2670: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
2680: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 34   CREATE TABLE t4
2690: 28 61 20 43 4f 4c 4c 41 54 45 20 4e 4f 43 41 53  (a COLLATE NOCAS
26a0: 45 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  E);.    INSERT I
26b0: 4e 54 4f 20 74 34 20 56 41 4c 55 45 53 28 27 54  NTO t4 VALUES('T
26c0: 68 69 73 27 29 3b 0a 20 20 20 20 49 4e 53 45 52  his');.    INSER
26d0: 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53  T INTO t4 VALUES
26e0: 28 27 74 68 69 73 27 29 3b 0a 20 20 20 20 49 4e  ('this');.    IN
26f0: 53 45 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c  SERT INTO t4 VAL
2700: 55 45 53 28 27 54 48 49 53 27 29 3b 0a 20 20 20  UES('THIS');.   
2710: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
2720: 34 20 57 48 45 52 45 20 61 20 3d 20 27 54 48 49  4 WHERE a = 'THI
2730: 53 27 3b 0a 20 20 7d 0a 7d 20 7b 54 68 69 73 20  S';.  }.} {This 
2740: 74 68 69 73 20 54 48 49 53 7d 0a 69 66 63 61 70  this THIS}.ifcap
2750: 61 62 6c 65 20 73 75 62 71 75 65 72 79 20 7b 0a  able subquery {.
2760: 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31    do_test view-1
2770: 31 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73 71  1.2 {.    execsq
2780: 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  l {.      SELECT
2790: 20 2a 20 46 52 4f 4d 20 28 53 45 4c 45 43 54 20   * FROM (SELECT 
27a0: 2a 20 46 52 4f 4d 20 74 34 29 20 57 48 45 52 45  * FROM t4) WHERE
27b0: 20 61 20 3d 20 27 54 48 49 53 27 3b 0a 20 20 20   a = 'THIS';.   
27c0: 20 7d 0a 20 20 7d 20 7b 54 68 69 73 20 74 68 69   }.  } {This thi
27d0: 73 20 54 48 49 53 7d 0a 7d 0a 64 6f 5f 74 65 73  s THIS}.}.do_tes
27e0: 74 20 76 69 65 77 2d 31 31 2e 33 20 7b 0a 20 20  t view-11.3 {.  
27f0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
2800: 45 41 54 45 20 56 49 45 57 20 76 31 31 20 41 53  EATE VIEW v11 AS
2810: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
2820: 34 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  4;.    SELECT * 
2830: 46 52 4f 4d 20 76 31 31 20 57 48 45 52 45 20 61  FROM v11 WHERE a
2840: 20 3d 20 27 54 48 49 53 27 3b 0a 20 20 7d 0a 7d   = 'THIS';.  }.}
2850: 20 7b 54 68 69 73 20 74 68 69 73 20 54 48 49 53   {This this THIS
2860: 7d 0a 0a 23 20 54 69 63 6b 65 74 20 23 31 32 37  }..# Ticket #127
2870: 30 3a 20 20 44 6f 20 6e 6f 74 20 61 6c 6c 6f 77  0:  Do not allow
2880: 20 70 61 72 61 6d 65 74 65 72 73 20 69 6e 20 76   parameters in v
2890: 69 65 77 20 64 65 66 69 6e 69 74 69 6f 6e 73 2e  iew definitions.
28a0: 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  .#.do_test view-
28b0: 31 32 2e 31 20 7b 0a 20 20 63 61 74 63 68 73 71  12.1 {.  catchsq
28c0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  l {.    CREATE V
28d0: 49 45 57 20 76 31 32 20 41 53 20 53 45 4c 45 43  IEW v12 AS SELEC
28e0: 54 20 61 20 46 52 4f 4d 20 74 31 20 57 48 45 52  T a FROM t1 WHER
28f0: 45 20 62 3d 3f 0a 20 20 7d 0a 7d 20 7b 31 20 7b  E b=?.  }.} {1 {
2900: 70 61 72 61 6d 65 74 65 72 73 20 61 72 65 20 6e  parameters are n
2910: 6f 74 20 61 6c 6c 6f 77 65 64 20 69 6e 20 76 69  ot allowed in vi
2920: 65 77 73 7d 7d 0a 0a 69 66 63 61 70 61 62 6c 65  ews}}..ifcapable
2930: 20 61 74 74 61 63 68 20 7b 0a 20 20 64 6f 5f 74   attach {.  do_t
2940: 65 73 74 20 76 69 65 77 2d 31 33 2e 31 20 7b 0a  est view-13.1 {.
2950: 20 20 20 20 66 6f 72 63 65 64 65 6c 65 74 65 20      forcedelete 
2960: 74 65 73 74 32 2e 64 62 0a 20 20 20 20 63 61 74  test2.db.    cat
2970: 63 68 73 71 6c 20 7b 0a 20 20 20 20 20 20 41 54  chsql {.      AT
2980: 54 41 43 48 20 27 74 65 73 74 32 2e 64 62 27 20  TACH 'test2.db' 
2990: 41 53 20 74 77 6f 3b 0a 20 20 20 20 20 20 43 52  AS two;.      CR
29a0: 45 41 54 45 20 54 41 42 4c 45 20 74 77 6f 2e 74  EATE TABLE two.t
29b0: 32 28 78 2c 79 29 3b 0a 20 20 20 20 20 20 43 52  2(x,y);.      CR
29c0: 45 41 54 45 20 56 49 45 57 20 76 31 33 20 41 53  EATE VIEW v13 AS
29d0: 20 53 45 4c 45 43 54 20 79 20 46 52 4f 4d 20 74   SELECT y FROM t
29e0: 77 6f 2e 74 32 3b 0a 20 20 20 20 7d 0a 20 20 7d  wo.t2;.    }.  }
29f0: 20 7b 31 20 7b 76 69 65 77 20 76 31 33 20 63 61   {1 {view v13 ca
2a00: 6e 6e 6f 74 20 72 65 66 65 72 65 6e 63 65 20 6f  nnot reference o
2a10: 62 6a 65 63 74 73 20 69 6e 20 64 61 74 61 62 61  bjects in databa
2a20: 73 65 20 74 77 6f 7d 7d 0a 7d 0a 0a 23 20 54 69  se two}}.}..# Ti
2a30: 63 6b 65 74 20 23 31 36 35 38 0a 23 0a 64 6f 5f  cket #1658.#.do_
2a40: 74 65 73 74 20 76 69 65 77 2d 31 34 2e 31 20 7b  test view-14.1 {
2a50: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
2a60: 20 20 43 52 45 41 54 45 20 54 45 4d 50 20 56 49    CREATE TEMP VI
2a70: 45 57 20 74 31 20 41 53 20 53 45 4c 45 43 54 20  EW t1 AS SELECT 
2a80: 61 2c 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20  a,b FROM t1;.   
2a90: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
2aa0: 65 6d 70 2e 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31  emp.t1;.  }.} {1
2ab0: 20 7b 76 69 65 77 20 74 31 20 69 73 20 63 69 72   {view t1 is cir
2ac0: 63 75 6c 61 72 6c 79 20 64 65 66 69 6e 65 64 7d  cularly defined}
2ad0: 7d 0a 0a 23 20 54 69 63 6b 65 74 73 20 23 31 36  }..# Tickets #16
2ae0: 38 38 2c 20 23 31 37 30 39 0a 23 0a 64 6f 5f 74  88, #1709.#.do_t
2af0: 65 73 74 20 76 69 65 77 2d 31 35 2e 31 20 7b 0a  est view-15.1 {.
2b00: 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20    execsql2 {.   
2b10: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 35   CREATE VIEW v15
2b20: 20 41 53 20 53 45 4c 45 43 54 20 61 20 41 53 20   AS SELECT a AS 
2b30: 78 2c 20 62 20 41 53 20 79 20 46 52 4f 4d 20 74  x, b AS y FROM t
2b40: 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  1;.    SELECT * 
2b50: 46 52 4f 4d 20 76 31 35 20 4c 49 4d 49 54 20 31  FROM v15 LIMIT 1
2b60: 3b 0a 20 20 7d 0a 7d 20 7b 78 20 32 20 79 20 33  ;.  }.} {x 2 y 3
2b70: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  }.do_test view-1
2b80: 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 32  5.2 {.  execsql2
2b90: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 78 2c   {.    SELECT x,
2ba0: 20 79 20 46 52 4f 4d 20 76 31 35 20 4c 49 4d 49   y FROM v15 LIMI
2bb0: 54 20 31 0a 20 20 7d 0a 7d 20 7b 78 20 32 20 79  T 1.  }.} {x 2 y
2bc0: 20 33 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65   3}..do_test vie
2bd0: 77 2d 31 36 2e 31 20 7b 0a 20 20 63 61 74 63 68  w-16.1 {.  catch
2be0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
2bf0: 20 56 49 45 57 20 49 46 20 4e 4f 54 20 45 58 49   VIEW IF NOT EXI
2c00: 53 54 53 20 76 31 20 41 53 20 53 45 4c 45 43 54  STS v1 AS SELECT
2c10: 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a   * FROM t1;.  }.
2c20: 7d 20 7b 30 20 7b 7d 7d 0a 64 6f 5f 74 65 73 74  } {0 {}}.do_test
2c30: 20 76 69 65 77 2d 31 36 2e 32 20 7b 0a 20 20 65   view-16.2 {.  e
2c40: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
2c50: 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 73 71 6c  ECT sql FROM sql
2c60: 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45  ite_master WHERE
2c70: 20 6e 61 6d 65 3d 27 76 31 27 0a 20 20 7d 0a 7d   name='v1'.  }.}
2c80: 20 7b 7b 43 52 45 41 54 45 20 56 49 45 57 20 76   {{CREATE VIEW v
2c90: 31 20 41 53 20 53 45 4c 45 43 54 20 61 20 41 53  1 AS SELECT a AS
2ca0: 20 27 78 79 7a 27 2c 20 62 2b 63 20 41 53 20 27   'xyz', b+c AS '
2cb0: 70 71 72 27 2c 20 63 2d 62 20 46 52 4f 4d 20 74  pqr', c-b FROM t
2cc0: 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  1}}.do_test view
2cd0: 2d 31 36 2e 33 20 7b 0a 20 20 63 61 74 63 68 73  -16.3 {.  catchs
2ce0: 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56 49  ql {.    DROP VI
2cf0: 45 57 20 49 46 20 45 58 49 53 54 53 20 6e 6f 73  EW IF EXISTS nos
2d00: 75 63 68 76 69 65 77 0a 20 20 7d 0a 7d 20 7b 30  uchview.  }.} {0
2d10: 20 7b 7d 7d 0a 0a 23 20 63 6f 72 72 65 63 74 20   {}}..# correct 
2d20: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 77 68  error message wh
2d30: 65 6e 20 61 74 74 65 6d 70 74 69 6e 67 20 74 6f  en attempting to
2d40: 20 64 72 6f 70 20 61 20 76 69 65 77 20 74 68 61   drop a view tha
2d50: 74 20 64 6f 65 73 20 6e 6f 74 0a 23 20 65 78 69  t does not.# exi
2d60: 73 74 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69  st..#.do_test vi
2d70: 65 77 2d 31 37 2e 31 20 7b 0a 20 20 63 61 74 63  ew-17.1 {.  catc
2d80: 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  hsql {.    DROP 
2d90: 56 49 45 57 20 6e 6f 73 75 63 68 76 69 65 77 0a  VIEW nosuchview.
2da0: 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75 63    }.} {1 {no suc
2db0: 68 20 76 69 65 77 3a 20 6e 6f 73 75 63 68 76 69  h view: nosuchvi
2dc0: 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  ew}}.do_test vie
2dd0: 77 2d 31 37 2e 32 20 7b 0a 20 20 63 61 74 63 68  w-17.2 {.  catch
2de0: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56  sql {.    DROP V
2df0: 49 45 57 20 6d 61 69 6e 2e 6e 6f 73 75 63 68 76  IEW main.nosuchv
2e00: 69 65 77 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f  iew.  }.} {1 {no
2e10: 20 73 75 63 68 20 76 69 65 77 3a 20 6d 61 69 6e   such view: main
2e20: 2e 6e 6f 73 75 63 68 76 69 65 77 7d 7d 0a 0a 64  .nosuchview}}..d
2e30: 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 38 2e 31  o_test view-18.1
2e40: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
2e50: 20 20 20 44 52 4f 50 20 56 49 45 57 20 74 31 3b     DROP VIEW t1;
2e60: 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20  .    DROP TABLE 
2e70: 74 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  t1;.    CREATE T
2e80: 41 42 4c 45 20 74 31 28 61 2c 20 62 2c 20 63 29  ABLE t1(a, b, c)
2e90: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
2ea0: 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c 20 32  O t1 VALUES(1, 2
2eb0: 2c 20 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  , 3);.    INSERT
2ec0: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
2ed0: 34 2c 20 35 2c 20 36 29 3b 0a 0a 20 20 20 20 43  4, 5, 6);..    C
2ee0: 52 45 41 54 45 20 56 49 45 57 20 76 76 31 20 41  REATE VIEW vv1 A
2ef0: 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  S SELECT * FROM 
2f00: 74 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56  t1;.    CREATE V
2f10: 49 45 57 20 76 76 32 20 41 53 20 53 45 4c 45 43  IEW vv2 AS SELEC
2f20: 54 20 2a 20 46 52 4f 4d 20 76 76 31 3b 0a 20 20  T * FROM vv1;.  
2f30: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 76    CREATE VIEW vv
2f40: 33 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52  3 AS SELECT * FR
2f50: 4f 4d 20 76 76 32 3b 0a 20 20 20 20 43 52 45 41  OM vv2;.    CREA
2f60: 54 45 20 56 49 45 57 20 76 76 34 20 41 53 20 53  TE VIEW vv4 AS S
2f70: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 76 33  ELECT * FROM vv3
2f80: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
2f90: 57 20 76 76 35 20 41 53 20 53 45 4c 45 43 54 20  W vv5 AS SELECT 
2fa0: 2a 20 46 52 4f 4d 20 76 76 34 3b 0a 0a 20 20 20  * FROM vv4;..   
2fb0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
2fc0: 76 35 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  v5;.  }.} {1 2 3
2fd0: 20 34 20 35 20 36 7d 0a 0a 23 20 54 69 63 6b 65   4 5 6}..# Ticke
2fe0: 74 20 23 33 33 30 38 0a 23 20 4d 61 6b 65 20 73  t #3308.# Make s
2ff0: 75 72 65 20 22 72 6f 77 69 64 22 20 63 6f 6c 75  ure "rowid" colu
3000: 6d 6e 73 20 69 6e 20 61 20 76 69 65 77 20 61 72  mns in a view ar
3010: 65 20 6e 61 6d 65 64 20 63 6f 72 72 65 63 74 6c  e named correctl
3020: 79 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65  y..#.do_test vie
3030: 77 2d 31 39 2e 31 20 7b 0a 20 20 65 78 65 63 73  w-19.1 {.  execs
3040: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
3050: 56 49 45 57 20 76 33 33 30 38 61 20 41 53 20 53  VIEW v3308a AS S
3060: 45 4c 45 43 54 20 72 6f 77 69 64 2c 20 2a 20 46  ELECT rowid, * F
3070: 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 65 78  ROM t1;.  }.  ex
3080: 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c  ecsql2 {.    SEL
3090: 45 43 54 20 2a 20 46 52 4f 4d 20 76 33 33 30 38  ECT * FROM v3308
30a0: 61 0a 20 20 7d 0a 7d 20 7b 72 6f 77 69 64 20 31  a.  }.} {rowid 1
30b0: 20 61 20 31 20 62 20 32 20 63 20 33 20 72 6f 77   a 1 b 2 c 3 row
30c0: 69 64 20 32 20 61 20 34 20 62 20 35 20 63 20 36  id 2 a 4 b 5 c 6
30d0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  }.do_test view-1
30e0: 39 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  9.2 {.  execsql 
30f0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
3100: 57 20 76 33 33 30 38 62 20 41 53 20 53 45 4c 45  W v3308b AS SELE
3110: 43 54 20 74 31 2e 72 6f 77 69 64 2c 20 74 31 2e  CT t1.rowid, t1.
3120: 61 2c 20 74 31 2e 62 2b 74 31 2e 63 20 46 52 4f  a, t1.b+t1.c FRO
3130: 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 65 78 65 63  M t1;.  }.  exec
3140: 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45 43  sql2 {.    SELEC
3150: 54 20 2a 20 46 52 4f 4d 20 76 33 33 30 38 62 0a  T * FROM v3308b.
3160: 20 20 7d 0a 7d 20 7b 72 6f 77 69 64 20 31 20 61    }.} {rowid 1 a
3170: 20 31 20 74 31 2e 62 2b 74 31 2e 63 20 35 20 72   1 t1.b+t1.c 5 r
3180: 6f 77 69 64 20 32 20 61 20 34 20 74 31 2e 62 2b  owid 2 a 4 t1.b+
3190: 74 31 2e 63 20 31 31 7d 0a 64 6f 5f 74 65 73 74  t1.c 11}.do_test
31a0: 20 76 69 65 77 2d 31 39 2e 33 20 7b 0a 20 20 65   view-19.3 {.  e
31b0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
31c0: 41 54 45 20 56 49 45 57 20 76 33 33 30 38 63 20  ATE VIEW v3308c 
31d0: 41 53 20 53 45 4c 45 43 54 20 74 31 2e 6f 69 64  AS SELECT t1.oid
31e0: 2c 20 41 2c 20 74 31 2e 62 2b 74 31 2e 63 20 41  , A, t1.b+t1.c A
31f0: 53 20 78 20 46 52 4f 4d 20 74 31 3b 0a 20 20 7d  S x FROM t1;.  }
3200: 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20  .  execsql2 {.  
3210: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
3220: 76 33 33 30 38 63 0a 20 20 7d 0a 7d 20 7b 72 6f  v3308c.  }.} {ro
3230: 77 69 64 20 31 20 61 20 31 20 78 20 35 20 72 6f  wid 1 a 1 x 5 ro
3240: 77 69 64 20 32 20 61 20 34 20 78 20 31 31 7d 0a  wid 2 a 4 x 11}.
3250: 0a 23 20 54 69 63 6b 65 74 20 23 33 35 33 39 20  .# Ticket #3539 
3260: 68 61 64 20 74 68 69 73 20 63 72 61 73 68 69 6e  had this crashin
3270: 67 20 28 73 65 65 20 63 6f 6d 6d 69 74 20 5b 35  g (see commit [5
3280: 39 34 30 5d 29 2e 0a 64 6f 5f 74 65 73 74 20 76  940])..do_test v
3290: 69 65 77 2d 32 30 2e 31 20 7b 0a 20 20 65 78 65  iew-20.1 {.  exe
32a0: 63 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  csql {.    DROP 
32b0: 54 41 42 4c 45 20 49 46 20 45 58 49 53 54 53 20  TABLE IF EXISTS 
32c0: 74 31 3b 0a 20 20 20 20 44 52 4f 50 20 56 49 45  t1;.    DROP VIE
32d0: 57 20 49 46 20 45 58 49 53 54 53 20 76 31 3b 0a  W IF EXISTS v1;.
32e0: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
32f0: 20 74 31 28 63 31 29 3b 0a 20 20 20 20 43 52 45   t1(c1);.    CRE
3300: 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20 53  ATE VIEW v1 AS S
3310: 45 4c 45 43 54 20 63 31 20 46 52 4f 4d 20 28 53  ELECT c1 FROM (S
3320: 45 4c 45 43 54 20 74 31 2e 63 31 20 46 52 4f 4d  ELECT t1.c1 FROM
3330: 20 74 31 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 0a   t1);.  }.} {}..
3340: 23 20 54 69 63 6b 65 74 20 5b 64 35 38 63 63 62  # Ticket [d58ccb
3350: 62 33 66 31 62 5d 3a 20 50 72 65 76 65 6e 74 20  b3f1b]: Prevent 
3360: 54 61 62 6c 65 2e 6e 52 65 66 20 6f 76 65 72 66  Table.nRef overf
3370: 6c 6f 77 2e 0a 64 62 20 63 6c 6f 73 65 0a 73 71  low..db close.sq
3380: 6c 69 74 65 33 20 64 62 20 3a 6d 65 6d 6f 72 79  lite3 db :memory
3390: 3a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32  :.do_test view-2
33a0: 31 2e 31 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  1.1 {.  catchsql
33b0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
33c0: 42 4c 45 20 74 31 28 78 29 3b 0a 20 20 20 20 49  BLE t1(x);.    I
33d0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
33e0: 4c 55 45 53 28 35 29 3b 0a 20 20 20 20 43 52 45  LUES(5);.    CRE
33f0: 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20 53  ATE VIEW v1 AS S
3400: 45 4c 45 43 54 20 78 2a 32 20 46 52 4f 4d 20 74  ELECT x*2 FROM t
3410: 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49  1;.    CREATE VI
3420: 45 57 20 76 32 20 41 53 20 53 45 4c 45 43 54 20  EW v2 AS SELECT 
3430: 2a 20 46 52 4f 4d 20 76 31 20 55 4e 49 4f 4e 20  * FROM v1 UNION 
3440: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
3450: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
3460: 57 20 76 34 20 41 53 20 53 45 4c 45 43 54 20 2a  W v4 AS SELECT *
3470: 20 46 52 4f 4d 20 76 32 20 55 4e 49 4f 4e 20 53   FROM v2 UNION S
3480: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 3b  ELECT * FROM v2;
3490: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
34a0: 20 76 38 20 41 53 20 53 45 4c 45 43 54 20 2a 20   v8 AS SELECT * 
34b0: 46 52 4f 4d 20 76 34 20 55 4e 49 4f 4e 20 53 45  FROM v4 UNION SE
34c0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 34 3b 0a  LECT * FROM v4;.
34d0: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
34e0: 76 31 36 20 41 53 20 53 45 4c 45 43 54 20 2a 20  v16 AS SELECT * 
34f0: 46 52 4f 4d 20 76 38 20 55 4e 49 4f 4e 20 53 45  FROM v8 UNION SE
3500: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 38 3b 0a  LECT * FROM v8;.
3510: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
3520: 76 33 32 20 41 53 20 53 45 4c 45 43 54 20 2a 20  v32 AS SELECT * 
3530: 46 52 4f 4d 20 76 31 36 20 55 4e 49 4f 4e 20 53  FROM v16 UNION S
3540: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 36  ELECT * FROM v16
3550: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  ;.    CREATE VIE
3560: 57 20 76 36 34 20 41 53 20 53 45 4c 45 43 54 20  W v64 AS SELECT 
3570: 2a 20 46 52 4f 4d 20 76 33 32 20 55 4e 49 4f 4e  * FROM v32 UNION
3580: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
3590: 33 32 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56  32;.    CREATE V
35a0: 49 45 57 20 76 31 32 38 20 41 53 20 53 45 4c 45  IEW v128 AS SELE
35b0: 43 54 20 2a 20 46 52 4f 4d 20 76 36 34 20 55 4e  CT * FROM v64 UN
35c0: 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  ION SELECT * FRO
35d0: 4d 20 76 36 34 3b 0a 20 20 20 20 43 52 45 41 54  M v64;.    CREAT
35e0: 45 20 56 49 45 57 20 76 32 35 36 20 41 53 20 53  E VIEW v256 AS S
35f0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 32  ELECT * FROM v12
3600: 38 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a  8 UNION SELECT *
3610: 20 46 52 4f 4d 20 76 31 32 38 3b 0a 20 20 20 20   FROM v128;.    
3620: 43 52 45 41 54 45 20 56 49 45 57 20 76 35 31 32  CREATE VIEW v512
3630: 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f   AS SELECT * FRO
3640: 4d 20 76 32 35 36 20 55 4e 49 4f 4e 20 53 45 4c  M v256 UNION SEL
3650: 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 35 36 3b  ECT * FROM v256;
3660: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
3670: 20 76 31 30 32 34 20 41 53 20 53 45 4c 45 43 54   v1024 AS SELECT
3680: 20 2a 20 46 52 4f 4d 20 76 35 31 32 20 55 4e 49   * FROM v512 UNI
3690: 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  ON SELECT * FROM
36a0: 20 76 35 31 32 3b 0a 20 20 20 20 43 52 45 41 54   v512;.    CREAT
36b0: 45 20 56 49 45 57 20 76 32 30 34 38 20 41 53 20  E VIEW v2048 AS 
36c0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
36d0: 30 32 34 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54  024 UNION SELECT
36e0: 20 2a 20 46 52 4f 4d 20 76 31 30 32 34 3b 0a 20   * FROM v1024;. 
36f0: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
3700: 34 30 39 36 20 41 53 20 53 45 4c 45 43 54 20 2a  4096 AS SELECT *
3710: 20 46 52 4f 4d 20 76 32 30 34 38 20 55 4e 49 4f   FROM v2048 UNIO
3720: 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  N SELECT * FROM 
3730: 76 32 30 34 38 3b 0a 20 20 20 20 43 52 45 41 54  v2048;.    CREAT
3740: 45 20 56 49 45 57 20 76 38 31 39 32 20 41 53 20  E VIEW v8192 AS 
3750: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 34  SELECT * FROM v4
3760: 30 39 36 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54  096 UNION SELECT
3770: 20 2a 20 46 52 4f 4d 20 76 34 30 39 36 3b 0a 20   * FROM v4096;. 
3780: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
3790: 31 36 33 38 34 20 41 53 20 53 45 4c 45 43 54 20  16384 AS SELECT 
37a0: 2a 20 46 52 4f 4d 20 76 38 31 39 32 20 55 4e 49  * FROM v8192 UNI
37b0: 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  ON SELECT * FROM
37c0: 20 76 38 31 39 32 3b 0a 20 20 20 20 43 52 45 41   v8192;.    CREA
37d0: 54 45 20 56 49 45 57 20 76 33 32 37 36 38 20 41  TE VIEW v32768 A
37e0: 53 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  S SELECT * FROM 
37f0: 76 31 36 33 38 34 20 55 4e 49 4f 4e 20 53 45 4c  v16384 UNION SEL
3800: 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 36 33 38  ECT * FROM v1638
3810: 34 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  4;.    SELECT * 
3820: 46 52 4f 4d 20 76 33 32 37 36 38 20 55 4e 49 4f  FROM v32768 UNIO
3830: 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  N SELECT * FROM 
3840: 76 33 32 37 36 38 3b 0a 20 20 7d 0a 7d 20 7b 31  v32768;.  }.} {1
3850: 20 7b 74 6f 6f 20 6d 61 6e 79 20 72 65 66 65 72   {too many refer
3860: 65 6e 63 65 73 20 74 6f 20 22 76 31 22 3a 20 6d  ences to "v1": m
3870: 61 78 20 36 35 35 33 35 7d 7d 0a 69 66 63 61 70  ax 65535}}.ifcap
3880: 61 62 6c 65 20 70 72 6f 67 72 65 73 73 20 7b 0a  able progress {.
3890: 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32    do_test view-2
38a0: 31 2e 32 20 7b 0a 20 20 20 20 64 62 20 70 72 6f  1.2 {.    db pro
38b0: 67 72 65 73 73 20 31 30 30 30 20 7b 65 78 70 72  gress 1000 {expr
38c0: 20 31 7d 0a 20 20 20 20 63 61 74 63 68 73 71 6c   1}.    catchsql
38d0: 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20   {.      SELECT 
38e0: 2a 20 46 52 4f 4d 20 76 33 32 37 36 38 3b 0a 20  * FROM v32768;. 
38f0: 20 20 20 7d 0a 20 20 7d 20 7b 31 20 69 6e 74 65     }.  } {1 inte
3900: 72 72 75 70 74 65 64 7d 0a 7d 0a 0a 64 62 20 63  rrupted}.}..db c
3910: 6c 6f 73 65 0a 73 71 6c 69 74 65 33 20 64 62 20  lose.sqlite3 db 
3920: 3a 6d 65 6d 6f 72 79 3a 0a 64 6f 5f 65 78 65 63  :memory:.do_exec
3930: 73 71 6c 5f 74 65 73 74 20 76 69 65 77 2d 32 32  sql_test view-22
3940: 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20 56 49  .1 {.  CREATE VI
3950: 45 57 20 78 31 20 41 53 20 53 45 4c 45 43 54 20  EW x1 AS SELECT 
3960: 31 32 33 20 41 53 20 27 27 2c 20 32 33 34 20 41  123 AS '', 234 A
3970: 53 20 27 27 2c 20 33 34 35 20 41 53 20 27 27 3b  S '', 345 AS '';
3980: 0a 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  .  SELECT * FROM
3990: 20 78 31 3b 0a 7d 20 7b 31 32 33 20 32 33 34 20   x1;.} {123 234 
39a0: 33 34 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  345}.do_test vie
39b0: 77 2d 32 32 2e 32 20 7b 0a 20 20 75 6e 73 65 74  w-22.2 {.  unset
39c0: 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20 78 0a 20   -nocomplain x. 
39d0: 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43 54   db eval {SELECT
39e0: 20 2a 20 46 52 4f 4d 20 78 31 7d 20 78 20 62 72   * FROM x1} x br
39f0: 65 61 6b 0a 20 20 6c 73 6f 72 74 20 5b 61 72 72  eak.  lsort [arr
3a00: 61 79 20 6e 61 6d 65 73 20 78 5d 0a 7d 20 7b 7b  ay names x].} {{
3a10: 7d 20 2a 20 3a 31 20 3a 32 7d 0a 0a 0a 66 69 6e  } * :1 :2}...fin
3a20: 69 73 68 5f 74 65 73 74 0a                       ish_test.