/ Hex Artifact Content
Login

Artifact 7fd2ef598cfabb6b9ff6ac13973b91d0527df49d:


0000: 23 20 54 68 65 20 61 75 74 68 6f 72 20 64 69 73  # The author dis
0010: 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68 74  claims copyright
0020: 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65 20   to this source 
0030: 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65 20  code.  In place 
0040: 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f 74  of.# a legal not
0050: 69 63 65 2c 20 68 65 72 65 20 69 73 20 61 20 62  ice, here is a b
0060: 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20 20  lessing:.#.#    
0070: 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20  May you do good 
0080: 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23 20  and not evil..# 
0090: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00a0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00b0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00c0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20 20  give others..#  
00d0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
00e0: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
00f0: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0100: 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a 2a  ou give..#.#****
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 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 0a 23 20 54 68 69 73 20 66 69 6c 65 20  ***.# This file 
0160: 69 6d 70 6c 65 6d 65 6e 74 73 20 72 65 67 72 65  implements regre
0170: 73 73 69 6f 6e 20 74 65 73 74 73 20 66 6f 72 20  ssion tests for 
0180: 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79 2e 20  SQLite library. 
0190: 20 54 68 65 0a 23 20 66 6f 63 75 73 20 6f 66 20   The.# focus of 
01a0: 74 68 69 73 20 66 69 6c 65 20 69 73 20 74 65 73  this file is tes
01b0: 74 69 6e 67 20 63 6f 6d 70 75 74 65 20 53 45 4c  ting compute SEL
01c0: 45 43 54 20 73 74 61 74 65 6d 65 6e 74 73 20 61  ECT statements a
01d0: 6e 64 20 6e 65 73 74 65 64 0a 23 20 76 69 65 77  nd nested.# view
01e0: 73 2e 0a 23 0a 23 20 24 49 64 3a 20 73 65 6c 65  s..#.# $Id: sele
01f0: 63 74 37 2e 74 65 73 74 2c 76 20 31 2e 31 31 20  ct7.test,v 1.11 
0200: 32 30 30 37 2f 30 39 2f 31 32 20 31 37 3a 30 31  2007/09/12 17:01
0210: 3a 34 35 20 64 61 6e 69 65 6c 6b 31 39 37 37 20  :45 danielk1977 
0220: 45 78 70 20 24 0a 0a 0a 73 65 74 20 74 65 73 74  Exp $...set test
0230: 64 69 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d  dir [file dirnam
0240: 65 20 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65  e $argv0].source
0250: 20 24 74 65 73 74 64 69 72 2f 74 65 73 74 65 72   $testdir/tester
0260: 2e 74 63 6c 0a 0a 69 66 63 61 70 61 62 6c 65 20  .tcl..ifcapable 
0270: 63 6f 6d 70 6f 75 6e 64 20 7b 0a 0a 23 20 41 20  compound {..# A 
0280: 33 2d 77 61 79 20 49 4e 54 45 52 53 45 43 54 2e  3-way INTERSECT.
0290: 20 20 54 69 63 6b 65 74 20 23 38 37 35 0a 69 66    Ticket #875.if
02a0: 63 61 70 61 62 6c 65 20 74 65 6d 70 64 62 20 7b  capable tempdb {
02b0: 0a 20 20 64 6f 5f 74 65 73 74 20 73 65 6c 65 63  .  do_test selec
02c0: 74 37 2d 31 2e 31 20 7b 0a 20 20 20 20 65 78 65  t7-1.1 {.    exe
02d0: 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 63 72 65  csql {.      cre
02e0: 61 74 65 20 74 65 6d 70 20 74 61 62 6c 65 20 74  ate temp table t
02f0: 31 28 78 29 3b 0a 20 20 20 20 20 20 69 6e 73 65  1(x);.      inse
0300: 72 74 20 69 6e 74 6f 20 74 31 20 76 61 6c 75 65  rt into t1 value
0310: 73 28 27 61 6d 78 27 29 3b 0a 20 20 20 20 20 20  s('amx');.      
0320: 69 6e 73 65 72 74 20 69 6e 74 6f 20 74 31 20 76  insert into t1 v
0330: 61 6c 75 65 73 28 27 61 6e 78 27 29 3b 0a 20 20  alues('anx');.  
0340: 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20      insert into 
0350: 74 31 20 76 61 6c 75 65 73 28 27 61 6d 79 27 29  t1 values('amy')
0360: 3b 0a 20 20 20 20 20 20 69 6e 73 65 72 74 20 69  ;.      insert i
0370: 6e 74 6f 20 74 31 20 76 61 6c 75 65 73 28 27 62  nto t1 values('b
0380: 6d 79 27 29 3b 0a 20 20 20 20 20 20 73 65 6c 65  my');.      sele
0390: 63 74 20 2a 20 66 72 6f 6d 20 74 31 20 77 68 65  ct * from t1 whe
03a0: 72 65 20 78 20 6c 69 6b 65 20 27 61 5f 5f 27 0a  re x like 'a__'.
03b0: 20 20 20 20 20 20 20 20 69 6e 74 65 72 73 65 63          intersec
03c0: 74 20 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d 20  t select * from 
03d0: 74 31 20 77 68 65 72 65 20 78 20 6c 69 6b 65 20  t1 where x like 
03e0: 27 5f 6d 5f 27 0a 20 20 20 20 20 20 20 20 69 6e  '_m_'.        in
03f0: 74 65 72 73 65 63 74 20 73 65 6c 65 63 74 20 2a  tersect select *
0400: 20 66 72 6f 6d 20 74 31 20 77 68 65 72 65 20 78   from t1 where x
0410: 20 6c 69 6b 65 20 27 5f 5f 78 27 3b 0a 20 20 20   like '__x';.   
0420: 20 7d 0a 20 20 7d 20 7b 61 6d 78 7d 0a 7d 0a 0a   }.  } {amx}.}..
0430: 0a 23 20 4e 65 73 74 65 64 20 76 69 65 77 73 20  .# Nested views 
0440: 64 6f 20 6e 6f 74 20 68 61 6e 64 6c 65 20 2a 20  do not handle * 
0450: 70 72 6f 70 65 72 6c 79 2e 20 20 54 69 63 6b 65  properly.  Ticke
0460: 74 20 23 38 32 36 2e 0a 23 0a 69 66 63 61 70 61  t #826..#.ifcapa
0470: 62 6c 65 20 76 69 65 77 20 7b 0a 64 6f 5f 74 65  ble view {.do_te
0480: 73 74 20 73 65 6c 65 63 74 37 2d 32 2e 31 20 7b  st select7-2.1 {
0490: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
04a0: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 78 28   CREATE TABLE x(
04b0: 69 64 20 69 6e 74 65 67 65 72 20 70 72 69 6d 61  id integer prima
04c0: 72 79 20 6b 65 79 2c 20 61 20 54 45 58 54 20 4e  ry key, a TEXT N
04d0: 55 4c 4c 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  ULL);.    INSERT
04e0: 20 49 4e 54 4f 20 78 20 28 61 29 20 56 41 4c 55   INTO x (a) VALU
04f0: 45 53 20 28 27 66 69 72 73 74 27 29 3b 0a 20 20  ES ('first');.  
0500: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
0510: 65 6d 70 78 28 69 64 20 69 6e 74 65 67 65 72 20  empx(id integer 
0520: 70 72 69 6d 61 72 79 20 6b 65 79 2c 20 61 20 54  primary key, a T
0530: 45 58 54 20 4e 55 4c 4c 29 3b 0a 20 20 20 20 49  EXT NULL);.    I
0540: 4e 53 45 52 54 20 49 4e 54 4f 20 74 65 6d 70 78  NSERT INTO tempx
0550: 20 28 61 29 20 56 41 4c 55 45 53 20 28 27 74 2d   (a) VALUES ('t-
0560: 66 69 72 73 74 27 29 3b 0a 20 20 20 20 43 52 45  first');.    CRE
0570: 41 54 45 20 56 49 45 57 20 74 76 31 20 41 53 20  ATE VIEW tv1 AS 
0580: 53 45 4c 45 43 54 20 78 2e 69 64 2c 20 74 78 2e  SELECT x.id, tx.
0590: 69 64 20 46 52 4f 4d 20 78 20 4a 4f 49 4e 20 74  id FROM x JOIN t
05a0: 65 6d 70 78 20 74 78 20 4f 4e 20 74 78 2e 69 64  empx tx ON tx.id
05b0: 3d 78 2e 69 64 3b 0a 20 20 20 20 43 52 45 41 54  =x.id;.    CREAT
05c0: 45 20 56 49 45 57 20 74 76 31 62 20 41 53 20 53  E VIEW tv1b AS S
05d0: 45 4c 45 43 54 20 78 2e 69 64 2c 20 74 78 2e 69  ELECT x.id, tx.i
05e0: 64 20 46 52 4f 4d 20 78 20 4a 4f 49 4e 20 74 65  d FROM x JOIN te
05f0: 6d 70 78 20 74 78 20 6f 6e 20 74 78 2e 69 64 3d  mpx tx on tx.id=
0600: 78 2e 69 64 3b 0a 20 20 20 20 43 52 45 41 54 45  x.id;.    CREATE
0610: 20 56 49 45 57 20 74 76 32 20 41 53 20 53 45 4c   VIEW tv2 AS SEL
0620: 45 43 54 20 2a 20 46 52 4f 4d 20 74 76 31 20 55  ECT * FROM tv1 U
0630: 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52  NION SELECT * FR
0640: 4f 4d 20 74 76 31 62 3b 0a 20 20 20 20 53 45 4c  OM tv1b;.    SEL
0650: 45 43 54 20 2a 20 46 52 4f 4d 20 74 76 32 3b 0a  ECT * FROM tv2;.
0660: 20 20 7d 0a 7d 20 7b 31 20 31 7d 0a 7d 20 3b 23    }.} {1 1}.} ;#
0670: 20 69 66 63 61 70 61 62 6c 65 20 76 69 65 77 0a   ifcapable view.
0680: 0a 7d 20 3b 23 20 69 66 63 61 70 61 62 6c 65 20  .} ;# ifcapable 
0690: 63 6f 6d 70 6f 75 6e 64 0a 0a 23 20 44 6f 20 6e  compound..# Do n
06a0: 6f 74 20 61 6c 6c 6f 77 20 47 52 4f 55 50 20 42  ot allow GROUP B
06b0: 59 20 77 69 74 68 6f 75 74 20 61 6e 20 61 67 67  Y without an agg
06c0: 72 65 67 61 74 65 2e 20 54 69 63 6b 65 74 20 23  regate. Ticket #
06d0: 31 30 33 39 2e 0a 23 0a 23 20 43 68 61 6e 67 65  1039..#.# Change
06e0: 3a 20 66 6f 72 63 65 20 61 6e 79 20 71 75 65 72  : force any quer
06f0: 79 20 77 69 74 68 20 61 20 47 52 4f 55 50 20 42  y with a GROUP B
0700: 59 20 63 6c 61 75 73 65 20 74 6f 20 62 65 20 70  Y clause to be p
0710: 72 6f 63 65 73 73 65 64 20 61 73 0a 23 20 61 6e  rocessed as.# an
0720: 20 61 67 67 72 65 67 61 74 65 20 71 75 65 72 79   aggregate query
0730: 2c 20 77 68 65 74 68 65 72 20 69 74 20 63 6f 6e  , whether it con
0740: 74 61 69 6e 73 20 61 67 67 72 65 67 61 74 65 73  tains aggregates
0750: 20 6f 72 20 6e 6f 74 2e 0a 23 0a 69 66 63 61 70   or not..#.ifcap
0760: 61 62 6c 65 20 73 75 62 71 75 65 72 79 20 7b 0a  able subquery {.
0770: 20 20 23 20 64 6f 5f 74 65 73 74 20 73 65 6c 65    # do_test sele
0780: 63 74 37 2d 33 2e 31 20 7b 0a 20 20 23 20 20 20  ct7-3.1 {.  #   
0790: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 23 20 20  catchsql {.  #  
07a0: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
07b0: 20 28 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20   (SELECT * FROM 
07c0: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 29 20 47  sqlite_master) G
07d0: 52 4f 55 50 20 42 59 20 6e 61 6d 65 0a 20 20 23  ROUP BY name.  #
07e0: 20 20 20 7d 0a 20 20 23 20 7d 20 7b 31 20 7b 47     }.  # } {1 {G
07f0: 52 4f 55 50 20 42 59 20 6d 61 79 20 6f 6e 6c 79  ROUP BY may only
0800: 20 62 65 20 75 73 65 64 20 6f 6e 20 61 67 67 72   be used on aggr
0810: 65 67 61 74 65 20 71 75 65 72 69 65 73 7d 7d 0a  egate queries}}.
0820: 20 20 64 6f 5f 74 65 73 74 20 73 65 6c 65 63 74    do_test select
0830: 37 2d 33 2e 31 20 7b 0a 20 20 20 20 63 61 74 63  7-3.1 {.    catc
0840: 68 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c  hsql {.      SEL
0850: 45 43 54 20 2a 20 46 52 4f 4d 20 28 53 45 4c 45  ECT * FROM (SELE
0860: 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65  CT * FROM sqlite
0870: 5f 6d 61 73 74 65 72 29 20 47 52 4f 55 50 20 42  _master) GROUP B
0880: 59 20 6e 61 6d 65 0a 20 20 20 20 7d 0a 20 20 7d  Y name.    }.  }
0890: 20 5b 6c 69 73 74 20 30 20 5b 65 78 65 63 73 71   [list 0 [execsq
08a0: 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  l {SELECT * FROM
08b0: 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 4f   sqlite_master O
08c0: 52 44 45 52 20 42 59 20 6e 61 6d 65 7d 5d 5d 0a  RDER BY name}]].
08d0: 7d 0a 0a 23 20 54 69 63 6b 65 74 20 23 32 30 31  }..# Ticket #201
08e0: 38 20 2d 20 4d 61 6b 65 20 73 75 72 65 20 6e 61  8 - Make sure na
08f0: 6d 65 73 20 61 72 65 20 72 65 73 6f 6c 76 65 64  mes are resolved
0900: 20 63 6f 72 72 65 63 74 6c 79 20 6f 6e 20 61 6c   correctly on al
0910: 6c 0a 23 20 53 45 4c 45 43 54 20 73 74 61 74 65  l.# SELECT state
0920: 6d 65 6e 74 73 20 6f 66 20 61 20 63 6f 6d 70 6f  ments of a compo
0930: 75 6e 64 20 73 75 62 71 75 65 72 79 2e 0a 23 0a  und subquery..#.
0940: 69 66 63 61 70 61 62 6c 65 20 7b 73 75 62 71 75  ifcapable {subqu
0950: 65 72 79 20 26 26 20 63 6f 6d 70 6f 75 6e 64 7d  ery && compound}
0960: 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 73 65 6c   {.  do_test sel
0970: 65 63 74 37 2d 34 2e 31 20 7b 0a 20 20 20 20 65  ect7-4.1 {.    e
0980: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 43  xecsql {.      C
0990: 52 45 41 54 45 20 54 41 42 4c 45 20 49 46 20 4e  REATE TABLE IF N
09a0: 4f 54 20 45 58 49 53 54 53 20 70 68 6f 74 6f 28  OT EXISTS photo(
09b0: 70 6b 20 69 6e 74 65 67 65 72 20 70 72 69 6d 61  pk integer prima
09c0: 72 79 20 6b 65 79 2c 20 78 29 3b 0a 20 20 20 20  ry key, x);.    
09d0: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 49    CREATE TABLE I
09e0: 46 20 4e 4f 54 20 45 58 49 53 54 53 20 74 61 67  F NOT EXISTS tag
09f0: 28 70 6b 20 69 6e 74 65 67 65 72 20 70 72 69 6d  (pk integer prim
0a00: 61 72 79 20 6b 65 79 2c 20 66 6b 20 69 6e 74 2c  ary key, fk int,
0a10: 20 6e 61 6d 65 29 3b 0a 20 20 20 20 0a 20 20 20   name);.    .   
0a20: 20 20 20 53 45 4c 45 43 54 20 50 2e 70 6b 20 66     SELECT P.pk f
0a30: 72 6f 6d 20 50 48 4f 54 4f 20 50 20 57 48 45 52  rom PHOTO P WHER
0a40: 45 20 4e 4f 54 20 45 58 49 53 54 53 20 28 20 0a  E NOT EXISTS ( .
0a50: 20 20 20 20 20 20 20 20 20 20 20 53 45 4c 45 43             SELEC
0a60: 54 20 54 32 2e 70 6b 20 66 72 6f 6d 20 54 41 47  T T2.pk from TAG
0a70: 20 54 32 20 57 48 45 52 45 20 54 32 2e 66 6b 20   T2 WHERE T2.fk 
0a80: 3d 20 50 2e 70 6b 20 0a 20 20 20 20 20 20 20 20  = P.pk .        
0a90: 20 20 20 45 58 43 45 50 54 20 0a 20 20 20 20 20     EXCEPT .     
0aa0: 20 20 20 20 20 20 53 45 4c 45 43 54 20 54 33 2e        SELECT T3.
0ab0: 70 6b 20 66 72 6f 6d 20 54 41 47 20 54 33 20 57  pk from TAG T3 W
0ac0: 48 45 52 45 20 54 33 2e 66 6b 20 3d 20 50 2e 70  HERE T3.fk = P.p
0ad0: 6b 20 41 4e 44 20 54 33 2e 6e 61 6d 65 20 4c 49  k AND T3.name LI
0ae0: 4b 45 20 27 25 66 6f 6f 25 27 0a 20 20 20 20 20  KE '%foo%'.     
0af0: 20 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7d   );.    }.  } {}
0b00: 0a 20 20 64 6f 5f 74 65 73 74 20 73 65 6c 65 63  .  do_test selec
0b10: 74 37 2d 34 2e 32 20 7b 0a 20 20 20 20 65 78 65  t7-4.2 {.    exe
0b20: 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 49 4e 53  csql {.      INS
0b30: 45 52 54 20 49 4e 54 4f 20 70 68 6f 74 6f 20 56  ERT INTO photo V
0b40: 41 4c 55 45 53 28 31 2c 31 29 3b 0a 20 20 20 20  ALUES(1,1);.    
0b50: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 70 68    INSERT INTO ph
0b60: 6f 74 6f 20 56 41 4c 55 45 53 28 32 2c 32 29 3b  oto VALUES(2,2);
0b70: 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e  .      INSERT IN
0b80: 54 4f 20 70 68 6f 74 6f 20 56 41 4c 55 45 53 28  TO photo VALUES(
0b90: 33 2c 33 29 3b 0a 20 20 20 20 20 20 49 4e 53 45  3,3);.      INSE
0ba0: 52 54 20 49 4e 54 4f 20 74 61 67 20 56 41 4c 55  RT INTO tag VALU
0bb0: 45 53 28 31 31 2c 31 2c 27 6f 6e 65 27 29 3b 0a  ES(11,1,'one');.
0bc0: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
0bd0: 4f 20 74 61 67 20 56 41 4c 55 45 53 28 31 32 2c  O tag VALUES(12,
0be0: 31 2c 27 74 77 6f 27 29 3b 0a 20 20 20 20 20 20  1,'two');.      
0bf0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 61 67 20  INSERT INTO tag 
0c00: 56 41 4c 55 45 53 28 32 31 2c 31 2c 27 6f 6e 65  VALUES(21,1,'one
0c10: 2d 62 27 29 3b 0a 20 20 20 20 20 20 53 45 4c 45  -b');.      SELE
0c20: 43 54 20 50 2e 70 6b 20 66 72 6f 6d 20 50 48 4f  CT P.pk from PHO
0c30: 54 4f 20 50 20 57 48 45 52 45 20 4e 4f 54 20 45  TO P WHERE NOT E
0c40: 58 49 53 54 53 20 28 20 0a 20 20 20 20 20 20 20  XISTS ( .       
0c50: 20 20 20 20 53 45 4c 45 43 54 20 54 32 2e 70 6b      SELECT T2.pk
0c60: 20 66 72 6f 6d 20 54 41 47 20 54 32 20 57 48 45   from TAG T2 WHE
0c70: 52 45 20 54 32 2e 66 6b 20 3d 20 50 2e 70 6b 20  RE T2.fk = P.pk 
0c80: 0a 20 20 20 20 20 20 20 20 20 20 20 45 58 43 45  .           EXCE
0c90: 50 54 20 0a 20 20 20 20 20 20 20 20 20 20 20 53  PT .           S
0ca0: 45 4c 45 43 54 20 54 33 2e 70 6b 20 66 72 6f 6d  ELECT T3.pk from
0cb0: 20 54 41 47 20 54 33 20 57 48 45 52 45 20 54 33   TAG T3 WHERE T3
0cc0: 2e 66 6b 20 3d 20 50 2e 70 6b 20 41 4e 44 20 54  .fk = P.pk AND T
0cd0: 33 2e 6e 61 6d 65 20 4c 49 4b 45 20 27 25 66 6f  3.name LIKE '%fo
0ce0: 6f 25 27 0a 20 20 20 20 20 20 29 3b 0a 20 20 20  o%'.      );.   
0cf0: 20 7d 0a 20 20 7d 20 7b 32 20 33 7d 0a 7d 0a 0a   }.  } {2 3}.}..
0d00: 23 20 74 69 63 6b 65 74 20 23 32 33 34 37 0a 23  # ticket #2347.#
0d10: 0a 69 66 63 61 70 61 62 6c 65 20 7b 73 75 62 71  .ifcapable {subq
0d20: 75 65 72 79 20 26 26 20 63 6f 6d 70 6f 75 6e 64  uery && compound
0d30: 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 73 65  } {.  do_test se
0d40: 6c 65 63 74 37 2d 35 2e 31 20 7b 0a 20 20 20 20  lect7-5.1 {.    
0d50: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 20  catchsql {.     
0d60: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
0d70: 28 61 2c 62 29 3b 0a 20 20 20 20 20 20 53 45 4c  (a,b);.      SEL
0d80: 45 43 54 20 35 20 49 4e 20 28 53 45 4c 45 43 54  ECT 5 IN (SELECT
0d90: 20 61 2c 62 20 46 52 4f 4d 20 74 32 29 3b 0a 20   a,b FROM t2);. 
0da0: 20 20 20 7d 0a 20 20 7d 20 5b 6c 69 73 74 20 31     }.  } [list 1
0db0: 20 5c 0a 20 20 20 20 20 7b 6f 6e 6c 79 20 61 20   \.     {only a 
0dc0: 73 69 6e 67 6c 65 20 72 65 73 75 6c 74 20 61 6c  single result al
0dd0: 6c 6f 77 65 64 20 66 6f 72 20 61 20 53 45 4c 45  lowed for a SELE
0de0: 43 54 20 74 68 61 74 20 69 73 20 70 61 72 74 20  CT that is part 
0df0: 6f 66 20 61 6e 20 65 78 70 72 65 73 73 69 6f 6e  of an expression
0e00: 7d 5d 0a 20 20 64 6f 5f 74 65 73 74 20 73 65 6c  }].  do_test sel
0e10: 65 63 74 37 2d 35 2e 32 20 7b 0a 20 20 20 20 63  ect7-5.2 {.    c
0e20: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 20 20  atchsql {.      
0e30: 53 45 4c 45 43 54 20 35 20 49 4e 20 28 53 45 4c  SELECT 5 IN (SEL
0e40: 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 29 3b 0a  ECT * FROM t2);.
0e50: 20 20 20 20 7d 0a 20 20 7d 20 5b 6c 69 73 74 20      }.  } [list 
0e60: 31 20 5c 0a 20 20 20 20 20 7b 6f 6e 6c 79 20 61  1 \.     {only a
0e70: 20 73 69 6e 67 6c 65 20 72 65 73 75 6c 74 20 61   single result a
0e80: 6c 6c 6f 77 65 64 20 66 6f 72 20 61 20 53 45 4c  llowed for a SEL
0e90: 45 43 54 20 74 68 61 74 20 69 73 20 70 61 72 74  ECT that is part
0ea0: 20 6f 66 20 61 6e 20 65 78 70 72 65 73 73 69 6f   of an expressio
0eb0: 6e 7d 5d 0a 20 20 64 6f 5f 74 65 73 74 20 73 65  n}].  do_test se
0ec0: 6c 65 63 74 37 2d 35 2e 33 20 7b 0a 20 20 20 20  lect7-5.3 {.    
0ed0: 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 20  catchsql {.     
0ee0: 20 53 45 4c 45 43 54 20 35 20 49 4e 20 28 53 45   SELECT 5 IN (SE
0ef0: 4c 45 43 54 20 61 2c 62 20 46 52 4f 4d 20 74 32  LECT a,b FROM t2
0f00: 20 55 4e 49 4f 4e 20 53 45 4c 45 43 54 20 62 2c   UNION SELECT b,
0f10: 61 20 46 52 4f 4d 20 74 32 29 3b 0a 20 20 20 20  a FROM t2);.    
0f20: 7d 0a 20 20 7d 20 5b 6c 69 73 74 20 31 20 5c 0a  }.  } [list 1 \.
0f30: 20 20 20 20 20 7b 6f 6e 6c 79 20 61 20 73 69 6e       {only a sin
0f40: 67 6c 65 20 72 65 73 75 6c 74 20 61 6c 6c 6f 77  gle result allow
0f50: 65 64 20 66 6f 72 20 61 20 53 45 4c 45 43 54 20  ed for a SELECT 
0f60: 74 68 61 74 20 69 73 20 70 61 72 74 20 6f 66 20  that is part of 
0f70: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 7d 5d 0a  an expression}].
0f80: 20 20 64 6f 5f 74 65 73 74 20 73 65 6c 65 63 74    do_test select
0f90: 37 2d 35 2e 34 20 7b 0a 20 20 20 20 63 61 74 63  7-5.4 {.    catc
0fa0: 68 73 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c  hsql {.      SEL
0fb0: 45 43 54 20 35 20 49 4e 20 28 53 45 4c 45 43 54  ECT 5 IN (SELECT
0fc0: 20 2a 20 46 52 4f 4d 20 74 32 20 55 4e 49 4f 4e   * FROM t2 UNION
0fd0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
0fe0: 32 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 5b 6c  2);.    }.  } [l
0ff0: 69 73 74 20 31 20 5c 0a 20 20 20 20 20 7b 6f 6e  ist 1 \.     {on
1000: 6c 79 20 61 20 73 69 6e 67 6c 65 20 72 65 73 75  ly a single resu
1010: 6c 74 20 61 6c 6c 6f 77 65 64 20 66 6f 72 20 61  lt allowed for a
1020: 20 53 45 4c 45 43 54 20 74 68 61 74 20 69 73 20   SELECT that is 
1030: 70 61 72 74 20 6f 66 20 61 6e 20 65 78 70 72 65  part of an expre
1040: 73 73 69 6f 6e 7d 5d 0a 7d 0a 0a 23 20 56 65 72  ssion}].}..# Ver
1050: 69 66 79 20 74 68 61 74 20 61 6e 20 65 72 72 6f  ify that an erro
1060: 72 20 6f 63 63 75 72 73 20 69 66 20 79 6f 75 20  r occurs if you 
1070: 68 61 76 65 20 74 6f 6f 20 6d 61 6e 79 20 74 65  have too many te
1080: 72 6d 73 20 6f 6e 20 61 0a 23 20 63 6f 6d 70 6f  rms on a.# compo
1090: 75 6e 64 20 73 65 6c 65 63 74 20 73 74 61 74 65  und select state
10a0: 6d 65 6e 74 2e 0a 23 0a 69 66 20 7b 5b 63 6c 61  ment..#.if {[cla
10b0: 6e 67 5f 73 61 6e 69 74 69 7a 65 5f 61 64 64 72  ng_sanitize_addr
10c0: 65 73 73 5d 3d 3d 30 7d 20 7b 0a 20 20 69 66 63  ess]==0} {.  ifc
10d0: 61 70 61 62 6c 65 20 63 6f 6d 70 6f 75 6e 64 20  apable compound 
10e0: 7b 0a 20 20 20 20 69 66 20 7b 24 53 51 4c 49 54  {.    if {$SQLIT
10f0: 45 5f 4d 41 58 5f 43 4f 4d 50 4f 55 4e 44 5f 53  E_MAX_COMPOUND_S
1100: 45 4c 45 43 54 3e 30 7d 20 7b 0a 20 20 20 20 20  ELECT>0} {.     
1110: 20 73 65 74 20 73 71 6c 20 7b 53 45 4c 45 43 54   set sql {SELECT
1120: 20 30 7d 0a 20 20 20 20 20 20 73 65 74 20 72 65   0}.      set re
1130: 73 75 6c 74 20 30 0a 20 20 20 20 20 20 20 20 66  sult 0.        f
1140: 6f 72 20 7b 73 65 74 20 69 20 31 7d 20 7b 24 69  or {set i 1} {$i
1150: 3c 24 53 51 4c 49 54 45 5f 4d 41 58 5f 43 4f 4d  <$SQLITE_MAX_COM
1160: 50 4f 55 4e 44 5f 53 45 4c 45 43 54 7d 20 7b 69  POUND_SELECT} {i
1170: 6e 63 72 20 69 7d 20 7b 0a 20 20 20 20 20 20 20  ncr i} {.       
1180: 20 20 20 61 70 70 65 6e 64 20 73 71 6c 20 22 20     append sql " 
1190: 55 4e 49 4f 4e 20 41 4c 4c 20 53 45 4c 45 43 54  UNION ALL SELECT
11a0: 20 24 69 22 0a 20 20 20 20 20 20 20 20 20 20 20   $i".           
11b0: 20 6c 61 70 70 65 6e 64 20 72 65 73 75 6c 74 20   lappend result 
11c0: 24 69 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  $i.        }.   
11d0: 20 20 20 64 6f 5f 74 65 73 74 20 73 65 6c 65 63     do_test selec
11e0: 74 37 2d 36 2e 31 20 7b 0a 20 20 20 20 20 20 20  t7-6.1 {.       
11f0: 20 63 61 74 63 68 73 71 6c 20 24 73 71 6c 0a 20   catchsql $sql. 
1200: 20 20 20 20 20 7d 20 5b 6c 69 73 74 20 30 20 24       } [list 0 $
1210: 72 65 73 75 6c 74 5d 0a 20 20 20 20 20 20 61 70  result].      ap
1220: 70 65 6e 64 20 73 71 6c 20 7b 20 55 4e 49 4f 4e  pend sql { UNION
1230: 20 41 4c 4c 20 53 45 4c 45 43 54 20 39 39 39 39   ALL SELECT 9999
1240: 39 39 39 39 7d 0a 20 20 20 20 20 20 64 6f 5f 74  9999}.      do_t
1250: 65 73 74 20 73 65 6c 65 63 74 37 2d 36 2e 32 20  est select7-6.2 
1260: 7b 0a 20 20 20 20 20 20 20 20 63 61 74 63 68 73  {.        catchs
1270: 71 6c 20 24 73 71 6c 0a 20 20 20 20 20 20 7d 20  ql $sql.      } 
1280: 7b 31 20 7b 74 6f 6f 20 6d 61 6e 79 20 74 65 72  {1 {too many ter
1290: 6d 73 20 69 6e 20 63 6f 6d 70 6f 75 6e 64 20 53  ms in compound S
12a0: 45 4c 45 43 54 7d 7d 0a 20 20 20 20 7d 0a 20 20  ELECT}}.    }.  
12b0: 7d 0a 7d 0a 0a 23 20 54 68 69 73 20 62 6c 6f 63  }.}..# This bloc
12c0: 6b 20 6f 66 20 74 65 73 74 73 20 76 65 72 69 66  k of tests verif
12d0: 69 65 73 20 74 68 61 74 20 62 75 67 20 61 61 39  ies that bug aa9
12e0: 32 63 37 36 63 64 34 20 69 73 20 66 69 78 65 64  2c76cd4 is fixed
12f0: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 73 65 6c 65  ..#.do_test sele
1300: 63 74 37 2d 37 2e 31 20 7b 0a 20 20 65 78 65 63  ct7-7.1 {.  exec
1310: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
1320: 20 54 41 42 4c 45 20 74 33 28 61 20 52 45 41 4c   TABLE t3(a REAL
1330: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
1340: 54 4f 20 74 33 20 56 41 4c 55 45 53 28 34 34 2e  TO t3 VALUES(44.
1350: 30 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  0);.    INSERT I
1360: 4e 54 4f 20 74 33 20 56 41 4c 55 45 53 28 35 36  NTO t3 VALUES(56
1370: 2e 30 29 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f  .0);.  }.} {}.do
1380: 5f 74 65 73 74 20 73 65 6c 65 63 74 37 2d 37 2e  _test select7-7.
1390: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  2 {.  execsql {.
13a0: 20 20 20 20 70 72 61 67 6d 61 20 76 64 62 65 5f      pragma vdbe_
13b0: 74 72 61 63 65 20 3d 20 30 3b 0a 20 20 20 20 53  trace = 0;.    S
13c0: 45 4c 45 43 54 20 28 43 41 53 45 20 57 48 45 4e  ELECT (CASE WHEN
13d0: 20 61 3d 30 20 54 48 45 4e 20 30 20 45 4c 53 45   a=0 THEN 0 ELSE
13e0: 20 28 61 20 2b 20 32 35 29 20 2f 20 35 30 20 45   (a + 25) / 50 E
13f0: 4e 44 29 20 41 53 20 63 61 74 65 67 2c 20 63 6f  ND) AS categ, co
1400: 75 6e 74 28 2a 29 0a 20 20 20 20 46 52 4f 4d 20  unt(*).    FROM 
1410: 74 33 20 47 52 4f 55 50 20 42 59 20 63 61 74 65  t3 GROUP BY cate
1420: 67 0a 20 20 7d 0a 7d 20 7b 31 2e 33 38 20 31 20  g.  }.} {1.38 1 
1430: 31 2e 36 32 20 31 7d 0a 64 6f 5f 74 65 73 74 20  1.62 1}.do_test 
1440: 73 65 6c 65 63 74 37 2d 37 2e 33 20 7b 0a 20 20  select7-7.3 {.  
1450: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
1460: 45 41 54 45 20 54 41 42 4c 45 20 74 34 28 61 20  EATE TABLE t4(a 
1470: 52 45 41 4c 29 3b 0a 20 20 20 20 49 4e 53 45 52  REAL);.    INSER
1480: 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55 45 53  T INTO t4 VALUES
1490: 28 20 32 2e 30 20 29 3b 0a 20 20 20 20 49 4e 53  ( 2.0 );.    INS
14a0: 45 52 54 20 49 4e 54 4f 20 74 34 20 56 41 4c 55  ERT INTO t4 VALU
14b0: 45 53 28 20 33 2e 30 20 29 3b 0a 20 20 7d 0a 7d  ES( 3.0 );.  }.}
14c0: 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 73 65 6c 65   {}.do_test sele
14d0: 63 74 37 2d 37 2e 34 20 7b 0a 20 20 65 78 65 63  ct7-7.4 {.  exec
14e0: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
14f0: 20 28 43 41 53 45 20 57 48 45 4e 20 61 3d 30 20   (CASE WHEN a=0 
1500: 54 48 45 4e 20 27 7a 65 72 6f 27 20 45 4c 53 45  THEN 'zero' ELSE
1510: 20 61 2f 32 20 45 4e 44 29 20 41 53 20 74 20 46   a/2 END) AS t F
1520: 52 4f 4d 20 74 34 20 47 52 4f 55 50 20 42 59 20  ROM t4 GROUP BY 
1530: 74 3b 0a 20 20 7d 0a 7d 20 7b 31 2e 30 20 31 2e  t;.  }.} {1.0 1.
1540: 35 7d 0a 64 6f 5f 74 65 73 74 20 73 65 6c 65 63  5}.do_test selec
1550: 74 37 2d 37 2e 35 20 7b 0a 20 20 65 78 65 63 73  t7-7.5 {.  execs
1560: 71 6c 20 7b 20 53 45 4c 45 43 54 20 61 3d 30 2c  ql { SELECT a=0,
1570: 20 74 79 70 65 6f 66 28 61 29 20 46 52 4f 4d 20   typeof(a) FROM 
1580: 74 34 20 7d 0a 7d 20 7b 30 20 72 65 61 6c 20 30  t4 }.} {0 real 0
1590: 20 72 65 61 6c 7d 0a 64 6f 5f 74 65 73 74 20 73   real}.do_test s
15a0: 65 6c 65 63 74 37 2d 37 2e 36 20 7b 0a 20 20 65  elect7-7.6 {.  e
15b0: 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54 20  xecsql { SELECT 
15c0: 61 3d 30 2c 20 74 79 70 65 6f 66 28 61 29 20 46  a=0, typeof(a) F
15d0: 52 4f 4d 20 74 34 20 47 52 4f 55 50 20 42 59 20  ROM t4 GROUP BY 
15e0: 61 20 7d 0a 7d 20 7b 30 20 72 65 61 6c 20 30 20  a }.} {0 real 0 
15f0: 72 65 61 6c 7d 0a 0a 64 6f 5f 74 65 73 74 20 73  real}..do_test s
1600: 65 6c 65 63 74 37 2d 37 2e 37 20 7b 0a 20 20 65  elect7-7.7 {.  e
1610: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45  xecsql {.    CRE
1620: 41 54 45 20 54 41 42 4c 45 20 74 35 28 61 20 54  ATE TABLE t5(a T
1630: 45 58 54 2c 20 62 20 49 4e 54 29 3b 0a 20 20 20  EXT, b INT);.   
1640: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 35 20   INSERT INTO t5 
1650: 56 41 4c 55 45 53 28 31 32 33 2c 20 34 35 36 29  VALUES(123, 456)
1660: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 74 79 70  ;.    SELECT typ
1670: 65 6f 66 28 61 29 2c 20 61 20 46 52 4f 4d 20 74  eof(a), a FROM t
1680: 35 20 47 52 4f 55 50 20 42 59 20 61 20 48 41 56  5 GROUP BY a HAV
1690: 49 4e 47 20 61 3c 62 3b 0a 20 20 7d 0a 7d 20 7b  ING a<b;.  }.} {
16a0: 74 65 78 74 20 31 32 33 7d 0a 0a 66 69 6e 69 73  text 123}..finis
16b0: 68 5f 74 65 73 74 0a                             h_test.