/ Hex Artifact Content
Login

Artifact 1ee12c6f8f4791a2c0655120d5562a49400cfe53:


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 31 36 20 32 30 30 33 2f 30 35 2f 33 31 20  1.16 2003/05/31 
0200: 31 36 3a 32 31 3a 31 33 20 64 72 68 20 45 78 70  16:21:13 drh Exp
0210: 20 24 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b   $.set testdir [
0220: 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72  file dirname $ar
0230: 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73  gv0].source $tes
0240: 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a  tdir/tester.tcl.
0250: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 2e  .do_test view-1.
0260: 30 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  0 {.  execsql {.
0270: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
0280: 20 74 31 28 61 2c 62 2c 63 29 3b 0a 20 20 20 20   t1(a,b,c);.    
0290: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
02a0: 41 4c 55 45 53 28 31 2c 32 2c 33 29 3b 0a 20 20  ALUES(1,2,3);.  
02b0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
02c0: 20 56 41 4c 55 45 53 28 34 2c 35 2c 36 29 3b 0a   VALUES(4,5,6);.
02d0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
02e0: 74 31 20 56 41 4c 55 45 53 28 37 2c 38 2c 39 29  t1 VALUES(7,8,9)
02f0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
0300: 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31  ROM t1;.  }.} {1
0310: 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20 39   2 3 4 5 6 7 8 9
0320: 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d  }..do_test view-
0330: 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.1 {.  execsql 
0340: 7b 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20  {.    BEGIN;.   
0350: 20 43 52 45 41 54 45 20 56 49 45 57 20 76 31 20   CREATE VIEW v1 
0360: 41 53 20 53 45 4c 45 43 54 20 61 2c 62 20 46 52  AS SELECT a,b FR
0370: 4f 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43  OM t1;.    SELEC
0380: 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45  T * FROM v1 ORDE
0390: 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31  R BY a;.  }.} {1
03a0: 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f 74   2 4 5 7 8}.do_t
03b0: 65 73 74 20 76 69 65 77 2d 31 2e 32 20 7b 0a 20  est view-1.2 {. 
03c0: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
03d0: 52 4f 4c 4c 42 41 43 4b 3b 0a 20 20 20 20 53 45  ROLLBACK;.    SE
03e0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f  LECT * FROM v1 O
03f0: 52 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d  RDER BY a;.  }.}
0400: 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62   {1 {no such tab
0410: 6c 65 3a 20 76 31 7d 7d 0a 64 6f 5f 74 65 73 74  le: v1}}.do_test
0420: 20 76 69 65 77 2d 31 2e 33 20 7b 0a 20 20 65 78   view-1.3 {.  ex
0430: 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  ecsql {.    CREA
0440: 54 45 20 56 49 45 57 20 76 31 20 41 53 20 53 45  TE VIEW v1 AS SE
0450: 4c 45 43 54 20 61 2c 62 20 46 52 4f 4d 20 74 31  LECT a,b FROM t1
0460: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
0470: 52 4f 4d 20 76 31 20 4f 52 44 45 52 20 42 59 20  ROM v1 ORDER BY 
0480: 61 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 34 20  a;.  }.} {1 2 4 
0490: 35 20 37 20 38 7d 0a 64 6f 5f 74 65 73 74 20 76  5 7 8}.do_test v
04a0: 69 65 77 2d 31 2e 33 2e 31 20 7b 0a 20 20 64 62  iew-1.3.1 {.  db
04b0: 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 20   close.  sqlite 
04c0: 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65  db test.db.  exe
04d0: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
04e0: 54 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45  T * FROM v1 ORDE
04f0: 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31  R BY a;.  }.} {1
0500: 20 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f 74   2 4 5 7 8}.do_t
0510: 65 73 74 20 76 69 65 77 2d 31 2e 34 20 7b 0a 20  est view-1.4 {. 
0520: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
0530: 44 52 4f 50 20 56 49 45 57 20 76 31 3b 0a 20 20  DROP VIEW v1;.  
0540: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0550: 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20  v1 ORDER BY a;. 
0560: 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68   }.} {1 {no such
0570: 20 74 61 62 6c 65 3a 20 76 31 7d 7d 0a 64 6f 5f   table: v1}}.do_
0580: 74 65 73 74 20 76 69 65 77 2d 31 2e 35 20 7b 0a  test view-1.5 {.
0590: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
05a0: 43 52 45 41 54 45 20 56 49 45 57 20 76 31 20 41  CREATE VIEW v1 A
05b0: 53 20 53 45 4c 45 43 54 20 61 2c 62 20 46 52 4f  S SELECT a,b FRO
05c0: 4d 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54  M t1;.    SELECT
05d0: 20 2a 20 46 52 4f 4d 20 76 31 20 4f 52 44 45 52   * FROM v1 ORDER
05e0: 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20 7b 31 20   BY a;.  }.} {1 
05f0: 32 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f 74 65  2 4 5 7 8}.do_te
0600: 73 74 20 76 69 65 77 2d 31 2e 36 20 7b 0a 20 20  st view-1.6 {.  
0610: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 44  catchsql {.    D
0620: 52 4f 50 20 54 41 42 4c 45 20 74 31 3b 0a 20 20  ROP TABLE t1;.  
0630: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0640: 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20  v1 ORDER BY a;. 
0650: 20 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68   }.} {1 {no such
0660: 20 74 61 62 6c 65 3a 20 6d 61 69 6e 2e 74 31 7d   table: main.t1}
0670: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31  }.do_test view-1
0680: 2e 37 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .7 {.  execsql {
0690: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
06a0: 45 20 74 31 28 78 2c 61 2c 62 2c 63 29 3b 0a 20  E t1(x,a,b,c);. 
06b0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
06c0: 31 20 56 41 4c 55 45 53 28 31 2c 32 2c 33 2c 34  1 VALUES(1,2,3,4
06d0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
06e0: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 34 2c 35  TO t1 VALUES(4,5
06f0: 2c 36 2c 37 29 3b 0a 20 20 20 20 49 4e 53 45 52  ,6,7);.    INSER
0700: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
0710: 28 37 2c 38 2c 39 2c 31 30 29 3b 0a 20 20 20 20  (7,8,9,10);.    
0720: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
0730: 20 4f 52 44 45 52 20 42 59 20 61 3b 0a 20 20 7d   ORDER BY a;.  }
0740: 0a 7d 20 7b 32 20 33 20 35 20 36 20 38 20 39 7d  .} {2 3 5 6 8 9}
0750: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 31 2e  .do_test view-1.
0760: 38 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20  8 {.  db close. 
0770: 20 73 71 6c 69 74 65 20 64 62 20 74 65 73 74 2e   sqlite db test.
0780: 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  db.  execsql {. 
0790: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
07a0: 20 76 31 20 4f 52 44 45 52 20 42 59 20 61 3b 0a   v1 ORDER BY a;.
07b0: 20 20 7d 0a 7d 20 7b 32 20 33 20 35 20 36 20 38    }.} {2 3 5 6 8
07c0: 20 39 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65   9}..do_test vie
07d0: 77 2d 32 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  w-2.1 {.  execsq
07e0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  l {.    CREATE V
07f0: 49 45 57 20 76 32 20 41 53 20 53 45 4c 45 43 54  IEW v2 AS SELECT
0800: 20 2a 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45   * FROM t1 WHERE
0810: 20 61 3e 35 0a 20 20 7d 3b 20 20 23 20 4e 6f 20   a>5.  };  # No 
0820: 73 65 6d 69 63 6f 6c 6f 6e 0a 20 20 65 78 65 63  semicolon.  exec
0830: 73 71 6c 32 20 7b 0a 20 20 20 20 53 45 4c 45 43  sql2 {.    SELEC
0840: 54 20 2a 20 46 52 4f 4d 20 76 32 3b 0a 20 20 7d  T * FROM v2;.  }
0850: 0a 7d 20 7b 78 20 37 20 61 20 38 20 62 20 39 20  .} {x 7 a 8 b 9 
0860: 63 20 31 30 7d 0a 64 6f 5f 74 65 73 74 20 76 69  c 10}.do_test vi
0870: 65 77 2d 32 2e 32 20 7b 0a 20 20 63 61 74 63 68  ew-2.2 {.  catch
0880: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
0890: 20 49 4e 54 4f 20 76 32 20 56 41 4c 55 45 53 28   INTO v2 VALUES(
08a0: 31 2c 32 2c 33 2c 34 29 3b 0a 20 20 7d 0a 7d 20  1,2,3,4);.  }.} 
08b0: 7b 31 20 7b 63 61 6e 6e 6f 74 20 6d 6f 64 69 66  {1 {cannot modif
08c0: 79 20 76 32 20 62 65 63 61 75 73 65 20 69 74 20  y v2 because it 
08d0: 69 73 20 61 20 76 69 65 77 7d 7d 0a 64 6f 5f 74  is a view}}.do_t
08e0: 65 73 74 20 76 69 65 77 2d 32 2e 33 20 7b 0a 20  est view-2.3 {. 
08f0: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
0900: 55 50 44 41 54 45 20 76 32 20 53 45 54 20 61 3d  UPDATE v2 SET a=
0910: 31 30 20 57 48 45 52 45 20 61 3d 35 3b 0a 20 20  10 WHERE a=5;.  
0920: 7d 0a 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 6d  }.} {1 {cannot m
0930: 6f 64 69 66 79 20 76 32 20 62 65 63 61 75 73 65  odify v2 because
0940: 20 69 74 20 69 73 20 61 20 76 69 65 77 7d 7d 0a   it is a view}}.
0950: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 32 2e 34  do_test view-2.4
0960: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a   {.  catchsql {.
0970: 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20      DELETE FROM 
0980: 76 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 63 61  v2;.  }.} {1 {ca
0990: 6e 6e 6f 74 20 6d 6f 64 69 66 79 20 76 32 20 62  nnot modify v2 b
09a0: 65 63 61 75 73 65 20 69 74 20 69 73 20 61 20 76  ecause it is a v
09b0: 69 65 77 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69  iew}}.do_test vi
09c0: 65 77 2d 32 2e 35 20 7b 0a 20 20 65 78 65 63 73  ew-2.5 {.  execs
09d0: 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20  ql {.    INSERT 
09e0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31  INTO t1 VALUES(1
09f0: 31 2c 31 32 2c 31 33 2c 31 34 29 3b 0a 20 20 20  1,12,13,14);.   
0a00: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
0a10: 32 20 4f 52 44 45 52 20 42 59 20 78 3b 0a 20 20  2 ORDER BY x;.  
0a20: 7d 0a 7d 20 7b 37 20 38 20 39 20 31 30 20 31 31  }.} {7 8 9 10 11
0a30: 20 31 32 20 31 33 20 31 34 7d 0a 64 6f 5f 74 65   12 13 14}.do_te
0a40: 73 74 20 76 69 65 77 2d 32 2e 36 20 7b 0a 20 20  st view-2.6 {.  
0a50: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
0a60: 4c 45 43 54 20 78 20 46 52 4f 4d 20 76 32 20 57  LECT x FROM v2 W
0a70: 48 45 52 45 20 61 3e 31 30 0a 20 20 7d 0a 7d 20  HERE a>10.  }.} 
0a80: 7b 31 31 7d 0a 0a 23 20 54 65 73 74 20 74 68 61  {11}..# Test tha
0a90: 74 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 20 6f 66  t column name of
0aa0: 20 76 69 65 77 73 20 61 72 65 20 67 65 6e 65 72   views are gener
0ab0: 61 74 65 64 20 63 6f 72 72 65 63 74 6c 79 2e 0a  ated correctly..
0ac0: 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 33  #.do_test view-3
0ad0: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 32 20  .1 {.  execsql2 
0ae0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
0af0: 52 4f 4d 20 76 31 20 4c 49 4d 49 54 20 31 0a 20  ROM v1 LIMIT 1. 
0b00: 20 7d 0a 7d 20 7b 61 20 32 20 62 20 33 7d 0a 64   }.} {a 2 b 3}.d
0b10: 6f 5f 74 65 73 74 20 76 69 65 77 2d 33 2e 32 20  o_test view-3.2 
0b20: 7b 0a 20 20 65 78 65 63 73 71 6c 32 20 7b 0a 20  {.  execsql2 {. 
0b30: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0b40: 20 76 32 20 4c 49 4d 49 54 20 31 0a 20 20 7d 0a   v2 LIMIT 1.  }.
0b50: 7d 20 7b 78 20 37 20 61 20 38 20 62 20 39 20 63  } {x 7 a 8 b 9 c
0b60: 20 31 30 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65   10}.do_test vie
0b70: 77 2d 33 2e 33 20 7b 0a 20 20 65 78 65 63 73 71  w-3.3 {.  execsq
0b80: 6c 32 20 7b 0a 20 20 20 20 44 52 4f 50 20 56 49  l2 {.    DROP VI
0b90: 45 57 20 76 31 3b 0a 20 20 20 20 43 52 45 41 54  EW v1;.    CREAT
0ba0: 45 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c  E VIEW v1 AS SEL
0bb0: 45 43 54 20 61 20 41 53 20 27 78 79 7a 27 2c 20  ECT a AS 'xyz', 
0bc0: 62 2b 63 20 41 53 20 27 70 71 72 27 2c 20 63 2d  b+c AS 'pqr', c-
0bd0: 62 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 53  b FROM t1;.    S
0be0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31 20  ELECT * FROM v1 
0bf0: 4c 49 4d 49 54 20 31 0a 20 20 7d 0a 7d 20 7b 78  LIMIT 1.  }.} {x
0c00: 79 7a 20 32 20 70 71 72 20 37 20 63 2d 62 20 31  yz 2 pqr 7 c-b 1
0c10: 7d 0a 64 6f 5f 74 65 73 74 20 20 76 69 65 77 2d  }.do_test  view-
0c20: 33 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 32  3.4 {.  execsql2
0c30: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49   {.    CREATE VI
0c40: 45 57 20 76 33 20 41 53 20 53 45 4c 45 43 54 20  EW v3 AS SELECT 
0c50: 61 20 46 52 4f 4d 20 74 31 20 55 4e 49 4f 4e 20  a FROM t1 UNION 
0c60: 53 45 4c 45 43 54 20 62 20 46 52 4f 4d 20 74 31  SELECT b FROM t1
0c70: 20 4f 52 44 45 52 20 42 59 20 62 3b 0a 20 20 20   ORDER BY b;.   
0c80: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
0c90: 33 20 4c 49 4d 49 54 20 34 3b 0a 20 20 7d 0a 7d  3 LIMIT 4;.  }.}
0ca0: 20 7b 62 20 32 20 62 20 33 20 62 20 35 20 62 20   {b 2 b 3 b 5 b 
0cb0: 36 7d 0a 64 6f 5f 74 65 73 74 20 20 76 69 65 77  6}.do_test  view
0cc0: 2d 33 2e 35 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.5 {.  execsql
0cd0: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  2 {.    CREATE V
0ce0: 49 45 57 20 76 34 20 41 53 20 0a 20 20 20 20 20  IEW v4 AS .     
0cf0: 20 53 45 4c 45 43 54 20 61 2c 20 62 20 46 52 4f   SELECT a, b FRO
0d00: 4d 20 74 31 20 0a 20 20 20 20 20 20 55 4e 49 4f  M t1 .      UNIO
0d10: 4e 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 62  N.      SELECT b
0d20: 20 41 53 20 27 78 27 2c 20 61 20 41 53 20 27 79   AS 'x', a AS 'y
0d30: 27 20 46 52 4f 4d 20 74 31 0a 20 20 20 20 20 20  ' FROM t1.      
0d40: 4f 52 44 45 52 20 42 59 20 78 2c 20 79 3b 0a 20  ORDER BY x, y;. 
0d50: 20 20 20 53 45 4c 45 43 54 20 79 20 46 52 4f 4d     SELECT y FROM
0d60: 20 76 34 20 4f 52 44 45 52 20 42 59 20 79 20 4c   v4 ORDER BY y L
0d70: 49 4d 49 54 20 34 3b 0a 20 20 7d 0a 7d 20 7b 79  IMIT 4;.  }.} {y
0d80: 20 32 20 79 20 33 20 79 20 35 20 79 20 36 7d 0a   2 y 3 y 5 y 6}.
0d90: 0a 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34  ..do_test view-4
0da0: 2e 31 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  .1 {.  catchsql 
0db0: 7b 0a 20 20 20 20 44 52 4f 50 20 56 49 45 57 20  {.    DROP VIEW 
0dc0: 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 73  t1;.  }.} {1 {us
0dd0: 65 20 44 52 4f 50 20 54 41 42 4c 45 20 74 6f 20  e DROP TABLE to 
0de0: 64 65 6c 65 74 65 20 74 61 62 6c 65 20 74 31 7d  delete table t1}
0df0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 34  }.do_test view-4
0e00: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
0e10: 0a 20 20 20 20 53 45 4c 45 43 54 20 31 20 46 52  .    SELECT 1 FR
0e20: 4f 4d 20 74 31 20 4c 49 4d 49 54 20 31 3b 0a 20  OM t1 LIMIT 1;. 
0e30: 20 7d 0a 7d 20 31 0a 64 6f 5f 74 65 73 74 20 76   }.} 1.do_test v
0e40: 69 65 77 2d 34 2e 33 20 7b 0a 20 20 63 61 74 63  iew-4.3 {.  catc
0e50: 68 73 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20  hsql {.    DROP 
0e60: 54 41 42 4c 45 20 76 31 3b 0a 20 20 7d 0a 7d 20  TABLE v1;.  }.} 
0e70: 7b 31 20 7b 75 73 65 20 44 52 4f 50 20 56 49 45  {1 {use DROP VIE
0e80: 57 20 74 6f 20 64 65 6c 65 74 65 20 76 69 65 77  W to delete view
0e90: 20 76 31 7d 7d 0a 64 6f 5f 74 65 73 74 20 76 69   v1}}.do_test vi
0ea0: 65 77 2d 34 2e 34 20 7b 0a 20 20 65 78 65 63 73  ew-4.4 {.  execs
0eb0: 71 6c 20 7b 0a 20 20 20 20 20 53 45 4c 45 43 54  ql {.     SELECT
0ec0: 20 31 20 46 52 4f 4d 20 76 31 20 4c 49 4d 49 54   1 FROM v1 LIMIT
0ed0: 20 31 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f   1;.  }.} {1}.do
0ee0: 5f 74 65 73 74 20 76 69 65 77 2d 34 2e 35 20 7b  _test view-4.5 {
0ef0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
0f00: 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 69    CREATE INDEX i
0f10: 31 76 31 20 4f 4e 20 76 31 28 78 79 7a 29 3b 0a  1v1 ON v1(xyz);.
0f20: 20 20 7d 0a 7d 20 7b 31 20 7b 76 69 65 77 73 20    }.} {1 {views 
0f30: 6d 61 79 20 6e 6f 74 20 62 65 20 69 6e 64 65 78  may not be index
0f40: 65 64 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 69  ed}}..do_test vi
0f50: 65 77 2d 35 2e 31 20 7b 0a 20 20 65 78 65 63 73  ew-5.1 {.  execs
0f60: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
0f70: 54 41 42 4c 45 20 74 32 28 79 2c 61 29 3b 0a 20  TABLE t2(y,a);. 
0f80: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0f90: 32 20 56 41 4c 55 45 53 28 32 32 2c 32 29 3b 0a  2 VALUES(22,2);.
0fa0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0fb0: 74 32 20 56 41 4c 55 45 53 28 33 33 2c 33 29 3b  t2 VALUES(33,3);
0fc0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0fd0: 20 74 32 20 56 41 4c 55 45 53 28 34 34 2c 34 29   t2 VALUES(44,4)
0fe0: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
0ff0: 4f 20 74 32 20 56 41 4c 55 45 53 28 35 35 2c 35  O t2 VALUES(55,5
1000: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  );.    SELECT * 
1010: 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b  FROM t2;.  }.} {
1020: 32 32 20 32 20 33 33 20 33 20 34 34 20 34 20 35  22 2 33 3 44 4 5
1030: 35 20 35 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65  5 5}.do_test vie
1040: 77 2d 35 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  w-5.2 {.  execsq
1050: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 56  l {.    CREATE V
1060: 49 45 57 20 76 35 20 41 53 0a 20 20 20 20 20 20  IEW v5 AS.      
1070: 53 45 4c 45 43 54 20 74 31 2e 78 20 41 53 20 76  SELECT t1.x AS v
1080: 2c 20 74 32 2e 79 20 41 53 20 77 20 46 52 4f 4d  , t2.y AS w FROM
1090: 20 74 31 20 4a 4f 49 4e 20 74 32 20 55 53 49 4e   t1 JOIN t2 USIN
10a0: 47 28 61 29 3b 0a 20 20 20 20 53 45 4c 45 43 54  G(a);.    SELECT
10b0: 20 2a 20 46 52 4f 4d 20 76 35 3b 0a 20 20 7d 0a   * FROM v5;.  }.
10c0: 7d 20 7b 31 20 32 32 20 34 20 35 35 7d 0a 0a 23  } {1 22 4 55}..#
10d0: 20 56 65 72 69 66 79 20 74 68 61 74 20 74 68 65   Verify that the
10e0: 20 76 69 65 77 20 76 35 20 67 65 74 73 20 66 6c   view v5 gets fl
10f0: 61 74 74 65 6e 65 64 2e 20 20 73 65 65 20 73 71  attened.  see sq
1100: 6c 69 74 65 46 6c 61 74 74 65 6e 53 75 62 71 75  liteFlattenSubqu
1110: 65 72 79 28 29 2e 0a 23 20 54 69 63 6b 65 74 20  ery()..# Ticket 
1120: 23 32 37 32 0a 64 6f 5f 74 65 73 74 20 76 69 65  #272.do_test vie
1130: 77 2d 35 2e 33 20 7b 0a 20 20 6c 73 65 61 72 63  w-5.3 {.  lsearc
1140: 68 20 5b 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  h [execsql {.   
1150: 20 45 58 50 4c 41 49 4e 20 53 45 4c 45 43 54 20   EXPLAIN SELECT 
1160: 2a 20 46 52 4f 4d 20 76 35 3b 0a 20 20 7d 5d 20  * FROM v5;.  }] 
1170: 4f 70 65 6e 54 65 6d 70 0a 7d 20 7b 2d 31 7d 0a  OpenTemp.} {-1}.
1180: 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e 34  do_test view-5.4
1190: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
11a0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
11b0: 20 76 35 20 41 53 20 61 2c 20 74 32 20 41 53 20   v5 AS a, t2 AS 
11c0: 62 20 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b  b WHERE a.w=b.y;
11d0: 0a 20 20 7d 0a 7d 20 7b 31 20 32 32 20 32 32 20  .  }.} {1 22 22 
11e0: 32 20 34 20 35 35 20 35 35 20 35 7d 0a 64 6f 5f  2 4 55 55 5}.do_
11f0: 74 65 73 74 20 76 69 65 77 2d 35 2e 35 20 7b 0a  test view-5.5 {.
1200: 20 20 6c 73 65 61 72 63 68 20 5b 65 78 65 63 73    lsearch [execs
1210: 71 6c 20 7b 0a 20 20 20 20 45 58 50 4c 41 49 4e  ql {.    EXPLAIN
1220: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
1230: 35 20 41 53 20 61 2c 20 74 32 20 41 53 20 62 20  5 AS a, t2 AS b 
1240: 57 48 45 52 45 20 61 2e 77 3d 62 2e 79 3b 0a 20  WHERE a.w=b.y;. 
1250: 20 7d 5d 20 4f 70 65 6e 54 65 6d 70 0a 7d 20 7b   }] OpenTemp.} {
1260: 2d 31 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  -1}.do_test view
1270: 2d 35 2e 36 20 7b 0a 20 20 65 78 65 63 73 71 6c  -5.6 {.  execsql
1280: 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20   {.    SELECT * 
1290: 46 52 4f 4d 20 74 32 20 41 53 20 62 2c 20 76 35  FROM t2 AS b, v5
12a0: 20 41 53 20 61 20 57 48 45 52 45 20 61 2e 77 3d   AS a WHERE a.w=
12b0: 62 2e 79 3b 0a 20 20 7d 0a 7d 20 7b 32 32 20 32  b.y;.  }.} {22 2
12c0: 20 31 20 32 32 20 35 35 20 35 20 34 20 35 35 7d   1 22 55 5 4 55}
12d0: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 35 2e  .do_test view-5.
12e0: 37 20 7b 0a 20 20 6c 73 65 61 72 63 68 20 5b 65  7 {.  lsearch [e
12f0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 45 58 50  xecsql {.    EXP
1300: 4c 41 49 4e 20 53 45 4c 45 43 54 20 2a 20 46 52  LAIN SELECT * FR
1310: 4f 4d 20 74 32 20 41 53 20 62 2c 20 76 35 20 41  OM t2 AS b, v5 A
1320: 53 20 61 20 57 48 45 52 45 20 61 2e 77 3d 62 2e  S a WHERE a.w=b.
1330: 79 3b 0a 20 20 7d 5d 20 4f 70 65 6e 54 65 6d 70  y;.  }] OpenTemp
1340: 0a 7d 20 7b 2d 31 7d 0a 64 6f 5f 74 65 73 74 20  .} {-1}.do_test 
1350: 76 69 65 77 2d 35 2e 38 20 7b 0a 20 20 65 78 65  view-5.8 {.  exe
1360: 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43  csql {.    SELEC
1370: 54 20 2a 20 46 52 4f 4d 20 74 31 20 41 53 20 61  T * FROM t1 AS a
1380: 2c 20 76 35 20 41 53 20 62 2c 20 74 32 20 41 53  , v5 AS b, t2 AS
1390: 20 63 20 57 48 45 52 45 20 61 2e 78 3d 62 2e 76   c WHERE a.x=b.v
13a0: 20 41 4e 44 20 62 2e 77 3d 63 2e 79 3b 0a 20 20   AND b.w=c.y;.  
13b0: 7d 0a 7d 20 7b 31 20 32 20 33 20 34 20 31 20 32  }.} {1 2 3 4 1 2
13c0: 32 20 32 32 20 32 20 34 20 35 20 36 20 37 20 34  2 22 2 4 5 6 7 4
13d0: 20 35 35 20 35 35 20 35 7d 0a 64 6f 5f 74 65 73   55 55 5}.do_tes
13e0: 74 20 76 69 65 77 2d 35 2e 39 20 7b 0a 20 20 6c  t view-5.9 {.  l
13f0: 73 65 61 72 63 68 20 5b 65 78 65 63 73 71 6c 20  search [execsql 
1400: 7b 0a 20 20 20 20 45 58 50 4c 41 49 4e 20 53 45  {.    EXPLAIN SE
1410: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 41  LECT * FROM t1 A
1420: 53 20 61 2c 20 76 35 20 41 53 20 62 2c 20 74 32  S a, v5 AS b, t2
1430: 20 41 53 20 63 20 57 48 45 52 45 20 61 2e 78 3d   AS c WHERE a.x=
1440: 62 2e 76 20 41 4e 44 20 62 2e 77 3d 63 2e 79 3b  b.v AND b.w=c.y;
1450: 0a 20 20 7d 5d 20 4f 70 65 6e 54 65 6d 70 0a 7d  .  }] OpenTemp.}
1460: 20 7b 2d 31 7d 0a 0a 64 6f 5f 74 65 73 74 20 76   {-1}..do_test v
1470: 69 65 77 2d 36 2e 31 20 7b 0a 20 20 65 78 65 63  iew-6.1 {.  exec
1480: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
1490: 20 6d 69 6e 28 78 29 2c 20 6d 69 6e 28 61 29 2c   min(x), min(a),
14a0: 20 6d 69 6e 28 62 29 2c 20 6d 69 6e 28 63 29 2c   min(b), min(c),
14b0: 20 6d 69 6e 28 61 2b 62 2b 63 29 20 46 52 4f 4d   min(a+b+c) FROM
14c0: 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 37 20 38 20   v2;.  }.} {7 8 
14d0: 39 20 31 30 20 32 37 7d 0a 64 6f 5f 74 65 73 74  9 10 27}.do_test
14e0: 20 76 69 65 77 2d 36 2e 32 20 7b 0a 20 20 65 78   view-6.2 {.  ex
14f0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
1500: 43 54 20 6d 61 78 28 78 29 2c 20 6d 61 78 28 61  CT max(x), max(a
1510: 29 2c 20 6d 61 78 28 62 29 2c 20 6d 61 78 28 63  ), max(b), max(c
1520: 29 2c 20 6d 61 78 28 61 2b 62 2b 63 29 20 46 52  ), max(a+b+c) FR
1530: 4f 4d 20 76 32 3b 0a 20 20 7d 0a 7d 20 7b 31 31  OM v2;.  }.} {11
1540: 20 31 32 20 31 33 20 31 34 20 33 39 7d 0a 0a 64   12 13 14 39}..d
1550: 6f 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 31 20  o_test view-7.1 
1560: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1570: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
1580: 65 73 74 31 28 69 64 20 69 6e 74 65 67 65 72 20  est1(id integer 
1590: 70 72 69 6d 61 72 79 20 6b 65 79 2c 20 61 29 3b  primary key, a);
15a0: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
15b0: 45 20 74 65 73 74 32 28 69 64 20 69 6e 74 65 67  E test2(id integ
15c0: 65 72 2c 20 62 29 3b 0a 20 20 20 20 49 4e 53 45  er, b);.    INSE
15d0: 52 54 20 49 4e 54 4f 20 74 65 73 74 31 20 56 41  RT INTO test1 VA
15e0: 4c 55 45 53 28 31 2c 32 29 3b 0a 20 20 20 20 49  LUES(1,2);.    I
15f0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 65 73 74 32  NSERT INTO test2
1600: 20 56 41 4c 55 45 53 28 31 2c 33 29 3b 0a 20 20   VALUES(1,3);.  
1610: 20 20 43 52 45 41 54 45 20 56 49 45 57 20 74 65    CREATE VIEW te
1620: 73 74 20 41 53 0a 20 20 20 20 20 20 53 45 4c 45  st AS.      SELE
1630: 43 54 20 74 65 73 74 31 2e 69 64 2c 20 61 2c 20  CT test1.id, a, 
1640: 62 0a 20 20 20 20 20 20 46 52 4f 4d 20 74 65 73  b.      FROM tes
1650: 74 31 20 4a 4f 49 4e 20 74 65 73 74 32 20 4f 4e  t1 JOIN test2 ON
1660: 20 74 65 73 74 32 2e 69 64 3d 74 65 73 74 31 2e   test2.id=test1.
1670: 69 64 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a  id;.    SELECT *
1680: 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a   FROM test;.  }.
1690: 7d 20 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73  } {1 2 3}.do_tes
16a0: 74 20 76 69 65 77 2d 37 2e 32 20 7b 0a 20 20 64  t view-7.2 {.  d
16b0: 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65  b close.  sqlite
16c0: 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78   db test.db.  ex
16d0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
16e0: 43 54 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a  CT * FROM test;.
16f0: 20 20 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 64 6f    }.} {1 2 3}.do
1700: 5f 74 65 73 74 20 76 69 65 77 2d 37 2e 33 20 7b  _test view-7.3 {
1710: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1720: 20 44 52 4f 50 20 56 49 45 57 20 74 65 73 74 3b   DROP VIEW test;
1730: 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57  .    CREATE VIEW
1740: 20 74 65 73 74 20 41 53 0a 20 20 20 20 20 20 53   test AS.      S
1750: 45 4c 45 43 54 20 74 65 73 74 31 2e 69 64 2c 20  ELECT test1.id, 
1760: 61 2c 20 62 0a 20 20 20 20 20 20 46 52 4f 4d 20  a, b.      FROM 
1770: 74 65 73 74 31 20 4a 4f 49 4e 20 74 65 73 74 32  test1 JOIN test2
1780: 20 55 53 49 4e 47 28 69 64 29 3b 0a 20 20 20 20   USING(id);.    
1790: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 65  SELECT * FROM te
17a0: 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33  st;.  }.} {1 2 3
17b0: 7d 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 37  }.do_test view-7
17c0: 2e 34 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  .4 {.  db close.
17d0: 20 20 73 71 6c 69 74 65 20 64 62 20 74 65 73 74    sqlite db test
17e0: 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  .db.  execsql {.
17f0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1800: 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20 7b 31  M test;.  }.} {1
1810: 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20 76 69   2 3}.do_test vi
1820: 65 77 2d 37 2e 35 20 7b 0a 20 20 65 78 65 63 73  ew-7.5 {.  execs
1830: 71 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 56 49  ql {.    DROP VI
1840: 45 57 20 74 65 73 74 3b 0a 20 20 20 20 43 52 45  EW test;.    CRE
1850: 41 54 45 20 56 49 45 57 20 74 65 73 74 20 41 53  ATE VIEW test AS
1860: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 74 65  .      SELECT te
1870: 73 74 31 2e 69 64 2c 20 61 2c 20 62 0a 20 20 20  st1.id, a, b.   
1880: 20 20 20 46 52 4f 4d 20 74 65 73 74 31 20 4e 41     FROM test1 NA
1890: 54 55 52 41 4c 20 4a 4f 49 4e 20 74 65 73 74 32  TURAL JOIN test2
18a0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
18b0: 52 4f 4d 20 74 65 73 74 3b 0a 20 20 7d 0a 7d 20  ROM test;.  }.} 
18c0: 7b 31 20 32 20 33 7d 0a 64 6f 5f 74 65 73 74 20  {1 2 3}.do_test 
18d0: 76 69 65 77 2d 37 2e 36 20 7b 0a 20 20 64 62 20  view-7.6 {.  db 
18e0: 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 20 64  close.  sqlite d
18f0: 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63  b test.db.  exec
1900: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
1910: 20 2a 20 46 52 4f 4d 20 74 65 73 74 3b 0a 20 20   * FROM test;.  
1920: 7d 0a 7d 20 7b 31 20 32 20 33 7d 0a 0a 64 6f 5f  }.} {1 2 3}..do_
1930: 74 65 73 74 20 76 69 65 77 2d 38 2e 31 20 7b 0a  test view-8.1 {.
1940: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1950: 43 52 45 41 54 45 20 56 49 45 57 20 76 36 20 41  CREATE VIEW v6 A
1960: 53 20 53 45 4c 45 43 54 20 70 71 72 2c 20 78 79  S SELECT pqr, xy
1970: 7a 20 46 52 4f 4d 20 76 31 3b 0a 20 20 20 20 53  z FROM v1;.    S
1980: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 36 20  ELECT * FROM v6 
1990: 4f 52 44 45 52 20 42 59 20 78 79 7a 3b 0a 20 20  ORDER BY xyz;.  
19a0: 7d 0a 7d 20 7b 37 20 32 20 31 33 20 35 20 31 39  }.} {7 2 13 5 19
19b0: 20 38 20 32 37 20 31 32 7d 0a 64 6f 5f 74 65 73   8 27 12}.do_tes
19c0: 74 20 76 69 65 77 2d 38 2e 32 20 7b 0a 20 20 64  t view-8.2 {.  d
19d0: 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65  b close.  sqlite
19e0: 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78   db test.db.  ex
19f0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45  ecsql {.    SELE
1a00: 43 54 20 2a 20 46 52 4f 4d 20 76 36 20 4f 52 44  CT * FROM v6 ORD
1a10: 45 52 20 42 59 20 78 79 7a 3b 0a 20 20 7d 0a 7d  ER BY xyz;.  }.}
1a20: 20 7b 37 20 32 20 31 33 20 35 20 31 39 20 38 20   {7 2 13 5 19 8 
1a30: 32 37 20 31 32 7d 0a 64 6f 5f 74 65 73 74 20 76  27 12}.do_test v
1a40: 69 65 77 2d 38 2e 33 20 7b 0a 20 20 65 78 65 63  iew-8.3 {.  exec
1a50: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
1a60: 20 56 49 45 57 20 76 37 20 41 53 20 53 45 4c 45   VIEW v7 AS SELE
1a70: 43 54 20 70 71 72 2b 78 79 7a 20 41 53 20 61 20  CT pqr+xyz AS a 
1a80: 46 52 4f 4d 20 76 36 3b 0a 20 20 20 20 53 45 4c  FROM v6;.    SEL
1a90: 45 43 54 20 2a 20 46 52 4f 4d 20 76 37 20 4f 52  ECT * FROM v7 OR
1aa0: 44 45 52 20 42 59 20 61 3b 0a 20 20 7d 0a 7d 20  DER BY a;.  }.} 
1ab0: 7b 39 20 31 38 20 32 37 20 33 39 7d 0a 64 6f 5f  {9 18 27 39}.do_
1ac0: 74 65 73 74 20 76 69 65 77 2d 38 2e 34 20 7b 0a  test view-8.4 {.
1ad0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1ae0: 43 52 45 41 54 45 20 56 49 45 57 20 76 38 20 41  CREATE VIEW v8 A
1af0: 53 20 53 45 4c 45 43 54 20 6d 61 78 28 63 6e 74  S SELECT max(cnt
1b00: 29 20 41 53 20 6d 78 20 46 52 4f 4d 0a 20 20 20  ) AS mx FROM.   
1b10: 20 20 20 28 53 45 4c 45 43 54 20 61 25 32 20 41     (SELECT a%2 A
1b20: 53 20 65 6f 2c 20 63 6f 75 6e 74 28 2a 29 20 41  S eo, count(*) A
1b30: 53 20 63 6e 74 20 46 52 4f 4d 20 74 31 20 47 52  S cnt FROM t1 GR
1b40: 4f 55 50 20 42 59 20 65 6f 29 3b 0a 20 20 20 20  OUP BY eo);.    
1b50: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 38  SELECT * FROM v8
1b60: 3b 0a 20 20 7d 0a 7d 20 33 0a 64 6f 5f 74 65 73  ;.  }.} 3.do_tes
1b70: 74 20 76 69 65 77 2d 38 2e 35 20 7b 0a 20 20 65  t view-8.5 {.  e
1b80: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
1b90: 45 43 54 20 6d 78 2b 31 30 2c 20 6d 78 2a 32 20  ECT mx+10, mx*2 
1ba0: 46 52 4f 4d 20 76 38 3b 0a 20 20 7d 0a 7d 20 7b  FROM v8;.  }.} {
1bb0: 31 33 20 36 7d 0a 64 6f 5f 74 65 73 74 20 76 69  13 6}.do_test vi
1bc0: 65 77 2d 38 2e 36 20 7b 0a 20 20 65 78 65 63 73  ew-8.6 {.  execs
1bd0: 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  ql {.    SELECT 
1be0: 6d 78 2b 31 30 2c 20 70 71 72 20 46 52 4f 4d 20  mx+10, pqr FROM 
1bf0: 76 36 2c 20 76 38 20 57 48 45 52 45 20 78 79 7a  v6, v8 WHERE xyz
1c00: 3d 32 3b 0a 20 20 7d 0a 7d 20 7b 31 33 20 37 7d  =2;.  }.} {13 7}
1c10: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 38 2e  .do_test view-8.
1c20: 37 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  7 {.  execsql {.
1c30: 20 20 20 20 53 45 4c 45 43 54 20 6d 78 2b 31 30      SELECT mx+10
1c40: 2c 20 70 71 72 20 46 52 4f 4d 20 76 36 2c 20 76  , pqr FROM v6, v
1c50: 38 20 57 48 45 52 45 20 78 79 7a 3e 32 3b 0a 20  8 WHERE xyz>2;. 
1c60: 20 7d 0a 7d 20 7b 31 33 20 31 33 20 31 33 20 31   }.} {13 13 13 1
1c70: 39 20 31 33 20 32 37 7d 0a 0a 23 20 54 65 73 74  9 13 27}..# Test
1c80: 73 20 66 6f 72 20 61 20 62 75 67 20 66 6f 75 6e  s for a bug foun
1c90: 64 20 62 79 20 4d 69 63 68 69 65 6c 20 64 65 20  d by Michiel de 
1ca0: 57 69 74 20 69 6e 76 6f 6c 76 69 6e 67 20 4f 52  Wit involving OR
1cb0: 44 45 52 20 42 59 20 69 6e 20 61 20 56 49 45 57  DER BY in a VIEW
1cc0: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 69 65 77  ..#.do_test view
1cd0: 2d 39 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -9.1 {.  execsql
1ce0: 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e   {.    INSERT IN
1cf0: 54 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46  TO t2 SELECT * F
1d00: 52 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c 35  ROM t2 WHERE a<5
1d10: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
1d20: 4f 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52  O t2 SELECT * FR
1d30: 4f 4d 20 74 32 20 57 48 45 52 45 20 61 3c 34 3b  OM t2 WHERE a<4;
1d40: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
1d50: 20 74 32 20 53 45 4c 45 43 54 20 2a 20 46 52 4f   t2 SELECT * FRO
1d60: 4d 20 74 32 20 57 48 45 52 45 20 61 3c 33 3b 0a  M t2 WHERE a<3;.
1d70: 20 20 20 20 53 45 4c 45 43 54 20 44 49 53 54 49      SELECT DISTI
1d80: 4e 43 54 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f  NCT count(*) FRO
1d90: 4d 20 74 32 20 47 52 4f 55 50 20 42 59 20 61 20  M t2 GROUP BY a 
1da0: 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20 7d 0a  ORDER BY 1;.  }.
1db0: 7d 20 7b 31 20 32 20 34 20 38 7d 0a 64 6f 5f 74  } {1 2 4 8}.do_t
1dc0: 65 73 74 20 76 69 65 77 2d 39 2e 32 20 7b 0a 20  est view-9.2 {. 
1dd0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53   execsql {.    S
1de0: 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20 63  ELECT DISTINCT c
1df0: 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32 20  ount(*) FROM t2 
1e00: 47 52 4f 55 50 20 42 59 20 61 20 4f 52 44 45 52  GROUP BY a ORDER
1e10: 20 42 59 20 31 20 4c 49 4d 49 54 20 33 3b 0a 20   BY 1 LIMIT 3;. 
1e20: 20 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f 5f   }.} {1 2 4}.do_
1e30: 74 65 73 74 20 76 69 65 77 2d 39 2e 33 20 7b 0a  test view-9.3 {.
1e40: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1e50: 43 52 45 41 54 45 20 56 49 45 57 20 76 39 20 41  CREATE VIEW v9 A
1e60: 53 20 0a 20 20 20 20 20 20 20 53 45 4c 45 43 54  S .       SELECT
1e70: 20 44 49 53 54 49 4e 43 54 20 63 6f 75 6e 74 28   DISTINCT count(
1e80: 2a 29 20 46 52 4f 4d 20 74 32 20 47 52 4f 55 50  *) FROM t2 GROUP
1e90: 20 42 59 20 61 20 4f 52 44 45 52 20 42 59 20 31   BY a ORDER BY 1
1ea0: 20 4c 49 4d 49 54 20 33 3b 0a 20 20 20 20 53 45   LIMIT 3;.    SE
1eb0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 39 3b 0a  LECT * FROM v9;.
1ec0: 20 20 7d 0a 7d 20 7b 31 20 32 20 34 7d 0a 64 6f    }.} {1 2 4}.do
1ed0: 5f 74 65 73 74 20 76 69 65 77 2d 39 2e 34 20 7b  _test view-9.4 {
1ee0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1ef0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76   SELECT * FROM v
1f00: 39 20 4f 52 44 45 52 20 42 59 20 31 20 44 45 53  9 ORDER BY 1 DES
1f10: 43 3b 0a 20 20 7d 0a 7d 20 7b 34 20 32 20 31 7d  C;.  }.} {4 2 1}
1f20: 0a 64 6f 5f 74 65 73 74 20 76 69 65 77 2d 39 2e  .do_test view-9.
1f30: 35 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  5 {.  execsql {.
1f40: 20 20 20 20 43 52 45 41 54 45 20 56 49 45 57 20      CREATE VIEW 
1f50: 76 31 30 20 41 53 20 0a 20 20 20 20 20 20 20 53  v10 AS .       S
1f60: 45 4c 45 43 54 20 44 49 53 54 49 4e 43 54 20 61  ELECT DISTINCT a
1f70: 2c 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20  , count(*) FROM 
1f80: 74 32 20 47 52 4f 55 50 20 42 59 20 61 20 4f 52  t2 GROUP BY a OR
1f90: 44 45 52 20 42 59 20 32 20 4c 49 4d 49 54 20 33  DER BY 2 LIMIT 3
1fa0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  ;.    SELECT * F
1fb0: 52 4f 4d 20 76 31 30 3b 0a 20 20 7d 0a 7d 20 7b  ROM v10;.  }.} {
1fc0: 35 20 31 20 34 20 32 20 33 20 34 7d 0a 64 6f 5f  5 1 4 2 3 4}.do_
1fd0: 74 65 73 74 20 76 69 65 77 2d 39 2e 36 20 7b 0a  test view-9.6 {.
1fe0: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
1ff0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 76 31  SELECT * FROM v1
2000: 30 20 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20  0 ORDER BY 1;.  
2010: 7d 0a 7d 20 7b 33 20 34 20 34 20 32 20 35 20 31  }.} {3 4 4 2 5 1
2020: 7d 0a 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a  }...finish_test.