/ Hex Artifact Content
Login

Artifact 306cc4342eb03c28de1a92c681836189e03e5af9:


0000: 23 20 32 30 30 32 20 46 65 62 72 75 61 72 79 20  # 2002 February 
0010: 32 36 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  26.#.# The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61  lace of.# a lega
0060: 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69  l notice, here i
0070: 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a  s a blessing:.#.
0080: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20  #    May you do 
0090: 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69  good and not evi
00a0: 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  l..#    May you 
00b0: 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73  find forgiveness
00c0: 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e   for yourself an
00d0: 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73  d forgive others
00e0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73  ..#    May you s
00f0: 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76  hare freely, nev
0100: 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74  er taking more t
0110: 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a  han you give..#.
0120: 23 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  #***************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73 20  ********.# This 
0170: 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20  file implements 
0180: 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73  regression tests
0190: 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62 72   for SQLite libr
01a0: 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f 63 75  ary.  The.# focu
01b0: 73 20 6f 66 20 74 68 69 73 20 66 69 6c 65 20 69  s of this file i
01c0: 73 20 74 65 73 74 69 6e 67 20 56 49 45 57 20 73  s testing VIEW s
01d0: 74 61 74 65 6d 65 6e 74 73 2e 0a 23 0a 23 20 24  tatements..#.# $
01e0: 49 64 3a 20 76 69 65 77 2e 74 65 73 74 2c 76 20  Id: view.test,v 
01f0: 31 2e 32 34 20 32 30 30 35 2f 30 31 2f 33 30 20  1.24 2005/01/30 
0200: 31 31 3a 31 31 3a 34 34 20 64 61 6e 69 65 6c 6b  11:11:44 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 76 31    CREATE VIEW v1
03e0: 20 41 53 20 53 45 4c 45 43 54 20 61 2c 62 20 46   AS SELECT a,b F
03f0: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  ROM t1;.    SELE
0400: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
0410: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
0420: 31 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f  1 2 4 5 7 8}.do_
0430: 74 65 73 74 20 76 69 65 77 2d 31 2e 32 20 7b 0a  test view-1.2 {.
0440: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
0450: 20 52 4f 4c 4c 42 41 43 4b 3b 0a 20 20 20 20 53   ROLLBACK;.    S
0460: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20  ELECT * FROM v1 
0470: 4f 52 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a  ORDER BY a;.  }.
0480: 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61  } {1 {no such ta
0490: 62 6c 65 3a 20 76 31 7d 7d 0a 64 6f 5f 74 65 73  ble: v1}}.do_tes
04a0: 74 20 76 69 65 77 2d 31 2e 33 20 7b 0a 20 20 65  t view-1.3 {.  e
04b0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
04c0: 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20 53  ATE VIEW v1 AS S
04d0: 45 4c 45 43 54 20 61 2c 62 20 46 52 4f 4d 20 74  ELECT a,b FROM t
04e0: 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  1;.    SELECT * 
04f0: 46 52 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59  FROM v1 ORDER BY
0500: 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34   a;.  }.} {1 2 4
0510: 20 35 20 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20   5 7 8}.do_test 
0520: 76 69 65 77 2d 31 2e 33 2e 31 20 7b 0a 20 20 64  view-1.3.1 {.  d
0530: 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65  b close.  sqlite
0540: 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65  3 db test.db.  e
0550: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
0560: 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52  ECT * FROM v1 OR
0570: 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20  DER BY a;.  }.} 
0580: 7b 31 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f  {1 2 4 5 7 8}.do
0590: 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 34 20 7b  _test view-1.4 {
05a0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
05b0: 20 20 44 52 4f 50 20 56 49 45 57 20 76 31 3b 0a    DROP VIEW v1;.
05c0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
05d0: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
05e0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75  .  }.} {1 {no su
05f0: 63 68 20 74 61 62 6c 65 3a 20 76 31 7d 7d 0a 64  ch table: v1}}.d
0600: 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 2e 35 20  o_test view-1.5 
0610: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
0620: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31    CREATE VIEW v1
0630: 20 41 53 20 53 45 4c 45 43 54 20 61 2c 62 20 46   AS SELECT a,b F
0640: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45  ROM t1;.    SELE
0650: 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44  CT * FROM v1 ORD
0660: 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b  ER BY a;.  }.} {
0670: 31 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f  1 2 4 5 7 8}.do_
0680: 74 65 73 74 20 76 69 65 77 2d 31 2e 36 20 7b 0a  test view-1.6 {.
0690: 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20    catchsql {.   
06a0: 20 44 52 4f 50 20 54 41 42 4c 45 20 74 31 3b 0a   DROP TABLE t1;.
06b0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
06c0: 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b  M v1 ORDER BY a;
06d0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75  .  }.} {1 {no su
06e0: 63 68 20 74 61 62 6c 65 3a 20 6d 61 69 6e 2e 74  ch table: main.t
06f0: 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  1}}.do_test view
0700: 2d 31 2e 37 20 7b 0a 20 20 65 78 65 63 73 71 6c  -1.7 {.  execsql
0710: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
0720: 42 4c 45 20 74 31 28 78 2c 61 2c 62 2c 63 29 3b  BLE t1(x,a,b,c);
0730: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0740: 20 74 31 20 56 41 4c 55 45 53 28 31 2c 32 2c 33   t1 VALUES(1,2,3
0750: 2c 34 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  ,4);.    INSERT 
0760: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 34  INTO t1 VALUES(4
0770: 2c 35 2c 36 2c 37 29 3b 0a 20 20 20 20 49 4e 53  ,5,6,7);.    INS
0780: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
0790: 45 53 28 37 2c 38 2c 39 2c 31 30 29 3b 0a 20 20  ES(7,8,9,10);.  
07a0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
07b0: 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20  v1 ORDER BY a;. 
07c0: 20 7d 0a 7d 20 7b 32 20 33 20 35 20 36 20 38 20   }.} {2 3 5 6 8 
07d0: 39 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  9}.do_test view-
07e0: 31 2e 38 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65  1.8 {.  db close
07f0: 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65  .  sqlite3 db te
0800: 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20  st.db.  execsql 
0810: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
0820: 52 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20  ROM v1 ORDER BY 
0830: 61 3b 0a 20 20 7d 0a 7d 20 7b 32 20 33 20 35 20  a;.  }.} {2 3 5 
0840: 36 20 38 20 39 7d 0a 0a 64 6f 5f 74 65 73 74 20  6 8 9}..do_test 
0850: 76 69 65 77 2d 32 2e 31 20 7b 0a 20 20 65 78 65  view-2.1 {.  exe
0860: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
0870: 45 20 56 49 45 57 20 76 32 20 41 53 20 53 45 4c  E VIEW v2 AS SEL
0880: 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 57 48  ECT * FROM t1 WH
0890: 45 52 45 20 61 3e 35 0a 20 20 7d 3b 20 20 23 20  ERE a>5.  };  # 
08a0: 4e 6f 20 73 65 6d 69 63 6f 6c 6f 6e 0a 20 20 65  No semicolon.  e
08b0: 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20 53 45  xecsql2 {.    SE
08c0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 32 3b 0a  LECT * FROM v2;.
08d0: 20 20 7d 0a 7d 20 7b 78 20 37 20 61 20 38 20 62    }.} {x 7 a 8 b
08e0: 20 39 20 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74   9 c 10}.do_test
08f0: 20 76 69 65 77 2d 32 2e 32 20 7b 0a 20 20 63 61   view-2.2 {.  ca
0900: 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  tchsql {.    INS
0910: 45 52 54 20 49 4e 54 4f 20 76 32 20 56 41 4c 55  ERT INTO v2 VALU
0920: 45 53 28 31 2c 32 2c 33 2c 34 29 3b 0a 20 20 7d  ES(1,2,3,4);.  }
0930: 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 6d 6f  .} {1 {cannot mo
0940: 64 69 66 79 20 76 32 20 62 65 63 61 75 73 65 20  dify v2 because 
0950: 69 74 20 69 73 20 61 20 76 69 65 77 7d 7d 0a 64  it is a view}}.d
0960: 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 33 20  o_test view-2.3 
0970: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
0980: 20 20 20 55 50 44 41 54 45 20 76 32 20 53 45 54     UPDATE v2 SET
0990: 20 61 3d 31 30 20 57 48 45 52 45 20 61 3d 35 3b   a=10 WHERE a=5;
09a0: 0a 20 20 7d 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f  .  }.} {1 {canno
09b0: 74 20 6d 6f 64 69 66 79 20 76 32 20 62 65 63 61  t modify v2 beca
09c0: 75 73 65 20 69 74 20 69 73 20 61 20 76 69 65 77  use it is a view
09d0: 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }}.do_test view-
09e0: 32 2e 34 20 7b 0a 20 20 63 61 74 63 68 73 71 6c  2.4 {.  catchsql
09f0: 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52   {.    DELETE FR
0a00: 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20  OM v2;.  }.} {1 
0a10: 7b 63 61 6e 6e 6f 74 20 6d 6f 64 69 66 79 20 76  {cannot modify v
0a20: 32 20 62 65 63 61 75 73 65 20 69 74 20 69 73 20  2 because it is 
0a30: 61 20 76 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74  a view}}.do_test
0a40: 20 76 69 65 77 2d 32 2e 35 20 7b 0a 20 20 65 78   view-2.5 {.  ex
0a50: 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45  ecsql {.    INSE
0a60: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
0a70: 53 28 31 31 2c 31 32 2c 31 33 2c 31 34 29 3b 0a  S(11,12,13,14);.
0a80: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
0a90: 4d 20 76 32 20 4f 52 44 45 52 20 42 59 20 78 3b  M v2 ORDER BY x;
0aa0: 0a 20 20 7d 0a 7d 20 7b 37 20 38 20 39 20 31 30  .  }.} {7 8 9 10
0ab0: 20 31 31 20 31 32 20 31 33 20 31 34 7d 0a 64 6f   11 12 13 14}.do
0ac0: 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 36 20 7b  _test view-2.6 {
0ad0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0ae0: 20 53 45 4c 45 43 54 20 78 20 46 52 4f 4d 20 76   SELECT x FROM v
0af0: 32 20 57 48 45 52 45 20 61 3e 31 30 0a 20 20 7d  2 WHERE a>10.  }
0b00: 0a 7d 20 7b 31 31 7d 0a 0a 23 20 54 65 73 74 20  .} {11}..# Test 
0b10: 74 68 61 74 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65  that column name
0b20: 20 6f 66 20 76 69 65 77 73 20 61 72 65 20 67 65   of views are ge
0b30: 6e 65 72 61 74 65 64 20 63 6f 72 72 65 63 74 6c  nerated correctl
0b40: 79 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65  y..#.do_test vie
0b50: 77 2d 33 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  w-3.1 {.  execsq
0b60: 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  l2 {.    SELECT 
0b70: 2a 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54 20  * FROM v1 LIMIT 
0b80: 31 0a 20 20 7d 0a 7d 20 7b 61 20 32 20 62 20 33  1.  }.} {a 2 b 3
0b90: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33  }.do_test view-3
0ba0: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20  .2 {.  execsql2 
0bb0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
0bc0: 52 4f 4d 20 76 32 20 4c 49 4d 49 54 20 31 0a 20  ROM v2 LIMIT 1. 
0bd0: 20 7d 0a 7d 20 7b 78 20 37 20 61 20 38 20 62 20   }.} {x 7 a 8 b 
0be0: 39 20 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74 20  9 c 10}.do_test 
0bf0: 76 69 65 77 2d 33 2e 33 20 7b 0a 20 20 65 78 65  view-3.3 {.  exe
0c00: 63 73 71 6c 32 20 7b 0a 20 20 20 20 44 52 4f 50  csql2 {.    DROP
0c10: 20 56 49 45 57 20 76 31 3b 0a 20 20 20 20 43 52   VIEW v1;.    CR
0c20: 45 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20  EATE VIEW v1 AS 
0c30: 53 45 4c 45 43 54 20 61 20 41 53 20 27 78 79 7a  SELECT a AS 'xyz
0c40: 27 2c 20 62 2b 63 20 41 53 20 27 70 71 72 27 2c  ', b+c AS 'pqr',
0c50: 20 63 2d 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20   c-b FROM t1;.  
0c60: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0c70: 76 31 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a 7d  v1 LIMIT 1.  }.}
0c80: 20 7b 78 79 7a 20 32 20 70 71 72 20 37 20 63 2d   {xyz 2 pqr 7 c-
0c90: 62 20 31 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20  b 1}..ifcapable 
0ca0: 63 6f 6d 70 6f 75 6e 64 20 7b 0a 64 6f 5f 74 65  compound {.do_te
0cb0: 73 74 20 20 76 69 65 77 2d 33 2e 34 20 7b 0a 20  st  view-3.4 {. 
0cc0: 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20   execsql2 {.    
0cd0: 43 52 45 41 54 45 20 56 49 45 57 20 76 33 20 41  CREATE VIEW v3 A
0ce0: 53 20 53 45 4c 45 43 54 20 61 20 46 52 4f 4d 20  S SELECT a FROM 
0cf0: 74 31 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20  t1 UNION SELECT 
0d00: 62 20 46 52 4f 4d 20 74 31 20 4f 52 44 45 52 20  b FROM t1 ORDER 
0d10: 42 59 20 62 3b 0a 20 20 20 20 53 45 4c 45 43 54  BY b;.    SELECT
0d20: 20 2a 20 46 52 4f 4d 20 76 33 20 4c 49 4d 49 54   * FROM v3 LIMIT
0d30: 20 34 3b 0a 20 20 7d 0a 7d 20 7b 62 20 32 20 62   4;.  }.} {b 2 b
0d40: 20 33 20 62 20 35 20 62 20 36 7d 0a 64 6f 5f 74   3 b 5 b 6}.do_t
0d50: 65 73 74 20 76 69 65 77 2d 33 2e 35 20 7b 0a 20  est view-3.5 {. 
0d60: 20 65 78 65 63 73 71 6c 32 20 7b 0a 20 20 20 20   execsql2 {.    
0d70: 43 52 45 41 54 45 20 56 49 45 57 20 76 34 20 41  CREATE VIEW v4 A
0d80: 53 20 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  S .      SELECT 
0d90: 61 2c 20 62 20 46 52 4f 4d 20 74 31 20 0a 20 20  a, b FROM t1 .  
0da0: 20 20 20 20 55 4e 49 4f 4e 0a 20 20 20 20 20 20      UNION.      
0db0: 53 45 4c 45 43 54 20 62 20 41 53 20 27 78 27 2c  SELECT b AS 'x',
0dc0: 20 61 20 41 53 20 27 79 27 20 46 52 4f 4d 20 74   a AS 'y' FROM t
0dd0: 31 0a 20 20 20 20 20 20 4f 52 44 45 52 20 42 59  1.      ORDER BY
0de0: 20 78 2c 20 79 3b 0a 20 20 20 20 53 45 4c 45 43   x, y;.    SELEC
0df0: 54 20 79 20 46 52 4f 4d 20 76 34 20 4f 52 44 45  T y FROM v4 ORDE
0e00: 52 20 42 59 20 79 20 4c 49 4d 49 54 20 34 3b 0a  R BY y LIMIT 4;.
0e10: 20 20 7d 0a 7d 20 7b 79 20 32 20 79 20 33 20 79    }.} {y 2 y 3 y
0e20: 20 35 20 79 20 36 7d 0a 7d 20 3b 23 20 69 66 63   5 y 6}.} ;# ifc
0e30: 61 70 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64 0a  apable compound.
0e40: 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34  ..do_test view-4
0e50: 2e 31 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  .1 {.  catchsql 
0e60: 7b 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20  {.    DROP VIEW 
0e70: 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73  t1;.  }.} {1 {us
0e80: 65 20 44 52 4f 50 20 54 41 42 4c 45 20 74 6f 20  e DROP TABLE to 
0e90: 64 65 6c 65 74 65 20 74 61 62 6c 65 20 74 31 7d  delete table t1}
0ea0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34  }.do_test view-4
0eb0: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
0ec0: 0a 20 20 20 20 53 45 4c 45 43 54 20 31 20 46 52  .    SELECT 1 FR
0ed0: 4f 4d 20 74 31 20 4c 49 4d 49 54 20 31 3b 0a 20  OM t1 LIMIT 1;. 
0ee0: 20 7d 0a 7d 20 31 0a 64 6f 5f 74 65 73 74 20 76   }.} 1.do_test v
0ef0: 69 65 77 2d 34 2e 33 20 7b 0a 20 20 63 61 74 63  iew-4.3 {.  catc
0f00: 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  hsql {.    DROP 
0f10: 54 41 42 4c 45 20 76 31 3b 0a 20 20 7d 0a 7d 20  TABLE v1;.  }.} 
0f20: 7b 31 20 7b 75 73 65 20 44 52 4f 50 20 56 49 45  {1 {use DROP VIE
0f30: 57 20 74 6f 20 64 65 6c 65 74 65 20 76 69 65 77  W to delete view
0f40: 20 76 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69   v1}}.do_test vi
0f50: 65 77 2d 34 2e 34 20 7b 0a 20 20 65 78 65 63 73  ew-4.4 {.  execs
0f60: 71 6c 20 7b 0a 20 20 20 20 20 53 45 4c 45 43 54  ql {.     SELECT
0f70: 20 31 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54   1 FROM v1 LIMIT
0f80: 20 31 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f   1;.  }.} {1}.do
0f90: 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 35 20 7b  _test view-4.5 {
0fa0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
0fb0: 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 69    CREATE INDEX i
0fc0: 31 76 31 20 4f 4e 20 76 31 28 78 79 7a 29 3b 0a  1v1 ON v1(xyz);.
0fd0: 20 20 7d 0a 7d 20 7b 31 20 7b 76 69 65 77 73 20    }.} {1 {views 
0fe0: 6d 61 79 20 6e 6f 74 20 62 65 20 69 6e 64 65 78  may not be index
0ff0: 65 64 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69  ed}}..do_test vi
1000: 65 77 2d 35 2e 31 20 7b 0a 20 20 65 78 65 63 73  ew-5.1 {.  execs
1010: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
1020: 54 41 42 4c 45 20 74 32 28 79 2c 61 29 3b 0a 20  TABLE t2(y,a);. 
1030: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
1040: 32 20 56 41 4c 55 45 53 28 32 32 2c 32 29 3b 0a  2 VALUES(22,2);.
1050: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
1060: 74 32 20 56 41 4c 55 45 53 28 33 33 2c 33 29 3b  t2 VALUES(33,3);
1070: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
1080: 20 74 32 20 56 41 4c 55 45 53 28 34 34 2c 34 29   t2 VALUES(44,4)
1090: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
10a0: 4f 20 74 32 20 56 41 4c 55 45 53 28 35 35 2c 35  O t2 VALUES(55,5
10b0: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  );.    SELECT * 
10c0: 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b  FROM t2;.  }.} {
10d0: 32 32 20 32 20 33 33 20 33 20 34 34 20 34 20 35  22 2 33 3 44 4 5
10e0: 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  5 5}.do_test vie
10f0: 77 2d 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  w-5.2 {.  execsq
1100: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  l {.    CREATE V
1110: 49 45 57 20 76 35 20 41 53 0a 20 20 20 20 20 20  IEW v5 AS.      
1120: 53 45 4c 45 43 54 20 74 31 2e 78 20 41 53 20 76  SELECT t1.x AS v
1130: 2c 20 74 32 2e 79 20 41 53 20 77 20 46 52 4f 4d  , t2.y AS w FROM
1140: 20 74 31 20 4a 4f 49 4e 20 74 32 20 55 53 49 4e   t1 JOIN t2 USIN
1150: 47 28 61 29 3b 0a 20 20 20 20 53 45 4c 45 43 54  G(a);.    SELECT
1160: 20 2a 20 46 52 4f 4d 20 76 35 3b 0a 20 20 7d 0a   * FROM v5;.  }.
1170: 7d 20 7b 31 20 32 32 20 34 20 35 35 7d 0a 0a 23  } {1 22 4 55}..#
1180: 20 56 65 72 69 66 79 20 74 68 61 74 20 74 68 65   Verify that the
1190: 20 76 69 65 77 20 76 35 20 67 65 74 73 20 66 6c   view v5 gets fl
11a0: 61 74 74 65 6e 65 64 2e 20 20 73 65 65 20 73 71  attened.  see sq
11b0: 6c 69 74 65 46 6c 61 74 74 65 6e 53 75 62 71 75  liteFlattenSubqu
11c0: 65 72 79 28 29 2e 0a 23 20 54 68 69 73 20 77 69  ery()..# This wi
11d0: 6c 6c 20 6f 6e 6c 79 20 77 6f 72 6b 20 69 66 20  ll only work if 
11e0: 45 58 50 4c 41 49 4e 20 69 73 20 65 6e 61 62 6c  EXPLAIN is enabl
11f0: 65 64 2e 0a 23 20 54 69 63 6b 65 74 20 23 32 37  ed..# Ticket #27
1200: 32 0a 23 0a 69 66 63 61 70 61 62 6c 65 20 7b 65  2.#.ifcapable {e
1210: 78 70 6c 61 69 6e 7d 20 7b 0a 64 6f 5f 74 65 73  xplain} {.do_tes
1220: 74 20 76 69 65 77 2d 35 2e 33 20 7b 0a 20 20 6c  t view-5.3 {.  l
1230: 73 65 61 72 63 68 20 5b 65 78 65 63 73 71 6c 20  search [execsql 
1240: 7b 0a 20 20 20 20 45 58 50 4c 41 49 4e 20 53 45  {.    EXPLAIN SE
1250: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 35 3b 0a  LECT * FROM v5;.
1260: 20 20 7d 5d 20 4f 70 65 6e 54 65 6d 70 0a 7d 20    }] OpenTemp.} 
1270: 7b 2d 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  {-1}.do_test vie
1280: 77 2d 35 2e 34 20 7b 0a 20 20 65 78 65 63 73 71  w-5.4 {.  execsq
1290: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
12a0: 20 46 52 4f 4d 20 76 35 20 41 53 20 61 2c 20 74   FROM v5 AS a, t
12b0: 32 20 41 53 20 62 20 57 48 45 52 45 20 61 2e 77  2 AS b WHERE a.w
12c0: 3d 62 2e 79 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  =b.y;.  }.} {1 2
12d0: 32 20 32 32 20 32 20 34 20 35 35 20 35 35 20 35  2 22 2 4 55 55 5
12e0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35  }.do_test view-5
12f0: 2e 35 20 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b  .5 {.  lsearch [
1300: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 45 58  execsql {.    EX
1310: 50 4c 41 49 4e 20 53 45 4c 45 43 54 20 2a 20 46  PLAIN SELECT * F
1320: 52 4f 4d 20 76 35 20 41 53 20 61 2c 20 74 32 20  ROM v5 AS a, t2 
1330: 41 53 20 62 20 57 48 45 52 45 20 61 2e 77 3d 62  AS b WHERE a.w=b
1340: 2e 79 3b 0a 20 20 7d 5d 20 4f 70 65 6e 54 65 6d  .y;.  }] OpenTem
1350: 70 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65 73 74  p.} {-1}.do_test
1360: 20 76 69 65 77 2d 35 2e 36 20 7b 0a 20 20 65 78   view-5.6 {.  ex
1370: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
1380: 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 41 53 20  CT * FROM t2 AS 
1390: 62 2c 20 76 35 20 41 53 20 61 20 57 48 45 52 45  b, v5 AS a WHERE
13a0: 20 61 2e 77 3d 62 2e 79 3b 0a 20 20 7d 0a 7d 20   a.w=b.y;.  }.} 
13b0: 7b 32 32 20 32 20 31 20 32 32 20 35 35 20 35 20  {22 2 1 22 55 5 
13c0: 34 20 35 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69  4 55}.do_test vi
13d0: 65 77 2d 35 2e 37 20 7b 0a 20 20 6c 73 65 61 72  ew-5.7 {.  lsear
13e0: 63 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20 20  ch [execsql {.  
13f0: 20 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43 54    EXPLAIN SELECT
1400: 20 2a 20 46 52 4f 4d 20 74 32 20 41 53 20 62 2c   * FROM t2 AS b,
1410: 20 76 35 20 41 53 20 61 20 57 48 45 52 45 20 61   v5 AS a WHERE a
1420: 2e 77 3d 62 2e 79 3b 0a 20 20 7d 5d 20 4f 70 65  .w=b.y;.  }] Ope
1430: 6e 54 65 6d 70 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f  nTemp.} {-1}.do_
1440: 74 65 73 74 20 76 69 65 77 2d 35 2e 38 20 7b 0a  test view-5.8 {.
1450: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1460: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31  SELECT * FROM t1
1470: 20 41 53 20 61 2c 20 76 35 20 41 53 20 62 2c 20   AS a, v5 AS b, 
1480: 74 32 20 41 53 20 63 20 57 48 45 52 45 20 61 2e  t2 AS c WHERE a.
1490: 78 3d 62 2e 76 20 41 4e 44 20 62 2e 77 3d 63 2e  x=b.v AND b.w=c.
14a0: 79 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 20  y;.  }.} {1 2 3 
14b0: 34 20 31 20 32 32 20 32 32 20 32 20 34 20 35 20  4 1 22 22 2 4 5 
14c0: 36 20 37 20 34 20 35 35 20 35 35 20 35 7d 0a 64  6 7 4 55 55 5}.d
14d0: 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 39 20  o_test view-5.9 
14e0: 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65  {.  lsearch [exe
14f0: 63 73 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41  csql {.    EXPLA
1500: 49 4e 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  IN SELECT * FROM
1510: 20 74 31 20 41 53 20 61 2c 20 76 35 20 41 53 20   t1 AS a, v5 AS 
1520: 62 2c 20 74 32 20 41 53 20 63 20 57 48 45 52 45  b, t2 AS c WHERE
1530: 20 61 2e 78 3d 62 2e 76 20 41 4e 44 20 62 2e 77   a.x=b.v AND b.w
1540: 3d 63 2e 79 3b 0a 20 20 7d 5d 20 4f 70 65 6e 54  =c.y;.  }] OpenT
1550: 65 6d 70 0a 7d 20 7b 2d 31 7d 0a 7d 20 3b 23 20  emp.} {-1}.} ;# 
1560: 65 6e 64 69 66 20 65 78 70 6c 61 69 6e 0a 0a 64  endif explain..d
1570: 6f 5f 74 65 73 74 20 76 69 65 77 2d 36 2e 31 20  o_test view-6.1 
1580: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1590: 20 20 53 45 4c 45 43 54 20 6d 69 6e 28 78 29 2c    SELECT min(x),
15a0: 20 6d 69 6e 28 61 29 2c 20 6d 69 6e 28 62 29 2c   min(a), min(b),
15b0: 20 6d 69 6e 28 63 29 2c 20 6d 69 6e 28 61 2b 62   min(c), min(a+b
15c0: 2b 63 29 20 46 52 4f 4d 20 76 32 3b 0a 20 20 7d  +c) FROM v2;.  }
15d0: 0a 7d 20 7b 37 20 38 20 39 20 31 30 20 32 37 7d  .} {7 8 9 10 27}
15e0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 36 2e  .do_test view-6.
15f0: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  2 {.  execsql {.
1600: 20 20 20 20 53 45 4c 45 43 54 20 6d 61 78 28 78      SELECT max(x
1610: 29 2c 20 6d 61 78 28 61 29 2c 20 6d 61 78 28 62  ), max(a), max(b
1620: 29 2c 20 6d 61 78 28 63 29 2c 20 6d 61 78 28 61  ), max(c), max(a
1630: 2b 62 2b 63 29 20 46 52 4f 4d 20 76 32 3b 0a 20  +b+c) FROM v2;. 
1640: 20 7d 0a 7d 20 7b 31 31 20 31 32 20 31 33 20 31   }.} {11 12 13 1
1650: 34 20 33 39 7d 0a 0a 64 6f 5f 74 65 73 74 20 76  4 39}..do_test v
1660: 69 65 77 2d 37 2e 31 20 7b 0a 20 20 65 78 65 63  iew-7.1 {.  exec
1670: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
1680: 20 54 41 42 4c 45 20 74 65 73 74 31 28 69 64 20   TABLE test1(id 
1690: 69 6e 74 65 67 65 72 20 70 72 69 6d 61 72 79 20  integer primary 
16a0: 6b 65 79 2c 20 61 29 3b 0a 20 20 20 20 43 52 45  key, a);.    CRE
16b0: 41 54 45 20 54 41 42 4c 45 20 74 65 73 74 32 28  ATE TABLE test2(
16c0: 69 64 20 69 6e 74 65 67 65 72 2c 20 62 29 3b 0a  id integer, b);.
16d0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
16e0: 74 65 73 74 31 20 56 41 4c 55 45 53 28 31 2c 32  test1 VALUES(1,2
16f0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
1700: 54 4f 20 74 65 73 74 32 20 56 41 4c 55 45 53 28  TO test2 VALUES(
1710: 31 2c 33 29 3b 0a 20 20 20 20 43 52 45 41 54 45  1,3);.    CREATE
1720: 20 56 49 45 57 20 74 65 73 74 20 41 53 0a 20 20   VIEW test AS.  
1730: 20 20 20 20 53 45 4c 45 43 54 20 74 65 73 74 31      SELECT test1
1740: 2e 69 64 2c 20 61 2c 20 62 0a 20 20 20 20 20 20  .id, a, b.      
1750: 46 52 4f 4d 20 74 65 73 74 31 20 4a 4f 49 4e 20  FROM test1 JOIN 
1760: 74 65 73 74 32 20 4f 4e 20 74 65 73 74 32 2e 69  test2 ON test2.i
1770: 64 3d 74 65 73 74 31 2e 69 64 3b 0a 20 20 20 20  d=test1.id;.    
1780: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65  SELECT * FROM te
1790: 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  st;.  }.} {1 2 3
17a0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37  }.do_test view-7
17b0: 2e 32 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  .2 {.  db close.
17c0: 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73    sqlite3 db tes
17d0: 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b  t.db.  execsql {
17e0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
17f0: 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b  OM test;.  }.} {
1800: 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76  1 2 3}.do_test v
1810: 69 65 77 2d 37 2e 33 20 7b 0a 20 20 65 78 65 63  iew-7.3 {.  exec
1820: 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56  sql {.    DROP V
1830: 49 45 57 20 74 65 73 74 3b 0a 20 20 20 20 43 52  IEW test;.    CR
1840: 45 41 54 45 20 56 49 45 57 20 74 65 73 74 20 41  EATE VIEW test A
1850: 53 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 74  S.      SELECT t
1860: 65 73 74 31 2e 69 64 2c 20 61 2c 20 62 0a 20 20  est1.id, a, b.  
1870: 20 20 20 20 46 52 4f 4d 20 74 65 73 74 31 20 4a      FROM test1 J
1880: 4f 49 4e 20 74 65 73 74 32 20 55 53 49 4e 47 28  OIN test2 USING(
1890: 69 64 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  id);.    SELECT 
18a0: 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d  * FROM test;.  }
18b0: 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65  .} {1 2 3}.do_te
18c0: 73 74 20 76 69 65 77 2d 37 2e 34 20 7b 0a 20 20  st view-7.4 {.  
18d0: 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74  db close.  sqlit
18e0: 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20  e3 db test.db.  
18f0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
1900: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74  LECT * FROM test
1910: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a  ;.  }.} {1 2 3}.
1920: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 35  do_test view-7.5
1930: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
1940: 20 20 20 44 52 4f 50 20 56 49 45 57 20 74 65 73     DROP VIEW tes
1950: 74 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49  t;.    CREATE VI
1960: 45 57 20 74 65 73 74 20 41 53 0a 20 20 20 20 20  EW test AS.     
1970: 20 53 45 4c 45 43 54 20 74 65 73 74 31 2e 69 64   SELECT test1.id
1980: 2c 20 61 2c 20 62 0a 20 20 20 20 20 20 46 52 4f  , a, b.      FRO
1990: 4d 20 74 65 73 74 31 20 4e 41 54 55 52 41 4c 20  M test1 NATURAL 
19a0: 4a 4f 49 4e 20 74 65 73 74 32 3b 0a 20 20 20 20  JOIN test2;.    
19b0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65  SELECT * FROM te
19c0: 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  st;.  }.} {1 2 3
19d0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37  }.do_test view-7
19e0: 2e 36 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  .6 {.  db close.
19f0: 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73    sqlite3 db tes
1a00: 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b  t.db.  execsql {
1a10: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
1a20: 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b  OM test;.  }.} {
1a30: 31 20 32 20 33 7d 0a 0a 64 6f 5f 74 65 73 74 20  1 2 3}..do_test 
1a40: 76 69 65 77 2d 38 2e 31 20 7b 0a 20 20 65 78 65  view-8.1 {.  exe
1a50: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
1a60: 45 20 56 49 45 57 20 76 36 20 41 53 20 53 45 4c  E VIEW v6 AS SEL
1a70: 45 43 54 20 70 71 72 2c 20 78 79 7a 20 46 52 4f  ECT pqr, xyz FRO
1a80: 4d 20 76 31 3b 0a 20 20 20 20 53 45 4c 45 43 54  M v1;.    SELECT
1a90: 20 2a 20 46 52 4f 4d 20 76 36 20 4f 52 44 45 52   * FROM v6 ORDER
1aa0: 20 42 59 20 78 79 7a 3b 0a 20 20 7d 0a 7d 20 7b   BY xyz;.  }.} {
1ab0: 37 20 32 20 31 33 20 35 20 31 39 20 38 20 32 37  7 2 13 5 19 8 27
1ac0: 20 31 32 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65   12}.do_test vie
1ad0: 77 2d 38 2e 32 20 7b 0a 20 20 64 62 20 63 6c 6f  w-8.2 {.  db clo
1ae0: 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20  se.  sqlite3 db 
1af0: 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71  test.db.  execsq
1b00: 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  l {.    SELECT *
1b10: 20 46 52 4f 4d 20 76 36 20 4f 52 44 45 52 20 42   FROM v6 ORDER B
1b20: 59 20 78 79 7a 3b 0a 20 20 7d 0a 7d 20 7b 37 20  Y xyz;.  }.} {7 
1b30: 32 20 31 33 20 35 20 31 39 20 38 20 32 37 20 31  2 13 5 19 8 27 1
1b40: 32 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  2}.do_test view-
1b50: 38 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  8.3 {.  execsql 
1b60: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
1b70: 57 20 76 37 20 41 53 20 53 45 4c 45 43 54 20 70  W v7 AS SELECT p
1b80: 71 72 2b 78 79 7a 20 41 53 20 61 20 46 52 4f 4d  qr+xyz AS a FROM
1b90: 20 76 36 3b 0a 20 20 20 20 53 45 4c 45 43 54 20   v6;.    SELECT 
1ba0: 2a 20 46 52 4f 4d 20 76 37 20 4f 52 44 45 52 20  * FROM v7 ORDER 
1bb0: 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 39 20 31  BY a;.  }.} {9 1
1bc0: 38 20 32 37 20 33 39 7d 0a 0a 69 66 63 61 70 61  8 27 39}..ifcapa
1bd0: 62 6c 65 20 73 75 62 71 75 65 72 79 20 7b 0a 20  ble subquery {. 
1be0: 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e   do_test view-8.
1bf0: 34 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  4 {.    execsql 
1c00: 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 56  {.      CREATE V
1c10: 49 45 57 20 76 38 20 41 53 20 53 45 4c 45 43 54  IEW v8 AS SELECT
1c20: 20 6d 61 78 28 63 6e 74 29 20 41 53 20 6d 78 20   max(cnt) AS mx 
1c30: 46 52 4f 4d 0a 20 20 20 20 20 20 20 20 28 53 45  FROM.        (SE
1c40: 4c 45 43 54 20 61 25 32 20 41 53 20 65 6f 2c 20  LECT a%2 AS eo, 
1c50: 63 6f 75 6e 74 28 2a 29 20 41 53 20 63 6e 74 20  count(*) AS cnt 
1c60: 46 52 4f 4d 20 74 31 20 47 52 4f 55 50 20 42 59  FROM t1 GROUP BY
1c70: 20 65 6f 29 3b 0a 20 20 20 20 20 20 53 45 4c 45   eo);.      SELE
1c80: 43 54 20 2a 20 46 52 4f 4d 20 76 38 3b 0a 20 20  CT * FROM v8;.  
1c90: 20 20 7d 0a 20 20 7d 20 33 0a 20 20 64 6f 5f 74    }.  } 3.  do_t
1ca0: 65 73 74 20 76 69 65 77 2d 38 2e 35 20 7b 0a 20  est view-8.5 {. 
1cb0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
1cc0: 20 20 20 53 45 4c 45 43 54 20 6d 78 2b 31 30 2c     SELECT mx+10,
1cd0: 20 6d 78 2a 32 20 46 52 4f 4d 20 76 38 3b 0a 20   mx*2 FROM v8;. 
1ce0: 20 20 20 7d 0a 20 20 7d 20 7b 31 33 20 36 7d 0a     }.  } {13 6}.
1cf0: 20 20 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38    do_test view-8
1d00: 2e 36 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .6 {.    execsql
1d10: 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20   {.      SELECT 
1d20: 6d 78 2b 31 30 2c 20 70 71 72 20 46 52 4f 4d 20  mx+10, pqr FROM 
1d30: 76 36 2c 20 76 38 20 57 48 45 52 45 20 78 79 7a  v6, v8 WHERE xyz
1d40: 3d 32 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31  =2;.    }.  } {1
1d50: 33 20 37 7d 0a 20 20 64 6f 5f 74 65 73 74 20 76  3 7}.  do_test v
1d60: 69 65 77 2d 38 2e 37 20 7b 0a 20 20 20 20 65 78  iew-8.7 {.    ex
1d70: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45  ecsql {.      SE
1d80: 4c 45 43 54 20 6d 78 2b 31 30 2c 20 70 71 72 20  LECT mx+10, pqr 
1d90: 46 52 4f 4d 20 76 36 2c 20 76 38 20 57 48 45 52  FROM v6, v8 WHER
1da0: 45 20 78 79 7a 3e 32 3b 0a 20 20 20 20 7d 0a 20  E xyz>2;.    }. 
1db0: 20 7d 20 7b 31 33 20 31 33 20 31 33 20 31 39 20   } {13 13 13 19 
1dc0: 31 33 20 32 37 7d 0a 7d 20 3b 23 20 69 66 63 61  13 27}.} ;# ifca
1dd0: 70 61 62 6c 65 20 73 75 62 71 75 65 72 79 0a 0a  pable subquery..
1de0: 23 20 54 65 73 74 73 20 66 6f 72 20 61 20 62 75  # Tests for a bu
1df0: 67 20 66 6f 75 6e 64 20 62 79 20 4d 69 63 68 69  g found by Michi
1e00: 65 6c 20 64 65 20 57 69 74 20 69 6e 76 6f 6c 76  el de Wit involv
1e10: 69 6e 67 20 4f 52 44 45 52 20 42 59 20 69 6e 20  ing ORDER BY in 
1e20: 61 20 56 49 45 57 2e 0a 23 0a 64 6f 5f 74 65 73  a VIEW..#.do_tes
1e30: 74 20 76 69 65 77 2d 39 2e 31 20 7b 0a 20 20 65  t view-9.1 {.  e
1e40: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53  xecsql {.    INS
1e50: 45 52 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45  ERT INTO t2 SELE
1e60: 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 57 48 45  CT * FROM t2 WHE
1e70: 52 45 20 61 3c 35 3b 0a 20 20 20 20 49 4e 53 45  RE a<5;.    INSE
1e80: 52 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45 43  RT INTO t2 SELEC
1e90: 54 20 2a 20 46 52 4f 4d 20 74 32 20 57 48 45 52  T * FROM t2 WHER
1ea0: 45 20 61 3c 34 3b 0a 20 20 20 20 49 4e 53 45 52  E a<4;.    INSER
1eb0: 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45 43 54  T INTO t2 SELECT
1ec0: 20 2a 20 46 52 4f 4d 20 74 32 20 57 48 45 52 45   * FROM t2 WHERE
1ed0: 20 61 3c 33 3b 0a 20 20 20 20 53 45 4c 45 43 54   a<3;.    SELECT
1ee0: 20 44 49 53 54 49 4e 43 54 20 63 6f 75 6e 74 28   DISTINCT count(
1ef0: 2a 29 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50  *) FROM t2 GROUP
1f00: 20 42 59 20 61 20 4f 52 44 45 52 20 42 59 20 31   BY a ORDER BY 1
1f10: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20 38  ;.  }.} {1 2 4 8
1f20: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 39  }.do_test view-9
1f30: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
1f40: 0a 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54  .    SELECT DIST
1f50: 49 4e 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52  INCT count(*) FR
1f60: 4f 4d 20 74 32 20 47 52 4f 55 50 20 42 59 20 61  OM t2 GROUP BY a
1f70: 20 4f 52 44 45 52 20 42 59 20 31 20 4c 49 4d 49   ORDER BY 1 LIMI
1f80: 54 20 33 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20  T 3;.  }.} {1 2 
1f90: 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  4}.do_test view-
1fa0: 39 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  9.3 {.  execsql 
1fb0: 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45  {.    CREATE VIE
1fc0: 57 20 76 39 20 41 53 20 0a 20 20 20 20 20 20 20  W v9 AS .       
1fd0: 53 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20  SELECT DISTINCT 
1fe0: 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32  count(*) FROM t2
1ff0: 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52 44 45   GROUP BY a ORDE
2000: 52 20 42 59 20 31 20 4c 49 4d 49 54 20 33 3b 0a  R BY 1 LIMIT 3;.
2010: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
2020: 4d 20 76 39 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  M v9;.  }.} {1 2
2030: 20 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77   4}.do_test view
2040: 2d 39 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  -9.4 {.  execsql
2050: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
2060: 46 52 4f 4d 20 76 39 20 4f 52 44 45 52 20 42 59  FROM v9 ORDER BY
2070: 20 31 20 44 45 53 43 3b 0a 20 20 7d 0a 7d 20 7b   1 DESC;.  }.} {
2080: 34 20 32 20 31 7d 0a 64 6f 5f 74 65 73 74 20 76  4 2 1}.do_test v
2090: 69 65 77 2d 39 2e 35 20 7b 0a 20 20 65 78 65 63  iew-9.5 {.  exec
20a0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
20b0: 20 56 49 45 57 20 76 31 30 20 41 53 20 0a 20 20   VIEW v10 AS .  
20c0: 20 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54       SELECT DIST
20d0: 49 4e 43 54 20 61 2c 20 63 6f 75 6e 74 28 2a 29  INCT a, count(*)
20e0: 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50 20 42   FROM t2 GROUP B
20f0: 59 20 61 20 4f 52 44 45 52 20 42 59 20 32 20 4c  Y a ORDER BY 2 L
2100: 49 4d 49 54 20 33 3b 0a 20 20 20 20 53 45 4c 45  IMIT 3;.    SELE
2110: 43 54 20 2a 20 46 52 4f 4d 20 76 31 30 3b 0a 20  CT * FROM v10;. 
2120: 20 7d 0a 7d 20 7b 35 20 31 20 34 20 32 20 33 20   }.} {5 1 4 2 3 
2130: 34 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  4}.do_test view-
2140: 39 2e 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  9.6 {.  execsql 
2150: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
2160: 52 4f 4d 20 76 31 30 20 4f 52 44 45 52 20 42 59  ROM v10 ORDER BY
2170: 20 31 3b 0a 20 20 7d 0a 7d 20 7b 33 20 34 20 34   1;.  }.} {3 4 4
2180: 20 32 20 35 20 31 7d 0a 0a 23 20 54 61 62 6c 65   2 5 1}..# Table
2190: 73 20 77 69 74 68 20 63 6f 6c 75 6d 6e 73 20 68  s with columns h
21a0: 61 76 69 6e 67 20 70 65 63 75 6c 69 61 72 20 71  aving peculiar q
21b0: 75 6f 74 65 64 20 6e 61 6d 65 73 20 75 73 65 64  uoted names used
21c0: 20 69 6e 20 76 69 65 77 73 0a 23 20 54 69 63 6b   in views.# Tick
21d0: 65 74 20 23 37 35 36 2e 0a 23 0a 64 6f 5f 74 65  et #756..#.do_te
21e0: 73 74 20 76 69 65 77 2d 31 30 2e 31 20 7b 0a 20  st view-10.1 {. 
21f0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
2200: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 22  REATE TABLE t3("
2210: 39 22 20 69 6e 74 65 67 65 72 2c 20 5b 34 5d 20  9" integer, [4] 
2220: 74 65 78 74 29 3b 0a 20 20 20 20 49 4e 53 45 52  text);.    INSER
2230: 54 20 49 4e 54 4f 20 74 33 20 56 41 4c 55 45 53  T INTO t3 VALUES
2240: 28 31 2c 32 29 3b 0a 20 20 20 20 43 52 45 41 54  (1,2);.    CREAT
2250: 45 20 56 49 45 57 20 76 5f 74 33 5f 61 20 41 53  E VIEW v_t3_a AS
2260: 20 53 45 4c 45 43 54 20 61 2e 5b 39 5d 20 46 52   SELECT a.[9] FR
2270: 4f 4d 20 74 33 20 41 53 20 61 3b 0a 20 20 20 20  OM t3 AS a;.    
2280: 43 52 45 41 54 45 20 56 49 45 57 20 76 5f 74 33  CREATE VIEW v_t3
2290: 5f 62 20 41 53 20 53 45 4c 45 43 54 20 22 34 22  _b AS SELECT "4"
22a0: 20 46 52 4f 4d 20 74 33 3b 0a 20 20 20 20 53 45   FROM t3;.    SE
22b0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 5f 74 33  LECT * FROM v_t3
22c0: 5f 61 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f  _a;.  }.} {1}.do
22d0: 5f 74 65 73 74 20 76 69 65 77 2d 31 30 2e 32 20  _test view-10.2 
22e0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
22f0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
2300: 76 5f 74 33 5f 62 3b 0a 20 20 7d 0a 7d 20 7b 32  v_t3_b;.  }.} {2
2310: 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }..do_test view-
2320: 31 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  11.1 {.  execsql
2330: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
2340: 42 4c 45 20 74 34 28 61 20 43 4f 4c 4c 41 54 45  BLE t4(a COLLATE
2350: 20 4e 4f 43 41 53 45 29 3b 0a 20 20 20 20 49 4e   NOCASE);.    IN
2360: 53 45 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c  SERT INTO t4 VAL
2370: 55 45 53 28 27 54 68 69 73 27 29 3b 0a 20 20 20  UES('This');.   
2380: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 34 20   INSERT INTO t4 
2390: 56 41 4c 55 45 53 28 27 74 68 69 73 27 29 3b 0a  VALUES('this');.
23a0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
23b0: 74 34 20 56 41 4c 55 45 53 28 27 54 48 49 53 27  t4 VALUES('THIS'
23c0: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  );.    SELECT * 
23d0: 46 52 4f 4d 20 74 34 20 57 48 45 52 45 20 61 20  FROM t4 WHERE a 
23e0: 3d 20 27 54 48 49 53 27 3b 0a 20 20 7d 0a 7d 20  = 'THIS';.  }.} 
23f0: 7b 54 68 69 73 20 74 68 69 73 20 54 48 49 53 7d  {This this THIS}
2400: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 31  .do_test view-11
2410: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
2420: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
2430: 4f 4d 20 28 53 45 4c 45 43 54 20 2a 20 46 52 4f  OM (SELECT * FRO
2440: 4d 20 74 34 29 20 57 48 45 52 45 20 61 20 3d 20  M t4) WHERE a = 
2450: 27 54 48 49 53 27 3b 0a 20 20 7d 0a 7d 20 7b 54  'THIS';.  }.} {T
2460: 68 69 73 20 74 68 69 73 20 54 48 49 53 7d 0a 64  his this THIS}.d
2470: 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 31 2e 33  o_test view-11.3
2480: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
2490: 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20 76     CREATE VIEW v
24a0: 31 31 20 41 53 20 53 45 4c 45 43 54 20 2a 20 46  11 AS SELECT * F
24b0: 52 4f 4d 20 74 34 3b 0a 20 20 20 20 53 45 4c 45  ROM t4;.    SELE
24c0: 43 54 20 2a 20 46 52 4f 4d 20 76 31 31 20 57 48  CT * FROM v11 WH
24d0: 45 52 45 20 61 20 3d 20 27 54 48 49 53 27 3b 0a  ERE a = 'THIS';.
24e0: 20 20 7d 0a 7d 20 7b 54 68 69 73 20 74 68 69 73    }.} {This this
24f0: 20 54 48 49 53 7d 0a 0a 66 69 6e 69 73 68 5f 74   THIS}..finish_t
2500: 65 73 74 0a                                      est.