/ Hex Artifact Content
Login

Artifact 66c73fcb7719b8ff0e841b58338f13604ff3e2b50a723f9b8f383595735262f6:


0000: 2f 2a 0a 2a 2a 20 32 30 30 38 20 41 75 67 75 73  /*.** 2008 Augus
0010: 74 20 31 38 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61  t 18.**.** The a
0020: 75 74 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20  uthor disclaims 
0030: 63 6f 70 79 72 69 67 68 74 20 74 6f 20 74 68 69  copyright to thi
0040: 73 20 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20  s source code.  
0050: 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61  In place of.** a
0060: 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68   legal notice, h
0070: 65 72 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e  ere is a blessin
0080: 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20  g:.**.**    May 
0090: 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20  you do good and 
00a0: 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20  not evil..**    
00b0: 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72  May you find for
00c0: 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75  giveness for you
00d0: 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76  rself and forgiv
00e0: 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20  e others..**    
00f0: 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20 66 72  May you share fr
0100: 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69  eely, never taki
0110: 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75  ng more than you
0120: 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a   give..**.******
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 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 2a 2a 2a 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66  ***.**.** This f
0180: 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 72 6f 75  ile contains rou
0190: 74 69 6e 65 73 20 75 73 65 64 20 66 6f 72 20 77  tines used for w
01a0: 61 6c 6b 69 6e 67 20 74 68 65 20 70 61 72 73 65  alking the parse
01b0: 72 20 74 72 65 65 20 61 6e 64 0a 2a 2a 20 72 65  r tree and.** re
01c0: 73 6f 6c 76 65 20 61 6c 6c 20 69 64 65 6e 74 69  solve all identi
01d0: 66 69 65 72 73 20 62 79 20 61 73 73 6f 63 69 61  fiers by associa
01e0: 74 69 6e 67 20 74 68 65 6d 20 77 69 74 68 20 61  ting them with a
01f0: 20 70 61 72 74 69 63 75 6c 61 72 0a 2a 2a 20 74   particular.** t
0200: 61 62 6c 65 20 61 6e 64 20 63 6f 6c 75 6d 6e 2e  able and column.
0210: 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 73 71  .*/.#include "sq
0220: 6c 69 74 65 49 6e 74 2e 68 22 0a 0a 2f 2a 0a 2a  liteInt.h"../*.*
0230: 2a 20 57 61 6c 6b 20 74 68 65 20 65 78 70 72 65  * Walk the expre
0240: 73 73 69 6f 6e 20 74 72 65 65 20 70 45 78 70 72  ssion tree pExpr
0250: 20 61 6e 64 20 69 6e 63 72 65 61 73 65 20 74 68   and increase th
0260: 65 20 61 67 67 72 65 67 61 74 65 20 66 75 6e 63  e aggregate func
0270: 74 69 6f 6e 0a 2a 2a 20 64 65 70 74 68 20 28 74  tion.** depth (t
0280: 68 65 20 45 78 70 72 2e 6f 70 32 20 66 69 65 6c  he Expr.op2 fiel
0290: 64 29 20 62 79 20 4e 20 6f 6e 20 65 76 65 72 79  d) by N on every
02a0: 20 54 4b 5f 41 47 47 5f 46 55 4e 43 54 49 4f 4e   TK_AGG_FUNCTION
02b0: 20 6e 6f 64 65 2e 0a 2a 2a 20 54 68 69 73 20 6e   node..** This n
02c0: 65 65 64 73 20 74 6f 20 6f 63 63 75 72 20 77 68  eeds to occur wh
02d0: 65 6e 20 63 6f 70 79 69 6e 67 20 61 20 54 4b 5f  en copying a TK_
02e0: 41 47 47 5f 46 55 4e 43 54 49 4f 4e 20 6e 6f 64  AGG_FUNCTION nod
02f0: 65 20 66 72 6f 6d 20 61 6e 0a 2a 2a 20 6f 75 74  e from an.** out
0300: 65 72 20 71 75 65 72 79 20 69 6e 74 6f 20 61 6e  er query into an
0310: 20 69 6e 6e 65 72 20 73 75 62 71 75 65 72 79 2e   inner subquery.
0320: 0a 2a 2a 0a 2a 2a 20 69 6e 63 72 41 67 67 46 75  .**.** incrAggFu
0330: 6e 63 74 69 6f 6e 44 65 70 74 68 28 70 45 78 70  nctionDepth(pExp
0340: 72 2c 6e 29 20 69 73 20 74 68 65 20 6d 61 69 6e  r,n) is the main
0350: 20 72 6f 75 74 69 6e 65 2e 20 20 69 6e 63 72 41   routine.  incrA
0360: 67 67 44 65 70 74 68 28 2e 2e 29 0a 2a 2a 20 69  ggDepth(..).** i
0370: 73 20 61 20 68 65 6c 70 65 72 20 66 75 6e 63 74  s a helper funct
0380: 69 6f 6e 20 2d 20 61 20 63 61 6c 6c 62 61 63 6b  ion - a callback
0390: 20 66 6f 72 20 74 68 65 20 74 72 65 65 20 77 61   for the tree wa
03a0: 6c 6b 65 72 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  lker..*/.static 
03b0: 69 6e 74 20 69 6e 63 72 41 67 67 44 65 70 74 68  int incrAggDepth
03c0: 28 57 61 6c 6b 65 72 20 2a 70 57 61 6c 6b 65 72  (Walker *pWalker
03d0: 2c 20 45 78 70 72 20 2a 70 45 78 70 72 29 7b 0a  , Expr *pExpr){.
03e0: 20 20 69 66 28 20 70 45 78 70 72 2d 3e 6f 70 3d    if( pExpr->op=
03f0: 3d 54 4b 5f 41 47 47 5f 46 55 4e 43 54 49 4f 4e  =TK_AGG_FUNCTION
0400: 20 29 20 70 45 78 70 72 2d 3e 6f 70 32 20 2b 3d   ) pExpr->op2 +=
0410: 20 70 57 61 6c 6b 65 72 2d 3e 75 2e 6e 3b 0a 20   pWalker->u.n;. 
0420: 20 72 65 74 75 72 6e 20 57 52 43 5f 43 6f 6e 74   return WRC_Cont
0430: 69 6e 75 65 3b 0a 7d 0a 73 74 61 74 69 63 20 76  inue;.}.static v
0440: 6f 69 64 20 69 6e 63 72 41 67 67 46 75 6e 63 74  oid incrAggFunct
0450: 69 6f 6e 44 65 70 74 68 28 45 78 70 72 20 2a 70  ionDepth(Expr *p
0460: 45 78 70 72 2c 20 69 6e 74 20 4e 29 7b 0a 20 20  Expr, int N){.  
0470: 69 66 28 20 4e 3e 30 20 29 7b 0a 20 20 20 20 57  if( N>0 ){.    W
0480: 61 6c 6b 65 72 20 77 3b 0a 20 20 20 20 6d 65 6d  alker w;.    mem
0490: 73 65 74 28 26 77 2c 20 30 2c 20 73 69 7a 65 6f  set(&w, 0, sizeo
04a0: 66 28 77 29 29 3b 0a 20 20 20 20 77 2e 78 45 78  f(w));.    w.xEx
04b0: 70 72 43 61 6c 6c 62 61 63 6b 20 3d 20 69 6e 63  prCallback = inc
04c0: 72 41 67 67 44 65 70 74 68 3b 0a 20 20 20 20 77  rAggDepth;.    w
04d0: 2e 75 2e 6e 20 3d 20 4e 3b 0a 20 20 20 20 73 71  .u.n = N;.    sq
04e0: 6c 69 74 65 33 57 61 6c 6b 45 78 70 72 28 26 77  lite3WalkExpr(&w
04f0: 2c 20 70 45 78 70 72 29 3b 0a 20 20 7d 0a 7d 0a  , pExpr);.  }.}.
0500: 0a 2f 2a 0a 2a 2a 20 54 75 72 6e 20 74 68 65 20  ./*.** Turn the 
0510: 70 45 78 70 72 20 65 78 70 72 65 73 73 69 6f 6e  pExpr expression
0520: 20 69 6e 74 6f 20 61 6e 20 61 6c 69 61 73 20 66   into an alias f
0530: 6f 72 20 74 68 65 20 69 43 6f 6c 2d 74 68 20 63  or the iCol-th c
0540: 6f 6c 75 6d 6e 20 6f 66 20 74 68 65 0a 2a 2a 20  olumn of the.** 
0550: 72 65 73 75 6c 74 20 73 65 74 20 69 6e 20 70 45  result set in pE
0560: 4c 69 73 74 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74  List..**.** If t
0570: 68 65 20 72 65 66 65 72 65 6e 63 65 20 69 73 20  he reference is 
0580: 66 6f 6c 6c 6f 77 65 64 20 62 79 20 61 20 43 4f  followed by a CO
0590: 4c 4c 41 54 45 20 6f 70 65 72 61 74 6f 72 2c 20  LLATE operator, 
05a0: 74 68 65 6e 20 6d 61 6b 65 20 73 75 72 65 0a 2a  then make sure.*
05b0: 2a 20 74 68 65 20 43 4f 4c 4c 41 54 45 20 6f 70  * the COLLATE op
05c0: 65 72 61 74 6f 72 20 69 73 20 70 72 65 73 65 72  erator is preser
05d0: 76 65 64 2e 20 20 46 6f 72 20 65 78 61 6d 70 6c  ved.  For exampl
05e0: 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 53 45 4c  e:.**.**     SEL
05f0: 45 43 54 20 61 2b 62 2c 20 63 2b 64 20 46 52 4f  ECT a+b, c+d FRO
0600: 4d 20 74 31 20 4f 52 44 45 52 20 42 59 20 31 20  M t1 ORDER BY 1 
0610: 43 4f 4c 4c 41 54 45 20 6e 6f 63 61 73 65 3b 0a  COLLATE nocase;.
0620: 2a 2a 0a 2a 2a 20 53 68 6f 75 6c 64 20 62 65 20  **.** Should be 
0630: 74 72 61 6e 73 66 6f 72 6d 65 64 20 69 6e 74 6f  transformed into
0640: 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 53 45 4c 45  :.**.**     SELE
0650: 43 54 20 61 2b 62 2c 20 63 2b 64 20 46 52 4f 4d  CT a+b, c+d FROM
0660: 20 74 31 20 4f 52 44 45 52 20 42 59 20 28 61 2b   t1 ORDER BY (a+
0670: 62 29 20 43 4f 4c 4c 41 54 45 20 6e 6f 63 61 73  b) COLLATE nocas
0680: 65 3b 0a 2a 2a 0a 2a 2a 20 54 68 65 20 6e 53 75  e;.**.** The nSu
0690: 62 71 75 65 72 79 20 70 61 72 61 6d 65 74 65 72  bquery parameter
06a0: 20 73 70 65 63 69 66 69 65 73 20 68 6f 77 20 6d   specifies how m
06b0: 61 6e 79 20 6c 65 76 65 6c 73 20 6f 66 20 73 75  any levels of su
06c0: 62 71 75 65 72 79 20 74 68 65 0a 2a 2a 20 61 6c  bquery the.** al
06d0: 69 61 73 20 69 73 20 72 65 6d 6f 76 65 64 20 66  ias is removed f
06e0: 72 6f 6d 20 74 68 65 20 6f 72 69 67 69 6e 61 6c  rom the original
06f0: 20 65 78 70 72 65 73 73 69 6f 6e 2e 20 20 54 68   expression.  Th
0700: 65 20 75 73 75 61 6c 20 76 61 6c 75 65 20 69 73  e usual value is
0710: 0a 2a 2a 20 7a 65 72 6f 20 62 75 74 20 69 74 20  .** zero but it 
0720: 6d 69 67 68 74 20 62 65 20 6d 6f 72 65 20 69 66  might be more if
0730: 20 74 68 65 20 61 6c 69 61 73 20 69 73 20 63 6f   the alias is co
0740: 6e 74 61 69 6e 65 64 20 77 69 74 68 69 6e 20 61  ntained within a
0750: 20 73 75 62 71 75 65 72 79 0a 2a 2a 20 6f 66 20   subquery.** of 
0760: 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 65 78 70  the original exp
0770: 72 65 73 73 69 6f 6e 2e 20 20 54 68 65 20 45 78  ression.  The Ex
0780: 70 72 2e 6f 70 32 20 66 69 65 6c 64 20 6f 66 20  pr.op2 field of 
0790: 54 4b 5f 41 47 47 5f 46 55 4e 43 54 49 4f 4e 0a  TK_AGG_FUNCTION.
07a0: 2a 2a 20 73 74 72 75 63 74 75 72 65 73 20 6d 75  ** structures mu
07b0: 73 74 20 62 65 20 69 6e 63 72 65 61 73 65 64 20  st be increased 
07c0: 62 79 20 74 68 65 20 6e 53 75 62 71 75 65 72 79  by the nSubquery
07d0: 20 61 6d 6f 75 6e 74 2e 0a 2a 2f 0a 73 74 61 74   amount..*/.stat
07e0: 69 63 20 76 6f 69 64 20 72 65 73 6f 6c 76 65 41  ic void resolveA
07f0: 6c 69 61 73 28 0a 20 20 50 61 72 73 65 20 2a 70  lias(.  Parse *p
0800: 50 61 72 73 65 2c 20 20 20 20 20 20 20 20 20 2f  Parse,         /
0810: 2a 20 50 61 72 73 69 6e 67 20 63 6f 6e 74 65 78  * Parsing contex
0820: 74 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73 74 20  t */.  ExprList 
0830: 2a 70 45 4c 69 73 74 2c 20 20 20 20 20 20 2f 2a  *pEList,      /*
0840: 20 41 20 72 65 73 75 6c 74 20 73 65 74 20 2a 2f   A result set */
0850: 0a 20 20 69 6e 74 20 69 43 6f 6c 2c 20 20 20 20  .  int iCol,    
0860: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 20 63            /* A c
0870: 6f 6c 75 6d 6e 20 69 6e 20 74 68 65 20 72 65 73  olumn in the res
0880: 75 6c 74 20 73 65 74 2e 20 20 30 2e 2e 70 45 4c  ult set.  0..pEL
0890: 69 73 74 2d 3e 6e 45 78 70 72 2d 31 20 2a 2f 0a  ist->nExpr-1 */.
08a0: 20 20 45 78 70 72 20 2a 70 45 78 70 72 2c 20 20    Expr *pExpr,  
08b0: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 61 6e           /* Tran
08c0: 73 66 6f 72 6d 20 74 68 69 73 20 69 6e 74 6f 20  sform this into 
08d0: 61 6e 20 61 6c 69 61 73 20 74 6f 20 74 68 65 20  an alias to the 
08e0: 72 65 73 75 6c 74 20 73 65 74 20 2a 2f 0a 20 20  result set */.  
08f0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 54 79 70  const char *zTyp
0900: 65 2c 20 20 20 20 20 2f 2a 20 22 47 52 4f 55 50  e,     /* "GROUP
0910: 22 20 6f 72 20 22 4f 52 44 45 52 22 20 6f 72 20  " or "ORDER" or 
0920: 22 22 20 2a 2f 0a 20 20 69 6e 74 20 6e 53 75 62  "" */.  int nSub
0930: 71 75 65 72 79 20 20 20 20 20 20 20 20 20 20 2f  query          /
0940: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 73 75 62 71  * Number of subq
0950: 75 65 72 69 65 73 20 74 68 61 74 20 74 68 65 20  ueries that the 
0960: 6c 61 62 65 6c 20 69 73 20 6d 6f 76 69 6e 67 20  label is moving 
0970: 2a 2f 0a 29 7b 0a 20 20 45 78 70 72 20 2a 70 4f  */.){.  Expr *pO
0980: 72 69 67 3b 20 20 20 20 20 20 20 20 20 20 20 2f  rig;           /
0990: 2a 20 54 68 65 20 69 43 6f 6c 2d 74 68 20 63 6f  * The iCol-th co
09a0: 6c 75 6d 6e 20 6f 66 20 74 68 65 20 72 65 73 75  lumn of the resu
09b0: 6c 74 20 73 65 74 20 2a 2f 0a 20 20 45 78 70 72  lt set */.  Expr
09c0: 20 2a 70 44 75 70 3b 20 20 20 20 20 20 20 20 20   *pDup;         
09d0: 20 20 20 2f 2a 20 43 6f 70 79 20 6f 66 20 70 4f     /* Copy of pO
09e0: 72 69 67 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  rig */.  sqlite3
09f0: 20 2a 64 62 3b 20 20 20 20 20 20 20 20 20 20 20   *db;           
0a00: 2f 2a 20 54 68 65 20 64 61 74 61 62 61 73 65 20  /* The database 
0a10: 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a 0a 20  connection */.. 
0a20: 20 61 73 73 65 72 74 28 20 69 43 6f 6c 3e 3d 30   assert( iCol>=0
0a30: 20 26 26 20 69 43 6f 6c 3c 70 45 4c 69 73 74 2d   && iCol<pEList-
0a40: 3e 6e 45 78 70 72 20 29 3b 0a 20 20 70 4f 72 69  >nExpr );.  pOri
0a50: 67 20 3d 20 70 45 4c 69 73 74 2d 3e 61 5b 69 43  g = pEList->a[iC
0a60: 6f 6c 5d 2e 70 45 78 70 72 3b 0a 20 20 61 73 73  ol].pExpr;.  ass
0a70: 65 72 74 28 20 70 4f 72 69 67 21 3d 30 20 29 3b  ert( pOrig!=0 );
0a80: 0a 20 20 64 62 20 3d 20 70 50 61 72 73 65 2d 3e  .  db = pParse->
0a90: 64 62 3b 0a 20 20 70 44 75 70 20 3d 20 73 71 6c  db;.  pDup = sql
0aa0: 69 74 65 33 45 78 70 72 44 75 70 28 64 62 2c 20  ite3ExprDup(db, 
0ab0: 70 4f 72 69 67 2c 20 30 29 3b 0a 20 20 69 66 28  pOrig, 0);.  if(
0ac0: 20 70 44 75 70 3d 3d 30 20 29 20 72 65 74 75 72   pDup==0 ) retur
0ad0: 6e 3b 0a 20 20 69 66 28 20 7a 54 79 70 65 5b 30  n;.  if( zType[0
0ae0: 5d 21 3d 27 47 27 20 29 20 69 6e 63 72 41 67 67  ]!='G' ) incrAgg
0af0: 46 75 6e 63 74 69 6f 6e 44 65 70 74 68 28 70 44  FunctionDepth(pD
0b00: 75 70 2c 20 6e 53 75 62 71 75 65 72 79 29 3b 0a  up, nSubquery);.
0b10: 20 20 69 66 28 20 70 45 78 70 72 2d 3e 6f 70 3d    if( pExpr->op=
0b20: 3d 54 4b 5f 43 4f 4c 4c 41 54 45 20 29 7b 0a 20  =TK_COLLATE ){. 
0b30: 20 20 20 70 44 75 70 20 3d 20 73 71 6c 69 74 65     pDup = sqlite
0b40: 33 45 78 70 72 41 64 64 43 6f 6c 6c 61 74 65 53  3ExprAddCollateS
0b50: 74 72 69 6e 67 28 70 50 61 72 73 65 2c 20 70 44  tring(pParse, pD
0b60: 75 70 2c 20 70 45 78 70 72 2d 3e 75 2e 7a 54 6f  up, pExpr->u.zTo
0b70: 6b 65 6e 29 3b 0a 20 20 7d 0a 20 20 45 78 70 72  ken);.  }.  Expr
0b80: 53 65 74 50 72 6f 70 65 72 74 79 28 70 44 75 70  SetProperty(pDup
0b90: 2c 20 45 50 5f 41 6c 69 61 73 29 3b 0a 0a 20 20  , EP_Alias);..  
0ba0: 2f 2a 20 42 65 66 6f 72 65 20 63 61 6c 6c 69 6e  /* Before callin
0bb0: 67 20 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c  g sqlite3ExprDel
0bc0: 65 74 65 28 29 2c 20 73 65 74 20 74 68 65 20 45  ete(), set the E
0bd0: 50 5f 53 74 61 74 69 63 20 66 6c 61 67 2e 20 54  P_Static flag. T
0be0: 68 69 73 20 0a 20 20 2a 2a 20 70 72 65 76 65 6e  his .  ** preven
0bf0: 74 73 20 45 78 70 72 44 65 6c 65 74 65 28 29 20  ts ExprDelete() 
0c00: 66 72 6f 6d 20 64 65 6c 65 74 69 6e 67 20 74 68  from deleting th
0c10: 65 20 45 78 70 72 20 73 74 72 75 63 74 75 72 65  e Expr structure
0c20: 20 69 74 73 65 6c 66 2c 0a 20 20 2a 2a 20 61 6c   itself,.  ** al
0c30: 6c 6f 77 69 6e 67 20 69 74 20 74 6f 20 62 65 20  lowing it to be 
0c40: 72 65 70 6f 70 75 6c 61 74 65 64 20 62 79 20 74  repopulated by t
0c50: 68 65 20 6d 65 6d 63 70 79 28 29 20 6f 6e 20 74  he memcpy() on t
0c60: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 6c 69 6e  he following lin
0c70: 65 2e 0a 20 20 2a 2a 20 54 68 65 20 70 45 78 70  e..  ** The pExp
0c80: 72 2d 3e 75 2e 7a 54 6f 6b 65 6e 20 6d 69 67 68  r->u.zToken migh
0c90: 74 20 70 6f 69 6e 74 20 69 6e 74 6f 20 6d 65 6d  t point into mem
0ca0: 6f 72 79 20 74 68 61 74 20 77 69 6c 6c 20 62 65  ory that will be
0cb0: 20 66 72 65 65 64 20 62 79 20 74 68 65 0a 20 20   freed by the.  
0cc0: 2a 2a 20 73 71 6c 69 74 65 33 44 62 46 72 65 65  ** sqlite3DbFree
0cd0: 28 64 62 2c 20 70 44 75 70 29 20 6f 6e 20 74 68  (db, pDup) on th
0ce0: 65 20 6c 61 73 74 20 6c 69 6e 65 20 6f 66 20 74  e last line of t
0cf0: 68 69 73 20 62 6c 6f 63 6b 2c 20 73 6f 20 62 65  his block, so be
0d00: 20 73 75 72 65 20 74 6f 0a 20 20 2a 2a 20 6d 61   sure to.  ** ma
0d10: 6b 65 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65  ke a copy of the
0d20: 20 74 6f 6b 65 6e 20 62 65 66 6f 72 65 20 64 6f   token before do
0d30: 69 6e 67 20 74 68 65 20 73 71 6c 69 74 65 33 44  ing the sqlite3D
0d40: 62 46 72 65 65 28 29 2e 0a 20 20 2a 2f 0a 20 20  bFree()..  */.  
0d50: 45 78 70 72 53 65 74 50 72 6f 70 65 72 74 79 28  ExprSetProperty(
0d60: 70 45 78 70 72 2c 20 45 50 5f 53 74 61 74 69 63  pExpr, EP_Static
0d70: 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72  );.  sqlite3Expr
0d80: 44 65 6c 65 74 65 28 64 62 2c 20 70 45 78 70 72  Delete(db, pExpr
0d90: 29 3b 0a 20 20 6d 65 6d 63 70 79 28 70 45 78 70  );.  memcpy(pExp
0da0: 72 2c 20 70 44 75 70 2c 20 73 69 7a 65 6f 66 28  r, pDup, sizeof(
0db0: 2a 70 45 78 70 72 29 29 3b 0a 20 20 69 66 28 20  *pExpr));.  if( 
0dc0: 21 45 78 70 72 48 61 73 50 72 6f 70 65 72 74 79  !ExprHasProperty
0dd0: 28 70 45 78 70 72 2c 20 45 50 5f 49 6e 74 56 61  (pExpr, EP_IntVa
0de0: 6c 75 65 29 20 26 26 20 70 45 78 70 72 2d 3e 75  lue) && pExpr->u
0df0: 2e 7a 54 6f 6b 65 6e 21 3d 30 20 29 7b 0a 20 20  .zToken!=0 ){.  
0e00: 20 20 61 73 73 65 72 74 28 20 28 70 45 78 70 72    assert( (pExpr
0e10: 2d 3e 66 6c 61 67 73 20 26 20 28 45 50 5f 52 65  ->flags & (EP_Re
0e20: 64 75 63 65 64 7c 45 50 5f 54 6f 6b 65 6e 4f 6e  duced|EP_TokenOn
0e30: 6c 79 29 29 3d 3d 30 20 29 3b 0a 20 20 20 20 70  ly))==0 );.    p
0e40: 45 78 70 72 2d 3e 75 2e 7a 54 6f 6b 65 6e 20 3d  Expr->u.zToken =
0e50: 20 73 71 6c 69 74 65 33 44 62 53 74 72 44 75 70   sqlite3DbStrDup
0e60: 28 64 62 2c 20 70 45 78 70 72 2d 3e 75 2e 7a 54  (db, pExpr->u.zT
0e70: 6f 6b 65 6e 29 3b 0a 20 20 20 20 70 45 78 70 72  oken);.    pExpr
0e80: 2d 3e 66 6c 61 67 73 20 7c 3d 20 45 50 5f 4d 65  ->flags |= EP_Me
0e90: 6d 54 6f 6b 65 6e 3b 0a 20 20 7d 0a 20 20 73 71  mToken;.  }.  sq
0ea0: 6c 69 74 65 33 44 62 46 72 65 65 28 64 62 2c 20  lite3DbFree(db, 
0eb0: 70 44 75 70 29 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a  pDup);.}.../*.**
0ec0: 20 52 65 74 75 72 6e 20 54 52 55 45 20 69 66 20   Return TRUE if 
0ed0: 74 68 65 20 6e 61 6d 65 20 7a 43 6f 6c 20 6f 63  the name zCol oc
0ee0: 63 75 72 73 20 61 6e 79 77 68 65 72 65 20 69 6e  curs anywhere in
0ef0: 20 74 68 65 20 55 53 49 4e 47 20 63 6c 61 75 73   the USING claus
0f00: 65 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72 6e 20  e..**.** Return 
0f10: 46 41 4c 53 45 20 69 66 20 74 68 65 20 55 53 49  FALSE if the USI
0f20: 4e 47 20 63 6c 61 75 73 65 20 69 73 20 4e 55 4c  NG clause is NUL
0f30: 4c 20 6f 72 20 69 66 20 69 74 20 64 6f 65 73 20  L or if it does 
0f40: 6e 6f 74 20 63 6f 6e 74 61 69 6e 0a 2a 2a 20 7a  not contain.** z
0f50: 43 6f 6c 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  Col..*/.static i
0f60: 6e 74 20 6e 61 6d 65 49 6e 55 73 69 6e 67 43 6c  nt nameInUsingCl
0f70: 61 75 73 65 28 49 64 4c 69 73 74 20 2a 70 55 73  ause(IdList *pUs
0f80: 69 6e 67 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  ing, const char 
0f90: 2a 7a 43 6f 6c 29 7b 0a 20 20 69 66 28 20 70 55  *zCol){.  if( pU
0fa0: 73 69 6e 67 20 29 7b 0a 20 20 20 20 69 6e 74 20  sing ){.    int 
0fb0: 6b 3b 0a 20 20 20 20 66 6f 72 28 6b 3d 30 3b 20  k;.    for(k=0; 
0fc0: 6b 3c 70 55 73 69 6e 67 2d 3e 6e 49 64 3b 20 6b  k<pUsing->nId; k
0fd0: 2b 2b 29 7b 0a 20 20 20 20 20 20 69 66 28 20 73  ++){.      if( s
0fe0: 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 70 55  qlite3StrICmp(pU
0ff0: 73 69 6e 67 2d 3e 61 5b 6b 5d 2e 7a 4e 61 6d 65  sing->a[k].zName
1000: 2c 20 7a 43 6f 6c 29 3d 3d 30 20 29 20 72 65 74  , zCol)==0 ) ret
1010: 75 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d  urn 1;.    }.  }
1020: 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a  .  return 0;.}..
1030: 2f 2a 0a 2a 2a 20 53 75 62 71 75 65 72 69 65 73  /*.** Subqueries
1040: 20 73 74 6f 72 65 73 20 74 68 65 20 6f 72 69 67   stores the orig
1050: 69 6e 61 6c 20 64 61 74 61 62 61 73 65 2c 20 74  inal database, t
1060: 61 62 6c 65 20 61 6e 64 20 63 6f 6c 75 6d 6e 20  able and column 
1070: 6e 61 6d 65 73 20 66 6f 72 20 74 68 65 69 72 0a  names for their.
1080: 2a 2a 20 72 65 73 75 6c 74 20 73 65 74 73 20 69  ** result sets i
1090: 6e 20 45 78 70 72 4c 69 73 74 2e 61 5b 5d 2e 7a  n ExprList.a[].z
10a0: 53 70 61 6e 2c 20 69 6e 20 74 68 65 20 66 6f 72  Span, in the for
10b0: 6d 20 22 44 41 54 41 42 41 53 45 2e 54 41 42 4c  m "DATABASE.TABL
10c0: 45 2e 43 4f 4c 55 4d 4e 22 2e 0a 2a 2a 20 43 68  E.COLUMN"..** Ch
10d0: 65 63 6b 20 74 6f 20 73 65 65 20 69 66 20 74 68  eck to see if th
10e0: 65 20 7a 53 70 61 6e 20 67 69 76 65 6e 20 74 6f  e zSpan given to
10f0: 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 6d 61   this routine ma
1100: 74 63 68 65 73 20 74 68 65 20 7a 44 62 2c 20 7a  tches the zDb, z
1110: 54 61 62 2c 0a 2a 2a 20 61 6e 64 20 7a 43 6f 6c  Tab,.** and zCol
1120: 2e 20 20 49 66 20 61 6e 79 20 6f 66 20 7a 44 62  .  If any of zDb
1130: 2c 20 7a 54 61 62 2c 20 61 6e 64 20 7a 43 6f 6c  , zTab, and zCol
1140: 20 61 72 65 20 4e 55 4c 4c 20 74 68 65 6e 20 74   are NULL then t
1150: 68 6f 73 65 20 66 69 65 6c 64 73 20 77 69 6c 6c  hose fields will
1160: 0a 2a 2a 20 6d 61 74 63 68 20 61 6e 79 74 68 69  .** match anythi
1170: 6e 67 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  ng..*/.int sqlit
1180: 65 33 4d 61 74 63 68 53 70 61 6e 4e 61 6d 65 28  e3MatchSpanName(
1190: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
11a0: 53 70 61 6e 2c 0a 20 20 63 6f 6e 73 74 20 63 68  Span,.  const ch
11b0: 61 72 20 2a 7a 43 6f 6c 2c 0a 20 20 63 6f 6e 73  ar *zCol,.  cons
11c0: 74 20 63 68 61 72 20 2a 7a 54 61 62 2c 0a 20 20  t char *zTab,.  
11d0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 0a  const char *zDb.
11e0: 29 7b 0a 20 20 69 6e 74 20 6e 3b 0a 20 20 66 6f  ){.  int n;.  fo
11f0: 72 28 6e 3d 30 3b 20 41 4c 57 41 59 53 28 7a 53  r(n=0; ALWAYS(zS
1200: 70 61 6e 5b 6e 5d 29 20 26 26 20 7a 53 70 61 6e  pan[n]) && zSpan
1210: 5b 6e 5d 21 3d 27 2e 27 3b 20 6e 2b 2b 29 7b 7d  [n]!='.'; n++){}
1220: 0a 20 20 69 66 28 20 7a 44 62 20 26 26 20 28 73  .  if( zDb && (s
1230: 71 6c 69 74 65 33 53 74 72 4e 49 43 6d 70 28 7a  qlite3StrNICmp(z
1240: 53 70 61 6e 2c 20 7a 44 62 2c 20 6e 29 21 3d 30  Span, zDb, n)!=0
1250: 20 7c 7c 20 7a 44 62 5b 6e 5d 21 3d 30 29 20 29   || zDb[n]!=0) )
1260: 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a  {.    return 0;.
1270: 20 20 7d 0a 20 20 7a 53 70 61 6e 20 2b 3d 20 6e    }.  zSpan += n
1280: 2b 31 3b 0a 20 20 66 6f 72 28 6e 3d 30 3b 20 41  +1;.  for(n=0; A
1290: 4c 57 41 59 53 28 7a 53 70 61 6e 5b 6e 5d 29 20  LWAYS(zSpan[n]) 
12a0: 26 26 20 7a 53 70 61 6e 5b 6e 5d 21 3d 27 2e 27  && zSpan[n]!='.'
12b0: 3b 20 6e 2b 2b 29 7b 7d 0a 20 20 69 66 28 20 7a  ; n++){}.  if( z
12c0: 54 61 62 20 26 26 20 28 73 71 6c 69 74 65 33 53  Tab && (sqlite3S
12d0: 74 72 4e 49 43 6d 70 28 7a 53 70 61 6e 2c 20 7a  trNICmp(zSpan, z
12e0: 54 61 62 2c 20 6e 29 21 3d 30 20 7c 7c 20 7a 54  Tab, n)!=0 || zT
12f0: 61 62 5b 6e 5d 21 3d 30 29 20 29 7b 0a 20 20 20  ab[n]!=0) ){.   
1300: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20   return 0;.  }. 
1310: 20 7a 53 70 61 6e 20 2b 3d 20 6e 2b 31 3b 0a 20   zSpan += n+1;. 
1320: 20 69 66 28 20 7a 43 6f 6c 20 26 26 20 73 71 6c   if( zCol && sql
1330: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 53 70 61  ite3StrICmp(zSpa
1340: 6e 2c 20 7a 43 6f 6c 29 21 3d 30 20 29 7b 0a 20  n, zCol)!=0 ){. 
1350: 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d     return 0;.  }
1360: 0a 20 20 72 65 74 75 72 6e 20 31 3b 0a 7d 0a 0a  .  return 1;.}..
1370: 2f 2a 0a 2a 2a 20 47 69 76 65 6e 20 74 68 65 20  /*.** Given the 
1380: 6e 61 6d 65 20 6f 66 20 61 20 63 6f 6c 75 6d 6e  name of a column
1390: 20 6f 66 20 74 68 65 20 66 6f 72 6d 20 58 2e 59   of the form X.Y
13a0: 2e 5a 20 6f 72 20 59 2e 5a 20 6f 72 20 6a 75 73  .Z or Y.Z or jus
13b0: 74 20 5a 2c 20 6c 6f 6f 6b 20 75 70 0a 2a 2a 20  t Z, look up.** 
13c0: 74 68 61 74 20 6e 61 6d 65 20 69 6e 20 74 68 65  that name in the
13d0: 20 73 65 74 20 6f 66 20 73 6f 75 72 63 65 20 74   set of source t
13e0: 61 62 6c 65 73 20 69 6e 20 70 53 72 63 4c 69 73  ables in pSrcLis
13f0: 74 20 61 6e 64 20 6d 61 6b 65 20 74 68 65 20 70  t and make the p
1400: 45 78 70 72 20 0a 2a 2a 20 65 78 70 72 65 73 73  Expr .** express
1410: 69 6f 6e 20 6e 6f 64 65 20 72 65 66 65 72 20 62  ion node refer b
1420: 61 63 6b 20 74 6f 20 74 68 61 74 20 73 6f 75 72  ack to that sour
1430: 63 65 20 63 6f 6c 75 6d 6e 2e 20 20 54 68 65 20  ce column.  The 
1440: 66 6f 6c 6c 6f 77 69 6e 67 20 63 68 61 6e 67 65  following change
1450: 73 0a 2a 2a 20 61 72 65 20 6d 61 64 65 20 74 6f  s.** are made to
1460: 20 70 45 78 70 72 3a 0a 2a 2a 0a 2a 2a 20 20 20   pExpr:.**.**   
1470: 20 70 45 78 70 72 2d 3e 69 44 62 20 20 20 20 20   pExpr->iDb     
1480: 20 20 20 20 20 20 53 65 74 20 74 68 65 20 69 6e        Set the in
1490: 64 65 78 20 69 6e 20 64 62 2d 3e 61 44 62 5b 5d  dex in db->aDb[]
14a0: 20 6f 66 20 74 68 65 20 64 61 74 61 62 61 73 65   of the database
14b0: 20 58 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20   X.**           
14c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28 65                (e
14d0: 76 65 6e 20 69 66 20 58 20 69 73 20 69 6d 70 6c  ven if X is impl
14e0: 69 65 64 29 2e 0a 2a 2a 20 20 20 20 70 45 78 70  ied)..**    pExp
14f0: 72 2d 3e 69 54 61 62 6c 65 20 20 20 20 20 20 20  r->iTable       
1500: 20 53 65 74 20 74 6f 20 74 68 65 20 63 75 72 73   Set to the curs
1510: 6f 72 20 6e 75 6d 62 65 72 20 66 6f 72 20 74 68  or number for th
1520: 65 20 74 61 62 6c 65 20 6f 62 74 61 69 6e 65 64  e table obtained
1530: 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20 20  .**             
1540: 20 20 20 20 20 20 20 20 20 20 20 20 66 72 6f 6d              from
1550: 20 70 53 72 63 4c 69 73 74 2e 0a 2a 2a 20 20 20   pSrcList..**   
1560: 20 70 45 78 70 72 2d 3e 70 54 61 62 20 20 20 20   pExpr->pTab    
1570: 20 20 20 20 20 20 50 6f 69 6e 74 73 20 74 6f 20        Points to 
1580: 74 68 65 20 54 61 62 6c 65 20 73 74 72 75 63 74  the Table struct
1590: 75 72 65 20 6f 66 20 58 2e 59 20 28 65 76 65 6e  ure of X.Y (even
15a0: 20 69 66 0a 2a 2a 20 20 20 20 20 20 20 20 20 20   if.**          
15b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 58                 X
15c0: 20 61 6e 64 2f 6f 72 20 59 20 61 72 65 20 69 6d   and/or Y are im
15d0: 70 6c 69 65 64 2e 29 0a 2a 2a 20 20 20 20 70 45  plied.).**    pE
15e0: 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 20 20 20  xpr->iColumn    
15f0: 20 20 20 53 65 74 20 74 6f 20 74 68 65 20 63 6f     Set to the co
1600: 6c 75 6d 6e 20 6e 75 6d 62 65 72 20 77 69 74 68  lumn number with
1610: 69 6e 20 74 68 65 20 74 61 62 6c 65 2e 0a 2a 2a  in the table..**
1620: 20 20 20 20 70 45 78 70 72 2d 3e 6f 70 20 20 20      pExpr->op   
1630: 20 20 20 20 20 20 20 20 20 53 65 74 20 74 6f 20           Set to 
1640: 54 4b 5f 43 4f 4c 55 4d 4e 2e 0a 2a 2a 20 20 20  TK_COLUMN..**   
1650: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 20 20   pExpr->pLeft   
1660: 20 20 20 20 20 20 41 6e 79 20 65 78 70 72 65 73        Any expres
1670: 73 69 6f 6e 20 74 68 69 73 20 70 6f 69 6e 74 73  sion this points
1680: 20 74 6f 20 69 73 20 64 65 6c 65 74 65 64 0a 2a   to is deleted.*
1690: 2a 20 20 20 20 70 45 78 70 72 2d 3e 70 52 69 67  *    pExpr->pRig
16a0: 68 74 20 20 20 20 20 20 20 20 41 6e 79 20 65 78  ht        Any ex
16b0: 70 72 65 73 73 69 6f 6e 20 74 68 69 73 20 70 6f  pression this po
16c0: 69 6e 74 73 20 74 6f 20 69 73 20 64 65 6c 65 74  ints to is delet
16d0: 65 64 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 7a 44  ed..**.** The zD
16e0: 62 20 76 61 72 69 61 62 6c 65 20 69 73 20 74 68  b variable is th
16f0: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 64 61  e name of the da
1700: 74 61 62 61 73 65 20 28 74 68 65 20 22 58 22 29  tabase (the "X")
1710: 2e 20 20 54 68 69 73 20 76 61 6c 75 65 20 6d 61  .  This value ma
1720: 79 20 62 65 0a 2a 2a 20 4e 55 4c 4c 20 6d 65 61  y be.** NULL mea
1730: 6e 69 6e 67 20 74 68 61 74 20 6e 61 6d 65 20 69  ning that name i
1740: 73 20 6f 66 20 74 68 65 20 66 6f 72 6d 20 59 2e  s of the form Y.
1750: 5a 20 6f 72 20 5a 2e 20 20 41 6e 79 20 61 76 61  Z or Z.  Any ava
1760: 69 6c 61 62 6c 65 20 64 61 74 61 62 61 73 65 0a  ilable database.
1770: 2a 2a 20 63 61 6e 20 62 65 20 75 73 65 64 2e 20  ** can be used. 
1780: 20 54 68 65 20 7a 54 61 62 6c 65 20 76 61 72 69   The zTable vari
1790: 61 62 6c 65 20 69 73 20 74 68 65 20 6e 61 6d 65  able is the name
17a0: 20 6f 66 20 74 68 65 20 74 61 62 6c 65 20 28 74   of the table (t
17b0: 68 65 20 22 59 22 29 2e 20 20 54 68 69 73 0a 2a  he "Y").  This.*
17c0: 2a 20 76 61 6c 75 65 20 63 61 6e 20 62 65 20 4e  * value can be N
17d0: 55 4c 4c 20 69 66 20 7a 44 62 20 69 73 20 61 6c  ULL if zDb is al
17e0: 73 6f 20 4e 55 4c 4c 2e 20 20 49 66 20 7a 54 61  so NULL.  If zTa
17f0: 62 6c 65 20 69 73 20 4e 55 4c 4c 20 69 74 0a 2a  ble is NULL it.*
1800: 2a 20 6d 65 61 6e 73 20 74 68 61 74 20 74 68 65  * means that the
1810: 20 66 6f 72 6d 20 6f 66 20 74 68 65 20 6e 61 6d   form of the nam
1820: 65 20 69 73 20 5a 20 61 6e 64 20 74 68 61 74 20  e is Z and that 
1830: 63 6f 6c 75 6d 6e 73 20 66 72 6f 6d 20 61 6e 79  columns from any
1840: 20 74 61 62 6c 65 0a 2a 2a 20 63 61 6e 20 62 65   table.** can be
1850: 20 75 73 65 64 2e 0a 2a 2a 0a 2a 2a 20 49 66 20   used..**.** If 
1860: 74 68 65 20 6e 61 6d 65 20 63 61 6e 6e 6f 74 20  the name cannot 
1870: 62 65 20 72 65 73 6f 6c 76 65 64 20 75 6e 61 6d  be resolved unam
1880: 62 69 67 75 6f 75 73 6c 79 2c 20 6c 65 61 76 65  biguously, leave
1890: 20 61 6e 20 65 72 72 6f 72 20 6d 65 73 73 61 67   an error messag
18a0: 65 0a 2a 2a 20 69 6e 20 70 50 61 72 73 65 20 61  e.** in pParse a
18b0: 6e 64 20 72 65 74 75 72 6e 20 57 52 43 5f 41 62  nd return WRC_Ab
18c0: 6f 72 74 2e 20 20 52 65 74 75 72 6e 20 57 52 43  ort.  Return WRC
18d0: 5f 50 72 75 6e 65 20 6f 6e 20 73 75 63 63 65 73  _Prune on succes
18e0: 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  s..*/.static int
18f0: 20 6c 6f 6f 6b 75 70 4e 61 6d 65 28 0a 20 20 50   lookupName(.  P
1900: 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20  arse *pParse,   
1910: 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73 69      /* The parsi
1920: 6e 67 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20  ng context */.  
1930: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 2c  const char *zDb,
1940: 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20       /* Name of 
1950: 74 68 65 20 64 61 74 61 62 61 73 65 20 63 6f 6e  the database con
1960: 74 61 69 6e 69 6e 67 20 74 61 62 6c 65 2c 20 6f  taining table, o
1970: 72 20 4e 55 4c 4c 20 2a 2f 0a 20 20 63 6f 6e 73  r NULL */.  cons
1980: 74 20 63 68 61 72 20 2a 7a 54 61 62 2c 20 20 20  t char *zTab,   
1990: 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 61 62 6c   /* Name of tabl
19a0: 65 20 63 6f 6e 74 61 69 6e 69 6e 67 20 63 6f 6c  e containing col
19b0: 75 6d 6e 2c 20 6f 72 20 4e 55 4c 4c 20 2a 2f 0a  umn, or NULL */.
19c0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 43    const char *zC
19d0: 6f 6c 2c 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f  ol,    /* Name o
19e0: 66 20 74 68 65 20 63 6f 6c 75 6d 6e 2e 20 2a 2f  f the column. */
19f0: 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78 74 20 2a  .  NameContext *
1a00: 70 4e 43 2c 20 20 20 20 2f 2a 20 54 68 65 20 6e  pNC,    /* The n
1a10: 61 6d 65 20 63 6f 6e 74 65 78 74 20 75 73 65 64  ame context used
1a20: 20 74 6f 20 72 65 73 6f 6c 76 65 20 74 68 65 20   to resolve the 
1a30: 6e 61 6d 65 20 2a 2f 0a 20 20 45 78 70 72 20 2a  name */.  Expr *
1a40: 70 45 78 70 72 20 20 20 20 20 20 20 20 20 20 2f  pExpr          /
1a50: 2a 20 4d 61 6b 65 20 74 68 69 73 20 45 58 50 52  * Make this EXPR
1a60: 20 6e 6f 64 65 20 70 6f 69 6e 74 20 74 6f 20 74   node point to t
1a70: 68 65 20 73 65 6c 65 63 74 65 64 20 63 6f 6c 75  he selected colu
1a80: 6d 6e 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74 20 69  mn */.){.  int i
1a90: 2c 20 6a 3b 20 20 20 20 20 20 20 20 20 20 20 20  , j;            
1aa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1ab0: 4c 6f 6f 70 20 63 6f 75 6e 74 65 72 73 20 2a 2f  Loop counters */
1ac0: 0a 20 20 69 6e 74 20 63 6e 74 20 3d 20 30 3b 20  .  int cnt = 0; 
1ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1ae0: 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f       /* Number o
1af0: 66 20 6d 61 74 63 68 69 6e 67 20 63 6f 6c 75 6d  f matching colum
1b00: 6e 20 6e 61 6d 65 73 20 2a 2f 0a 20 20 69 6e 74  n names */.  int
1b10: 20 63 6e 74 54 61 62 20 3d 20 30 3b 20 20 20 20   cntTab = 0;    
1b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
1b30: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 6d 61 74 63  * Number of matc
1b40: 68 69 6e 67 20 74 61 62 6c 65 20 6e 61 6d 65 73  hing table names
1b50: 20 2a 2f 0a 20 20 69 6e 74 20 6e 53 75 62 71 75   */.  int nSubqu
1b60: 65 72 79 20 3d 20 30 3b 20 20 20 20 20 20 20 20  ery = 0;        
1b70: 20 20 20 20 20 20 20 20 2f 2a 20 48 6f 77 20 6d          /* How m
1b80: 61 6e 79 20 6c 65 76 65 6c 73 20 6f 66 20 73 75  any levels of su
1b90: 62 71 75 65 72 79 20 2a 2f 0a 20 20 73 71 6c 69  bquery */.  sqli
1ba0: 74 65 33 20 2a 64 62 20 3d 20 70 50 61 72 73 65  te3 *db = pParse
1bb0: 2d 3e 64 62 3b 20 20 20 20 20 20 20 20 20 2f 2a  ->db;         /*
1bc0: 20 54 68 65 20 64 61 74 61 62 61 73 65 20 63 6f   The database co
1bd0: 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a 20 20 73 74  nnection */.  st
1be0: 72 75 63 74 20 53 72 63 4c 69 73 74 5f 69 74 65  ruct SrcList_ite
1bf0: 6d 20 2a 70 49 74 65 6d 3b 20 20 20 20 20 20 20  m *pItem;       
1c00: 2f 2a 20 55 73 65 20 66 6f 72 20 6c 6f 6f 70 69  /* Use for loopi
1c10: 6e 67 20 6f 76 65 72 20 70 53 72 63 4c 69 73 74  ng over pSrcList
1c20: 20 69 74 65 6d 73 20 2a 2f 0a 20 20 73 74 72 75   items */.  stru
1c30: 63 74 20 53 72 63 4c 69 73 74 5f 69 74 65 6d 20  ct SrcList_item 
1c40: 2a 70 4d 61 74 63 68 20 3d 20 30 3b 20 20 2f 2a  *pMatch = 0;  /*
1c50: 20 54 68 65 20 6d 61 74 63 68 69 6e 67 20 70 53   The matching pS
1c60: 72 63 4c 69 73 74 20 69 74 65 6d 20 2a 2f 0a 20  rcList item */. 
1c70: 20 4e 61 6d 65 43 6f 6e 74 65 78 74 20 2a 70 54   NameContext *pT
1c80: 6f 70 4e 43 20 3d 20 70 4e 43 3b 20 20 20 20 20  opNC = pNC;     
1c90: 20 20 20 2f 2a 20 46 69 72 73 74 20 6e 61 6d 65     /* First name
1ca0: 63 6f 6e 74 65 78 74 20 69 6e 20 74 68 65 20 6c  context in the l
1cb0: 69 73 74 20 2a 2f 0a 20 20 53 63 68 65 6d 61 20  ist */.  Schema 
1cc0: 2a 70 53 63 68 65 6d 61 20 3d 20 30 3b 20 20 20  *pSchema = 0;   
1cd0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 63             /* Sc
1ce0: 68 65 6d 61 20 6f 66 20 74 68 65 20 65 78 70 72  hema of the expr
1cf0: 65 73 73 69 6f 6e 20 2a 2f 0a 20 20 69 6e 74 20  ession */.  int 
1d00: 69 73 54 72 69 67 67 65 72 20 3d 20 30 3b 20 20  isTrigger = 0;  
1d10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
1d20: 20 54 72 75 65 20 69 66 20 72 65 73 6f 6c 76 65   True if resolve
1d30: 64 20 74 6f 20 61 20 74 72 69 67 67 65 72 20 63  d to a trigger c
1d40: 6f 6c 75 6d 6e 20 2a 2f 0a 20 20 54 61 62 6c 65  olumn */.  Table
1d50: 20 2a 70 54 61 62 20 3d 20 30 3b 20 20 20 20 20   *pTab = 0;     
1d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1d70: 54 61 62 6c 65 20 68 6f 6c 64 20 74 68 65 20 72  Table hold the r
1d80: 6f 77 20 2a 2f 0a 20 20 43 6f 6c 75 6d 6e 20 2a  ow */.  Column *
1d90: 70 43 6f 6c 3b 20 20 20 20 20 20 20 20 20 20 20  pCol;           
1da0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 20 63            /* A c
1db0: 6f 6c 75 6d 6e 20 6f 66 20 70 54 61 62 20 2a 2f  olumn of pTab */
1dc0: 0a 0a 20 20 61 73 73 65 72 74 28 20 70 4e 43 20  ..  assert( pNC 
1dd0: 29 3b 20 20 20 20 20 2f 2a 20 74 68 65 20 6e 61  );     /* the na
1de0: 6d 65 20 63 6f 6e 74 65 78 74 20 63 61 6e 6e 6f  me context canno
1df0: 74 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20 20  t be NULL. */.  
1e00: 61 73 73 65 72 74 28 20 7a 43 6f 6c 20 29 3b 20  assert( zCol ); 
1e10: 20 20 20 2f 2a 20 54 68 65 20 5a 20 69 6e 20 58     /* The Z in X
1e20: 2e 59 2e 5a 20 63 61 6e 6e 6f 74 20 62 65 20 4e  .Y.Z cannot be N
1e30: 55 4c 4c 20 2a 2f 0a 20 20 61 73 73 65 72 74 28  ULL */.  assert(
1e40: 20 21 45 78 70 72 48 61 73 50 72 6f 70 65 72 74   !ExprHasPropert
1e50: 79 28 70 45 78 70 72 2c 20 45 50 5f 54 6f 6b 65  y(pExpr, EP_Toke
1e60: 6e 4f 6e 6c 79 7c 45 50 5f 52 65 64 75 63 65 64  nOnly|EP_Reduced
1e70: 29 20 29 3b 0a 0a 20 20 2f 2a 20 49 6e 69 74 69  ) );..  /* Initi
1e80: 61 6c 69 7a 65 20 74 68 65 20 6e 6f 64 65 20 74  alize the node t
1e90: 6f 20 6e 6f 2d 6d 61 74 63 68 20 2a 2f 0a 20 20  o no-match */.  
1ea0: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20  pExpr->iTable = 
1eb0: 2d 31 3b 0a 20 20 70 45 78 70 72 2d 3e 70 54 61  -1;.  pExpr->pTa
1ec0: 62 20 3d 20 30 3b 0a 20 20 45 78 70 72 53 65 74  b = 0;.  ExprSet
1ed0: 56 56 41 50 72 6f 70 65 72 74 79 28 70 45 78 70  VVAProperty(pExp
1ee0: 72 2c 20 45 50 5f 4e 6f 52 65 64 75 63 65 29 3b  r, EP_NoReduce);
1ef0: 0a 0a 20 20 2f 2a 20 54 72 61 6e 73 6c 61 74 65  ..  /* Translate
1f00: 20 74 68 65 20 73 63 68 65 6d 61 20 6e 61 6d 65   the schema name
1f10: 20 69 6e 20 7a 44 62 20 69 6e 74 6f 20 61 20 70   in zDb into a p
1f20: 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 63 6f  ointer to the co
1f30: 72 72 65 73 70 6f 6e 64 69 6e 67 0a 20 20 2a 2a  rresponding.  **
1f40: 20 73 63 68 65 6d 61 2e 20 20 49 66 20 6e 6f 74   schema.  If not
1f50: 20 66 6f 75 6e 64 2c 20 70 53 63 68 65 6d 61 20   found, pSchema 
1f60: 77 69 6c 6c 20 72 65 6d 61 69 6e 20 4e 55 4c 4c  will remain NULL
1f70: 20 61 6e 64 20 6e 6f 74 68 69 6e 67 20 77 69 6c   and nothing wil
1f80: 6c 20 6d 61 74 63 68 0a 20 20 2a 2a 20 72 65 73  l match.  ** res
1f90: 75 6c 74 69 6e 67 20 69 6e 20 61 6e 20 61 70 70  ulting in an app
1fa0: 72 6f 70 72 69 61 74 65 20 65 72 72 6f 72 20 6d  ropriate error m
1fb0: 65 73 73 61 67 65 20 74 6f 77 61 72 64 20 74 68  essage toward th
1fc0: 65 20 65 6e 64 20 6f 66 20 74 68 69 73 20 72 6f  e end of this ro
1fd0: 75 74 69 6e 65 0a 20 20 2a 2f 0a 20 20 69 66 28  utine.  */.  if(
1fe0: 20 7a 44 62 20 29 7b 0a 20 20 20 20 74 65 73 74   zDb ){.    test
1ff0: 63 61 73 65 28 20 70 4e 43 2d 3e 6e 63 46 6c 61  case( pNC->ncFla
2000: 67 73 20 26 20 4e 43 5f 50 61 72 74 49 64 78 20  gs & NC_PartIdx 
2010: 29 3b 0a 20 20 20 20 74 65 73 74 63 61 73 65 28  );.    testcase(
2020: 20 70 4e 43 2d 3e 6e 63 46 6c 61 67 73 20 26 20   pNC->ncFlags & 
2030: 4e 43 5f 49 73 43 68 65 63 6b 20 29 3b 0a 20 20  NC_IsCheck );.  
2040: 20 20 69 66 28 20 28 70 4e 43 2d 3e 6e 63 46 6c    if( (pNC->ncFl
2050: 61 67 73 20 26 20 28 4e 43 5f 50 61 72 74 49 64  ags & (NC_PartId
2060: 78 7c 4e 43 5f 49 73 43 68 65 63 6b 29 29 21 3d  x|NC_IsCheck))!=
2070: 30 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 53 69  0 ){.      /* Si
2080: 6c 65 6e 74 6c 79 20 69 67 6e 6f 72 65 20 64 61  lently ignore da
2090: 74 61 62 61 73 65 20 71 75 61 6c 69 66 69 65 72  tabase qualifier
20a0: 73 20 69 6e 73 69 64 65 20 43 48 45 43 4b 20 63  s inside CHECK c
20b0: 6f 6e 73 74 72 61 69 6e 74 73 20 61 6e 64 0a 20  onstraints and. 
20c0: 20 20 20 20 20 2a 2a 20 70 61 72 74 69 61 6c 20       ** partial 
20d0: 69 6e 64 69 63 65 73 2e 20 20 44 6f 20 6e 6f 74  indices.  Do not
20e0: 20 72 61 69 73 65 20 65 72 72 6f 72 73 20 62 65   raise errors be
20f0: 63 61 75 73 65 20 74 68 61 74 20 6d 69 67 68 74  cause that might
2100: 20 62 72 65 61 6b 0a 20 20 20 20 20 20 2a 2a 20   break.      ** 
2110: 6c 65 67 61 63 79 20 61 6e 64 20 62 65 63 61 75  legacy and becau
2120: 73 65 20 69 74 20 64 6f 65 73 20 6e 6f 74 20 68  se it does not h
2130: 75 72 74 20 61 6e 79 74 68 69 6e 67 20 74 6f 20  urt anything to 
2140: 6a 75 73 74 20 69 67 6e 6f 72 65 20 74 68 65 0a  just ignore the.
2150: 20 20 20 20 20 20 2a 2a 20 64 61 74 61 62 61 73        ** databas
2160: 65 20 6e 61 6d 65 2e 20 2a 2f 0a 20 20 20 20 20  e name. */.     
2170: 20 7a 44 62 20 3d 20 30 3b 0a 20 20 20 20 7d 65   zDb = 0;.    }e
2180: 6c 73 65 7b 0a 20 20 20 20 20 20 66 6f 72 28 69  lse{.      for(i
2190: 3d 30 3b 20 69 3c 64 62 2d 3e 6e 44 62 3b 20 69  =0; i<db->nDb; i
21a0: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 61 73 73  ++){.        ass
21b0: 65 72 74 28 20 64 62 2d 3e 61 44 62 5b 69 5d 2e  ert( db->aDb[i].
21c0: 7a 44 62 53 4e 61 6d 65 20 29 3b 0a 20 20 20 20  zDbSName );.    
21d0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 53      if( sqlite3S
21e0: 74 72 49 43 6d 70 28 64 62 2d 3e 61 44 62 5b 69  trICmp(db->aDb[i
21f0: 5d 2e 7a 44 62 53 4e 61 6d 65 2c 7a 44 62 29 3d  ].zDbSName,zDb)=
2200: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
2210: 70 53 63 68 65 6d 61 20 3d 20 64 62 2d 3e 61 44  pSchema = db->aD
2220: 62 5b 69 5d 2e 70 53 63 68 65 6d 61 3b 0a 20 20  b[i].pSchema;.  
2230: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
2240: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
2250: 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a  .    }.  }..  /*
2260: 20 53 74 61 72 74 20 61 74 20 74 68 65 20 69 6e   Start at the in
2270: 6e 65 72 2d 6d 6f 73 74 20 63 6f 6e 74 65 78 74  ner-most context
2280: 20 61 6e 64 20 6d 6f 76 65 20 6f 75 74 77 61 72   and move outwar
2290: 64 20 75 6e 74 69 6c 20 61 20 6d 61 74 63 68 20  d until a match 
22a0: 69 73 20 66 6f 75 6e 64 20 2a 2f 0a 20 20 61 73  is found */.  as
22b0: 73 65 72 74 28 20 70 4e 43 20 26 26 20 63 6e 74  sert( pNC && cnt
22c0: 3d 3d 30 20 29 3b 0a 20 20 64 6f 7b 0a 20 20 20  ==0 );.  do{.   
22d0: 20 45 78 70 72 4c 69 73 74 20 2a 70 45 4c 69 73   ExprList *pELis
22e0: 74 3b 0a 20 20 20 20 53 72 63 4c 69 73 74 20 2a  t;.    SrcList *
22f0: 70 53 72 63 4c 69 73 74 20 3d 20 70 4e 43 2d 3e  pSrcList = pNC->
2300: 70 53 72 63 4c 69 73 74 3b 0a 0a 20 20 20 20 69  pSrcList;..    i
2310: 66 28 20 70 53 72 63 4c 69 73 74 20 29 7b 0a 20  f( pSrcList ){. 
2320: 20 20 20 20 20 66 6f 72 28 69 3d 30 2c 20 70 49       for(i=0, pI
2330: 74 65 6d 3d 70 53 72 63 4c 69 73 74 2d 3e 61 3b  tem=pSrcList->a;
2340: 20 69 3c 70 53 72 63 4c 69 73 74 2d 3e 6e 53 72   i<pSrcList->nSr
2350: 63 3b 20 69 2b 2b 2c 20 70 49 74 65 6d 2b 2b 29  c; i++, pItem++)
2360: 7b 0a 20 20 20 20 20 20 20 20 70 54 61 62 20 3d  {.        pTab =
2370: 20 70 49 74 65 6d 2d 3e 70 54 61 62 3b 0a 20 20   pItem->pTab;.  
2380: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70 54        assert( pT
2390: 61 62 21 3d 30 20 26 26 20 70 54 61 62 2d 3e 7a  ab!=0 && pTab->z
23a0: 4e 61 6d 65 21 3d 30 20 29 3b 0a 20 20 20 20 20  Name!=0 );.     
23b0: 20 20 20 61 73 73 65 72 74 28 20 70 54 61 62 2d     assert( pTab-
23c0: 3e 6e 43 6f 6c 3e 30 20 29 3b 0a 20 20 20 20 20  >nCol>0 );.     
23d0: 20 20 20 69 66 28 20 70 49 74 65 6d 2d 3e 70 53     if( pItem->pS
23e0: 65 6c 65 63 74 20 26 26 20 28 70 49 74 65 6d 2d  elect && (pItem-
23f0: 3e 70 53 65 6c 65 63 74 2d 3e 73 65 6c 46 6c 61  >pSelect->selFla
2400: 67 73 20 26 20 53 46 5f 4e 65 73 74 65 64 46 72  gs & SF_NestedFr
2410: 6f 6d 29 21 3d 30 20 29 7b 0a 20 20 20 20 20 20  om)!=0 ){.      
2420: 20 20 20 20 69 6e 74 20 68 69 74 20 3d 20 30 3b      int hit = 0;
2430: 0a 20 20 20 20 20 20 20 20 20 20 70 45 4c 69 73  .          pELis
2440: 74 20 3d 20 70 49 74 65 6d 2d 3e 70 53 65 6c 65  t = pItem->pSele
2450: 63 74 2d 3e 70 45 4c 69 73 74 3b 0a 20 20 20 20  ct->pEList;.    
2460: 20 20 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 6a        for(j=0; j
2470: 3c 70 45 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20  <pEList->nExpr; 
2480: 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  j++){.          
2490: 20 20 69 66 28 20 73 71 6c 69 74 65 33 4d 61 74    if( sqlite3Mat
24a0: 63 68 53 70 61 6e 4e 61 6d 65 28 70 45 4c 69 73  chSpanName(pELis
24b0: 74 2d 3e 61 5b 6a 5d 2e 7a 53 70 61 6e 2c 20 7a  t->a[j].zSpan, z
24c0: 43 6f 6c 2c 20 7a 54 61 62 2c 20 7a 44 62 29 20  Col, zTab, zDb) 
24d0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ){.             
24e0: 20 63 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20   cnt++;.        
24f0: 20 20 20 20 20 20 63 6e 74 54 61 62 20 3d 20 32        cntTab = 2
2500: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
2510: 70 4d 61 74 63 68 20 3d 20 70 49 74 65 6d 3b 0a  pMatch = pItem;.
2520: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70 45                pE
2530: 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20 6a  xpr->iColumn = j
2540: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
2550: 68 69 74 20 3d 20 31 3b 0a 20 20 20 20 20 20 20  hit = 1;.       
2560: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
2570: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 69 66 28   }.          if(
2580: 20 68 69 74 20 7c 7c 20 7a 54 61 62 3d 3d 30 20   hit || zTab==0 
2590: 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20  ) continue;.    
25a0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69 66      }.        if
25b0: 28 20 7a 44 62 20 26 26 20 70 54 61 62 2d 3e 70  ( zDb && pTab->p
25c0: 53 63 68 65 6d 61 21 3d 70 53 63 68 65 6d 61 20  Schema!=pSchema 
25d0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e  ){.          con
25e0: 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20 7d  tinue;.        }
25f0: 0a 20 20 20 20 20 20 20 20 69 66 28 20 7a 54 61  .        if( zTa
2600: 62 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 63  b ){.          c
2610: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 54 61 62 4e  onst char *zTabN
2620: 61 6d 65 20 3d 20 70 49 74 65 6d 2d 3e 7a 41 6c  ame = pItem->zAl
2630: 69 61 73 20 3f 20 70 49 74 65 6d 2d 3e 7a 41 6c  ias ? pItem->zAl
2640: 69 61 73 20 3a 20 70 54 61 62 2d 3e 7a 4e 61 6d  ias : pTab->zNam
2650: 65 3b 0a 20 20 20 20 20 20 20 20 20 20 61 73 73  e;.          ass
2660: 65 72 74 28 20 7a 54 61 62 4e 61 6d 65 21 3d 30  ert( zTabName!=0
2670: 20 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66   );.          if
2680: 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ( sqlite3StrICmp
2690: 28 7a 54 61 62 4e 61 6d 65 2c 20 7a 54 61 62 29  (zTabName, zTab)
26a0: 21 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  !=0 ){.         
26b0: 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20     continue;.   
26c0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
26d0: 20 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20 30   }.        if( 0
26e0: 3d 3d 28 63 6e 74 54 61 62 2b 2b 29 20 29 7b 0a  ==(cntTab++) ){.
26f0: 20 20 20 20 20 20 20 20 20 20 70 4d 61 74 63 68            pMatch
2700: 20 3d 20 70 49 74 65 6d 3b 0a 20 20 20 20 20 20   = pItem;.      
2710: 20 20 7d 0a 20 20 20 20 20 20 20 20 66 6f 72 28    }.        for(
2720: 6a 3d 30 2c 20 70 43 6f 6c 3d 70 54 61 62 2d 3e  j=0, pCol=pTab->
2730: 61 43 6f 6c 3b 20 6a 3c 70 54 61 62 2d 3e 6e 43  aCol; j<pTab->nC
2740: 6f 6c 3b 20 6a 2b 2b 2c 20 70 43 6f 6c 2b 2b 29  ol; j++, pCol++)
2750: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  {.          if( 
2760: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 70  sqlite3StrICmp(p
2770: 43 6f 6c 2d 3e 7a 4e 61 6d 65 2c 20 7a 43 6f 6c  Col->zName, zCol
2780: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  )==0 ){.        
2790: 20 20 20 20 2f 2a 20 49 66 20 74 68 65 72 65 20      /* If there 
27a0: 68 61 73 20 62 65 65 6e 20 65 78 61 63 74 6c 79  has been exactly
27b0: 20 6f 6e 65 20 70 72 69 6f 72 20 6d 61 74 63 68   one prior match
27c0: 20 61 6e 64 20 74 68 69 73 20 6d 61 74 63 68 0a   and this match.
27d0: 20 20 20 20 20 20 20 20 20 20 20 20 2a 2a 20 69              ** i
27e0: 73 20 66 6f 72 20 74 68 65 20 72 69 67 68 74 2d  s for the right-
27f0: 68 61 6e 64 20 74 61 62 6c 65 20 6f 66 20 61 20  hand table of a 
2800: 4e 41 54 55 52 41 4c 20 4a 4f 49 4e 20 6f 72 20  NATURAL JOIN or 
2810: 69 73 20 69 6e 20 61 20 0a 20 20 20 20 20 20 20  is in a .       
2820: 20 20 20 20 20 2a 2a 20 55 53 49 4e 47 20 63 6c       ** USING cl
2830: 61 75 73 65 2c 20 74 68 65 6e 20 73 6b 69 70 20  ause, then skip 
2840: 74 68 69 73 20 6d 61 74 63 68 2e 0a 20 20 20 20  this match..    
2850: 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20          */.     
2860: 20 20 20 20 20 20 20 69 66 28 20 63 6e 74 3d 3d         if( cnt==
2870: 31 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  1 ){.           
2880: 20 20 20 69 66 28 20 70 49 74 65 6d 2d 3e 66 67     if( pItem->fg
2890: 2e 6a 6f 69 6e 74 79 70 65 20 26 20 4a 54 5f 4e  .jointype & JT_N
28a0: 41 54 55 52 41 4c 20 29 20 63 6f 6e 74 69 6e 75  ATURAL ) continu
28b0: 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  e;.             
28c0: 20 69 66 28 20 6e 61 6d 65 49 6e 55 73 69 6e 67   if( nameInUsing
28d0: 43 6c 61 75 73 65 28 70 49 74 65 6d 2d 3e 70 55  Clause(pItem->pU
28e0: 73 69 6e 67 2c 20 7a 43 6f 6c 29 20 29 20 63 6f  sing, zCol) ) co
28f0: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20  ntinue;.        
2900: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
2910: 20 20 63 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20    cnt++;.       
2920: 20 20 20 20 20 70 4d 61 74 63 68 20 3d 20 70 49       pMatch = pI
2930: 74 65 6d 3b 0a 20 20 20 20 20 20 20 20 20 20 20  tem;.           
2940: 20 2f 2a 20 53 75 62 73 74 69 74 75 74 65 20 74   /* Substitute t
2950: 68 65 20 72 6f 77 69 64 20 28 63 6f 6c 75 6d 6e  he rowid (column
2960: 20 2d 31 29 20 66 6f 72 20 74 68 65 20 49 4e 54   -1) for the INT
2970: 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59  EGER PRIMARY KEY
2980: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20   */.            
2990: 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d  pExpr->iColumn =
29a0: 20 6a 3d 3d 70 54 61 62 2d 3e 69 50 4b 65 79 20   j==pTab->iPKey 
29b0: 3f 20 2d 31 20 3a 20 28 69 31 36 29 6a 3b 0a 20  ? -1 : (i16)j;. 
29c0: 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b             break
29d0: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  ;.          }.  
29e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
29f0: 20 20 20 20 20 20 69 66 28 20 70 4d 61 74 63 68        if( pMatch
2a00: 20 29 7b 0a 20 20 20 20 20 20 20 20 70 45 78 70   ){.        pExp
2a10: 72 2d 3e 69 54 61 62 6c 65 20 3d 20 70 4d 61 74  r->iTable = pMat
2a20: 63 68 2d 3e 69 43 75 72 73 6f 72 3b 0a 20 20 20  ch->iCursor;.   
2a30: 20 20 20 20 20 70 45 78 70 72 2d 3e 70 54 61 62       pExpr->pTab
2a40: 20 3d 20 70 4d 61 74 63 68 2d 3e 70 54 61 62 3b   = pMatch->pTab;
2a50: 0a 20 20 20 20 20 20 20 20 2f 2a 20 52 49 47 48  .        /* RIGH
2a60: 54 20 4a 4f 49 4e 20 6e 6f 74 20 28 79 65 74 29  T JOIN not (yet)
2a70: 20 73 75 70 70 6f 72 74 65 64 20 2a 2f 0a 20 20   supported */.  
2a80: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 28 70        assert( (p
2a90: 4d 61 74 63 68 2d 3e 66 67 2e 6a 6f 69 6e 74 79  Match->fg.jointy
2aa0: 70 65 20 26 20 4a 54 5f 52 49 47 48 54 29 3d 3d  pe & JT_RIGHT)==
2ab0: 30 20 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28  0 );.        if(
2ac0: 20 28 70 4d 61 74 63 68 2d 3e 66 67 2e 6a 6f 69   (pMatch->fg.joi
2ad0: 6e 74 79 70 65 20 26 20 4a 54 5f 4c 45 46 54 29  ntype & JT_LEFT)
2ae0: 21 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  !=0 ){.         
2af0: 20 45 78 70 72 53 65 74 50 72 6f 70 65 72 74 79   ExprSetProperty
2b00: 28 70 45 78 70 72 2c 20 45 50 5f 43 61 6e 42 65  (pExpr, EP_CanBe
2b10: 4e 75 6c 6c 29 3b 0a 20 20 20 20 20 20 20 20 7d  Null);.        }
2b20: 0a 20 20 20 20 20 20 20 20 70 53 63 68 65 6d 61  .        pSchema
2b30: 20 3d 20 70 45 78 70 72 2d 3e 70 54 61 62 2d 3e   = pExpr->pTab->
2b40: 70 53 63 68 65 6d 61 3b 0a 20 20 20 20 20 20 7d  pSchema;.      }
2b50: 0a 20 20 20 20 7d 20 2f 2a 20 69 66 28 20 70 53  .    } /* if( pS
2b60: 72 63 4c 69 73 74 20 29 20 2a 2f 0a 0a 23 69 66  rcList ) */..#if
2b70: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  ndef SQLITE_OMIT
2b80: 5f 54 52 49 47 47 45 52 0a 20 20 20 20 2f 2a 20  _TRIGGER.    /* 
2b90: 49 66 20 77 65 20 68 61 76 65 20 6e 6f 74 20 61  If we have not a
2ba0: 6c 72 65 61 64 79 20 72 65 73 6f 6c 76 65 64 20  lready resolved 
2bb0: 74 68 65 20 6e 61 6d 65 2c 20 74 68 65 6e 20 6d  the name, then m
2bc0: 61 79 62 65 20 0a 20 20 20 20 2a 2a 20 69 74 20  aybe .    ** it 
2bd0: 69 73 20 61 20 6e 65 77 2e 2a 20 6f 72 20 6f 6c  is a new.* or ol
2be0: 64 2e 2a 20 74 72 69 67 67 65 72 20 61 72 67 75  d.* trigger argu
2bf0: 6d 65 6e 74 20 72 65 66 65 72 65 6e 63 65 0a 20  ment reference. 
2c00: 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 7a 44     */.    if( zD
2c10: 62 3d 3d 30 20 26 26 20 7a 54 61 62 21 3d 30 20  b==0 && zTab!=0 
2c20: 26 26 20 63 6e 74 54 61 62 3d 3d 30 20 26 26 20  && cntTab==0 && 
2c30: 70 50 61 72 73 65 2d 3e 70 54 72 69 67 67 65 72  pParse->pTrigger
2c40: 54 61 62 21 3d 30 20 29 7b 0a 20 20 20 20 20 20  Tab!=0 ){.      
2c50: 69 6e 74 20 6f 70 20 3d 20 70 50 61 72 73 65 2d  int op = pParse-
2c60: 3e 65 54 72 69 67 67 65 72 4f 70 3b 0a 20 20 20  >eTriggerOp;.   
2c70: 20 20 20 61 73 73 65 72 74 28 20 6f 70 3d 3d 54     assert( op==T
2c80: 4b 5f 44 45 4c 45 54 45 20 7c 7c 20 6f 70 3d 3d  K_DELETE || op==
2c90: 54 4b 5f 55 50 44 41 54 45 20 7c 7c 20 6f 70 3d  TK_UPDATE || op=
2ca0: 3d 54 4b 5f 49 4e 53 45 52 54 20 29 3b 0a 20 20  =TK_INSERT );.  
2cb0: 20 20 20 20 69 66 28 20 6f 70 21 3d 54 4b 5f 44      if( op!=TK_D
2cc0: 45 4c 45 54 45 20 26 26 20 73 71 6c 69 74 65 33  ELETE && sqlite3
2cd0: 53 74 72 49 43 6d 70 28 22 6e 65 77 22 2c 7a 54  StrICmp("new",zT
2ce0: 61 62 29 20 3d 3d 20 30 20 29 7b 0a 20 20 20 20  ab) == 0 ){.    
2cf0: 20 20 20 20 70 45 78 70 72 2d 3e 69 54 61 62 6c      pExpr->iTabl
2d00: 65 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 70  e = 1;.        p
2d10: 54 61 62 20 3d 20 70 50 61 72 73 65 2d 3e 70 54  Tab = pParse->pT
2d20: 72 69 67 67 65 72 54 61 62 3b 0a 20 20 20 20 20  riggerTab;.     
2d30: 20 7d 65 6c 73 65 20 69 66 28 20 6f 70 21 3d 54   }else if( op!=T
2d40: 4b 5f 49 4e 53 45 52 54 20 26 26 20 73 71 6c 69  K_INSERT && sqli
2d50: 74 65 33 53 74 72 49 43 6d 70 28 22 6f 6c 64 22  te3StrICmp("old"
2d60: 2c 7a 54 61 62 29 3d 3d 30 20 29 7b 0a 20 20 20  ,zTab)==0 ){.   
2d70: 20 20 20 20 20 70 45 78 70 72 2d 3e 69 54 61 62       pExpr->iTab
2d80: 6c 65 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  le = 0;.        
2d90: 70 54 61 62 20 3d 20 70 50 61 72 73 65 2d 3e 70  pTab = pParse->p
2da0: 54 72 69 67 67 65 72 54 61 62 3b 0a 20 20 20 20  TriggerTab;.    
2db0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20    }else{.       
2dc0: 20 70 54 61 62 20 3d 20 30 3b 0a 20 20 20 20 20   pTab = 0;.     
2dd0: 20 7d 0a 0a 20 20 20 20 20 20 69 66 28 20 70 54   }..      if( pT
2de0: 61 62 20 29 7b 20 0a 20 20 20 20 20 20 20 20 69  ab ){ .        i
2df0: 6e 74 20 69 43 6f 6c 3b 0a 20 20 20 20 20 20 20  nt iCol;.       
2e00: 20 70 53 63 68 65 6d 61 20 3d 20 70 54 61 62 2d   pSchema = pTab-
2e10: 3e 70 53 63 68 65 6d 61 3b 0a 20 20 20 20 20 20  >pSchema;.      
2e20: 20 20 63 6e 74 54 61 62 2b 2b 3b 0a 20 20 20 20    cntTab++;.    
2e30: 20 20 20 20 66 6f 72 28 69 43 6f 6c 3d 30 2c 20      for(iCol=0, 
2e40: 70 43 6f 6c 3d 70 54 61 62 2d 3e 61 43 6f 6c 3b  pCol=pTab->aCol;
2e50: 20 69 43 6f 6c 3c 70 54 61 62 2d 3e 6e 43 6f 6c   iCol<pTab->nCol
2e60: 3b 20 69 43 6f 6c 2b 2b 2c 20 70 43 6f 6c 2b 2b  ; iCol++, pCol++
2e70: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  ){.          if(
2e80: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
2e90: 70 43 6f 6c 2d 3e 7a 4e 61 6d 65 2c 20 7a 43 6f  pCol->zName, zCo
2ea0: 6c 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  l)==0 ){.       
2eb0: 20 20 20 20 20 69 66 28 20 69 43 6f 6c 3d 3d 70       if( iCol==p
2ec0: 54 61 62 2d 3e 69 50 4b 65 79 20 29 7b 0a 20 20  Tab->iPKey ){.  
2ed0: 20 20 20 20 20 20 20 20 20 20 20 20 69 43 6f 6c              iCol
2ee0: 20 3d 20 2d 31 3b 0a 20 20 20 20 20 20 20 20 20   = -1;.         
2ef0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
2f00: 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20   break;.        
2f10: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
2f20: 20 20 20 20 20 20 69 66 28 20 69 43 6f 6c 3e 3d        if( iCol>=
2f30: 70 54 61 62 2d 3e 6e 43 6f 6c 20 26 26 20 73 71  pTab->nCol && sq
2f40: 6c 69 74 65 33 49 73 52 6f 77 69 64 28 7a 43 6f  lite3IsRowid(zCo
2f50: 6c 29 20 26 26 20 56 69 73 69 62 6c 65 52 6f 77  l) && VisibleRow
2f60: 69 64 28 70 54 61 62 29 20 29 7b 0a 20 20 20 20  id(pTab) ){.    
2f70: 20 20 20 20 20 20 2f 2a 20 49 4d 50 3a 20 52 2d        /* IMP: R-
2f80: 35 31 34 31 34 2d 33 32 39 31 30 20 2a 2f 0a 20  51414-32910 */. 
2f90: 20 20 20 20 20 20 20 20 20 69 43 6f 6c 20 3d 20           iCol = 
2fa0: 2d 31 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  -1;.        }.  
2fb0: 20 20 20 20 20 20 69 66 28 20 69 43 6f 6c 3c 70        if( iCol<p
2fc0: 54 61 62 2d 3e 6e 43 6f 6c 20 29 7b 0a 20 20 20  Tab->nCol ){.   
2fd0: 20 20 20 20 20 20 20 63 6e 74 2b 2b 3b 0a 20 20         cnt++;.  
2fe0: 20 20 20 20 20 20 20 20 69 66 28 20 69 43 6f 6c          if( iCol
2ff0: 3c 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  <0 ){.          
3000: 20 20 70 45 78 70 72 2d 3e 61 66 66 69 6e 69 74    pExpr->affinit
3010: 79 20 3d 20 53 51 4c 49 54 45 5f 41 46 46 5f 49  y = SQLITE_AFF_I
3020: 4e 54 45 47 45 52 3b 0a 20 20 20 20 20 20 20 20  NTEGER;.        
3030: 20 20 7d 65 6c 73 65 20 69 66 28 20 70 45 78 70    }else if( pExp
3040: 72 2d 3e 69 54 61 62 6c 65 3d 3d 30 20 29 7b 0a  r->iTable==0 ){.
3050: 20 20 20 20 20 20 20 20 20 20 20 20 74 65 73 74              test
3060: 63 61 73 65 28 20 69 43 6f 6c 3d 3d 33 31 20 29  case( iCol==31 )
3070: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 65  ;.            te
3080: 73 74 63 61 73 65 28 20 69 43 6f 6c 3d 3d 33 32  stcase( iCol==32
3090: 20 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20   );.            
30a0: 70 50 61 72 73 65 2d 3e 6f 6c 64 6d 61 73 6b 20  pParse->oldmask 
30b0: 7c 3d 20 28 69 43 6f 6c 3e 3d 33 32 20 3f 20 30  |= (iCol>=32 ? 0
30c0: 78 66 66 66 66 66 66 66 66 20 3a 20 28 28 28 75  xffffffff : (((u
30d0: 33 32 29 31 29 3c 3c 69 43 6f 6c 29 29 3b 0a 20  32)1)<<iCol));. 
30e0: 20 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a           }else{.
30f0: 20 20 20 20 20 20 20 20 20 20 20 20 74 65 73 74              test
3100: 63 61 73 65 28 20 69 43 6f 6c 3d 3d 33 31 20 29  case( iCol==31 )
3110: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 65  ;.            te
3120: 73 74 63 61 73 65 28 20 69 43 6f 6c 3d 3d 33 32  stcase( iCol==32
3130: 20 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20   );.            
3140: 70 50 61 72 73 65 2d 3e 6e 65 77 6d 61 73 6b 20  pParse->newmask 
3150: 7c 3d 20 28 69 43 6f 6c 3e 3d 33 32 20 3f 20 30  |= (iCol>=32 ? 0
3160: 78 66 66 66 66 66 66 66 66 20 3a 20 28 28 28 75  xffffffff : (((u
3170: 33 32 29 31 29 3c 3c 69 43 6f 6c 29 29 3b 0a 20  32)1)<<iCol));. 
3180: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
3190: 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c       pExpr->iCol
31a0: 75 6d 6e 20 3d 20 28 69 31 36 29 69 43 6f 6c 3b  umn = (i16)iCol;
31b0: 0a 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72  .          pExpr
31c0: 2d 3e 70 54 61 62 20 3d 20 70 54 61 62 3b 0a 20  ->pTab = pTab;. 
31d0: 20 20 20 20 20 20 20 20 20 69 73 54 72 69 67 67           isTrigg
31e0: 65 72 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20  er = 1;.        
31f0: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  }.      }.    }.
3200: 23 65 6e 64 69 66 20 2f 2a 20 21 64 65 66 69 6e  #endif /* !defin
3210: 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 54  ed(SQLITE_OMIT_T
3220: 52 49 47 47 45 52 29 20 2a 2f 0a 0a 20 20 20 20  RIGGER) */..    
3230: 2f 2a 0a 20 20 20 20 2a 2a 20 50 65 72 68 61 70  /*.    ** Perhap
3240: 73 20 74 68 65 20 6e 61 6d 65 20 69 73 20 61 20  s the name is a 
3250: 72 65 66 65 72 65 6e 63 65 20 74 6f 20 74 68 65  reference to the
3260: 20 52 4f 57 49 44 0a 20 20 20 20 2a 2f 0a 20 20   ROWID.    */.  
3270: 20 20 69 66 28 20 63 6e 74 3d 3d 30 0a 20 20 20    if( cnt==0.   
3280: 20 20 26 26 20 63 6e 74 54 61 62 3d 3d 31 0a 20    && cntTab==1. 
3290: 20 20 20 20 26 26 20 70 4d 61 74 63 68 0a 20 20      && pMatch.  
32a0: 20 20 20 26 26 20 28 70 4e 43 2d 3e 6e 63 46 6c     && (pNC->ncFl
32b0: 61 67 73 20 26 20 4e 43 5f 49 64 78 45 78 70 72  ags & NC_IdxExpr
32c0: 29 3d 3d 30 0a 20 20 20 20 20 26 26 20 73 71 6c  )==0.     && sql
32d0: 69 74 65 33 49 73 52 6f 77 69 64 28 7a 43 6f 6c  ite3IsRowid(zCol
32e0: 29 0a 20 20 20 20 20 26 26 20 56 69 73 69 62 6c  ).     && Visibl
32f0: 65 52 6f 77 69 64 28 70 4d 61 74 63 68 2d 3e 70  eRowid(pMatch->p
3300: 54 61 62 29 0a 20 20 20 20 29 7b 0a 20 20 20 20  Tab).    ){.    
3310: 20 20 63 6e 74 20 3d 20 31 3b 0a 20 20 20 20 20    cnt = 1;.     
3320: 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20   pExpr->iColumn 
3330: 3d 20 2d 31 3b 0a 20 20 20 20 20 20 70 45 78 70  = -1;.      pExp
3340: 72 2d 3e 61 66 66 69 6e 69 74 79 20 3d 20 53 51  r->affinity = SQ
3350: 4c 49 54 45 5f 41 46 46 5f 49 4e 54 45 47 45 52  LITE_AFF_INTEGER
3360: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 0a  ;.    }..    /*.
3370: 20 20 20 20 2a 2a 20 49 66 20 74 68 65 20 69 6e      ** If the in
3380: 70 75 74 20 69 73 20 6f 66 20 74 68 65 20 66 6f  put is of the fo
3390: 72 6d 20 5a 20 28 6e 6f 74 20 59 2e 5a 20 6f 72  rm Z (not Y.Z or
33a0: 20 58 2e 59 2e 5a 29 20 74 68 65 6e 20 74 68 65   X.Y.Z) then the
33b0: 20 6e 61 6d 65 20 5a 0a 20 20 20 20 2a 2a 20 6d   name Z.    ** m
33c0: 69 67 68 74 20 72 65 66 65 72 20 74 6f 20 61 6e  ight refer to an
33d0: 20 72 65 73 75 6c 74 2d 73 65 74 20 61 6c 69 61   result-set alia
33e0: 73 2e 20 20 54 68 69 73 20 68 61 70 70 65 6e 73  s.  This happens
33f0: 2c 20 66 6f 72 20 65 78 61 6d 70 6c 65 2c 20 77  , for example, w
3400: 68 65 6e 0a 20 20 20 20 2a 2a 20 77 65 20 61 72  hen.    ** we ar
3410: 65 20 72 65 73 6f 6c 76 69 6e 67 20 6e 61 6d 65  e resolving name
3420: 73 20 69 6e 20 74 68 65 20 57 48 45 52 45 20 63  s in the WHERE c
3430: 6c 61 75 73 65 20 6f 66 20 74 68 65 20 66 6f 6c  lause of the fol
3440: 6c 6f 77 69 6e 67 20 63 6f 6d 6d 61 6e 64 3a 0a  lowing command:.
3450: 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 20 20      **.    **   
3460: 20 20 53 45 4c 45 43 54 20 61 2b 62 20 41 53 20    SELECT a+b AS 
3470: 78 20 46 52 4f 4d 20 74 61 62 6c 65 20 57 48 45  x FROM table WHE
3480: 52 45 20 78 3c 31 30 3b 0a 20 20 20 20 2a 2a 0a  RE x<10;.    **.
3490: 20 20 20 20 2a 2a 20 49 6e 20 63 61 73 65 73 20      ** In cases 
34a0: 6c 69 6b 65 20 74 68 69 73 2c 20 72 65 70 6c 61  like this, repla
34b0: 63 65 20 70 45 78 70 72 20 77 69 74 68 20 61 20  ce pExpr with a 
34c0: 63 6f 70 79 20 6f 66 20 74 68 65 20 65 78 70 72  copy of the expr
34d0: 65 73 73 69 6f 6e 20 74 68 61 74 0a 20 20 20 20  ession that.    
34e0: 2a 2a 20 66 6f 72 6d 73 20 74 68 65 20 72 65 73  ** forms the res
34f0: 75 6c 74 20 73 65 74 20 65 6e 74 72 79 20 28 22  ult set entry ("
3500: 61 2b 62 22 20 69 6e 20 74 68 65 20 65 78 61 6d  a+b" in the exam
3510: 70 6c 65 29 20 61 6e 64 20 72 65 74 75 72 6e 20  ple) and return 
3520: 69 6d 6d 65 64 69 61 74 65 6c 79 2e 0a 20 20 20  immediately..   
3530: 20 2a 2a 20 4e 6f 74 65 20 74 68 61 74 20 74 68   ** Note that th
3540: 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69 6e 20  e expression in 
3550: 74 68 65 20 72 65 73 75 6c 74 20 73 65 74 20 73  the result set s
3560: 68 6f 75 6c 64 20 68 61 76 65 20 61 6c 72 65 61  hould have alrea
3570: 64 79 20 62 65 65 6e 0a 20 20 20 20 2a 2a 20 72  dy been.    ** r
3580: 65 73 6f 6c 76 65 64 20 62 79 20 74 68 65 20 74  esolved by the t
3590: 69 6d 65 20 74 68 65 20 57 48 45 52 45 20 63 6c  ime the WHERE cl
35a0: 61 75 73 65 20 69 73 20 72 65 73 6f 6c 76 65 64  ause is resolved
35b0: 2e 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20  ..    **.    ** 
35c0: 54 68 65 20 61 62 69 6c 69 74 79 20 74 6f 20 75  The ability to u
35d0: 73 65 20 61 6e 20 6f 75 74 70 75 74 20 72 65 73  se an output res
35e0: 75 6c 74 2d 73 65 74 20 63 6f 6c 75 6d 6e 20 69  ult-set column i
35f0: 6e 20 74 68 65 20 57 48 45 52 45 2c 20 47 52 4f  n the WHERE, GRO
3600: 55 50 20 42 59 2c 0a 20 20 20 20 2a 2a 20 6f 72  UP BY,.    ** or
3610: 20 48 41 56 49 4e 47 20 63 6c 61 75 73 65 73 2c   HAVING clauses,
3620: 20 6f 72 20 61 73 20 70 61 72 74 20 6f 66 20 61   or as part of a
3630: 20 6c 61 72 67 65 72 20 65 78 70 72 65 73 73 69   larger expressi
3640: 6f 6e 20 69 6e 20 74 68 65 20 4f 52 44 45 52 20  on in the ORDER 
3650: 42 59 0a 20 20 20 20 2a 2a 20 63 6c 61 75 73 65  BY.    ** clause
3660: 20 69 73 20 6e 6f 74 20 73 74 61 6e 64 61 72 64   is not standard
3670: 20 53 51 4c 2e 20 20 54 68 69 73 20 69 73 20 61   SQL.  This is a
3680: 20 28 67 6f 6f 66 79 29 20 53 51 4c 69 74 65 20   (goofy) SQLite 
3690: 65 78 74 65 6e 73 69 6f 6e 2c 20 74 68 61 74 0a  extension, that.
36a0: 20 20 20 20 2a 2a 20 69 73 20 73 75 70 70 6f 72      ** is suppor
36b0: 74 65 64 20 66 6f 72 20 62 61 63 6b 77 61 72 64  ted for backward
36c0: 73 20 63 6f 6d 70 61 74 69 62 69 6c 69 74 79 20  s compatibility 
36d0: 6f 6e 6c 79 2e 20 48 65 6e 63 65 2c 20 77 65 20  only. Hence, we 
36e0: 69 73 73 75 65 20 61 20 77 61 72 6e 69 6e 67 0a  issue a warning.
36f0: 20 20 20 20 2a 2a 20 6f 6e 20 73 71 6c 69 74 65      ** on sqlite
3700: 33 5f 6c 6f 67 28 29 20 77 68 65 6e 65 76 65 72  3_log() whenever
3710: 20 74 68 65 20 63 61 70 61 62 69 6c 69 74 79 20   the capability 
3720: 69 73 20 75 73 65 64 2e 0a 20 20 20 20 2a 2f 0a  is used..    */.
3730: 20 20 20 20 69 66 28 20 28 70 45 4c 69 73 74 20      if( (pEList 
3740: 3d 20 70 4e 43 2d 3e 70 45 4c 69 73 74 29 21 3d  = pNC->pEList)!=
3750: 30 0a 20 20 20 20 20 26 26 20 7a 54 61 62 3d 3d  0.     && zTab==
3760: 30 0a 20 20 20 20 20 26 26 20 63 6e 74 3d 3d 30  0.     && cnt==0
3770: 0a 20 20 20 20 29 7b 0a 20 20 20 20 20 20 66 6f  .    ){.      fo
3780: 72 28 6a 3d 30 3b 20 6a 3c 70 45 4c 69 73 74 2d  r(j=0; j<pEList-
3790: 3e 6e 45 78 70 72 3b 20 6a 2b 2b 29 7b 0a 20 20  >nExpr; j++){.  
37a0: 20 20 20 20 20 20 63 68 61 72 20 2a 7a 41 73 20        char *zAs 
37b0: 3d 20 70 45 4c 69 73 74 2d 3e 61 5b 6a 5d 2e 7a  = pEList->a[j].z
37c0: 4e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 69 66  Name;.        if
37d0: 28 20 7a 41 73 21 3d 30 20 26 26 20 73 71 6c 69  ( zAs!=0 && sqli
37e0: 74 65 33 53 74 72 49 43 6d 70 28 7a 41 73 2c 20  te3StrICmp(zAs, 
37f0: 7a 43 6f 6c 29 3d 3d 30 20 29 7b 0a 20 20 20 20  zCol)==0 ){.    
3800: 20 20 20 20 20 20 45 78 70 72 20 2a 70 4f 72 69        Expr *pOri
3810: 67 3b 0a 20 20 20 20 20 20 20 20 20 20 61 73 73  g;.          ass
3820: 65 72 74 28 20 70 45 78 70 72 2d 3e 70 4c 65 66  ert( pExpr->pLef
3830: 74 3d 3d 30 20 26 26 20 70 45 78 70 72 2d 3e 70  t==0 && pExpr->p
3840: 52 69 67 68 74 3d 3d 30 20 29 3b 0a 20 20 20 20  Right==0 );.    
3850: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70 45        assert( pE
3860: 78 70 72 2d 3e 78 2e 70 4c 69 73 74 3d 3d 30 20  xpr->x.pList==0 
3870: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 61 73 73  );.          ass
3880: 65 72 74 28 20 70 45 78 70 72 2d 3e 78 2e 70 53  ert( pExpr->x.pS
3890: 65 6c 65 63 74 3d 3d 30 20 29 3b 0a 20 20 20 20  elect==0 );.    
38a0: 20 20 20 20 20 20 70 4f 72 69 67 20 3d 20 70 45        pOrig = pE
38b0: 4c 69 73 74 2d 3e 61 5b 6a 5d 2e 70 45 78 70 72  List->a[j].pExpr
38c0: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  ;.          if( 
38d0: 28 70 4e 43 2d 3e 6e 63 46 6c 61 67 73 26 4e 43  (pNC->ncFlags&NC
38e0: 5f 41 6c 6c 6f 77 41 67 67 29 3d 3d 30 20 26 26  _AllowAgg)==0 &&
38f0: 20 45 78 70 72 48 61 73 50 72 6f 70 65 72 74 79   ExprHasProperty
3900: 28 70 4f 72 69 67 2c 20 45 50 5f 41 67 67 29 20  (pOrig, EP_Agg) 
3910: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 73  ){.            s
3920: 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70  qlite3ErrorMsg(p
3930: 50 61 72 73 65 2c 20 22 6d 69 73 75 73 65 20 6f  Parse, "misuse o
3940: 66 20 61 6c 69 61 73 65 64 20 61 67 67 72 65 67  f aliased aggreg
3950: 61 74 65 20 25 73 22 2c 20 7a 41 73 29 3b 0a 20  ate %s", zAs);. 
3960: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
3970: 6e 20 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20 20  n WRC_Abort;.   
3980: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
3990: 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 45 78     if( sqlite3Ex
39a0: 70 72 56 65 63 74 6f 72 53 69 7a 65 28 70 4f 72  prVectorSize(pOr
39b0: 69 67 29 21 3d 31 20 29 7b 0a 20 20 20 20 20 20  ig)!=1 ){.      
39c0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72        sqlite3Err
39d0: 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 72  orMsg(pParse, "r
39e0: 6f 77 20 76 61 6c 75 65 20 6d 69 73 75 73 65 64  ow value misused
39f0: 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ");.            
3a00: 72 65 74 75 72 6e 20 57 52 43 5f 41 62 6f 72 74  return WRC_Abort
3a10: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  ;.          }.  
3a20: 20 20 20 20 20 20 20 20 72 65 73 6f 6c 76 65 41          resolveA
3a30: 6c 69 61 73 28 70 50 61 72 73 65 2c 20 70 45 4c  lias(pParse, pEL
3a40: 69 73 74 2c 20 6a 2c 20 70 45 78 70 72 2c 20 22  ist, j, pExpr, "
3a50: 22 2c 20 6e 53 75 62 71 75 65 72 79 29 3b 0a 20  ", nSubquery);. 
3a60: 20 20 20 20 20 20 20 20 20 63 6e 74 20 3d 20 31           cnt = 1
3a70: 3b 0a 20 20 20 20 20 20 20 20 20 20 70 4d 61 74  ;.          pMat
3a80: 63 68 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  ch = 0;.        
3a90: 20 20 61 73 73 65 72 74 28 20 7a 54 61 62 3d 3d    assert( zTab==
3aa0: 30 20 26 26 20 7a 44 62 3d 3d 30 20 29 3b 0a 20  0 && zDb==0 );. 
3ab0: 20 20 20 20 20 20 20 20 20 67 6f 74 6f 20 6c 6f           goto lo
3ac0: 6f 6b 75 70 6e 61 6d 65 5f 65 6e 64 3b 0a 20 20  okupname_end;.  
3ad0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 20        }.      } 
3ae0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 41  .    }..    /* A
3af0: 64 76 61 6e 63 65 20 74 6f 20 74 68 65 20 6e 65  dvance to the ne
3b00: 78 74 20 6e 61 6d 65 20 63 6f 6e 74 65 78 74 2e  xt name context.
3b10: 20 20 54 68 65 20 6c 6f 6f 70 20 77 69 6c 6c 20    The loop will 
3b20: 65 78 69 74 20 77 68 65 6e 20 65 69 74 68 65 72  exit when either
3b30: 0a 20 20 20 20 2a 2a 20 77 65 20 68 61 76 65 20  .    ** we have 
3b40: 61 20 6d 61 74 63 68 20 28 63 6e 74 3e 30 29 20  a match (cnt>0) 
3b50: 6f 72 20 77 68 65 6e 20 77 65 20 72 75 6e 20 6f  or when we run o
3b60: 75 74 20 6f 66 20 6e 61 6d 65 20 63 6f 6e 74 65  ut of name conte
3b70: 78 74 73 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  xts..    */.    
3b80: 69 66 28 20 63 6e 74 20 29 20 62 72 65 61 6b 3b  if( cnt ) break;
3b90: 0a 20 20 20 20 70 4e 43 20 3d 20 70 4e 43 2d 3e  .    pNC = pNC->
3ba0: 70 4e 65 78 74 3b 0a 20 20 20 20 6e 53 75 62 71  pNext;.    nSubq
3bb0: 75 65 72 79 2b 2b 3b 0a 20 20 7d 77 68 69 6c 65  uery++;.  }while
3bc0: 28 20 70 4e 43 20 29 3b 0a 0a 0a 20 20 2f 2a 0a  ( pNC );...  /*.
3bd0: 20 20 2a 2a 20 49 66 20 58 20 61 6e 64 20 59 20    ** If X and Y 
3be0: 61 72 65 20 4e 55 4c 4c 20 28 69 6e 20 6f 74 68  are NULL (in oth
3bf0: 65 72 20 77 6f 72 64 73 20 69 66 20 6f 6e 6c 79  er words if only
3c00: 20 74 68 65 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65   the column name
3c10: 20 5a 20 69 73 0a 20 20 2a 2a 20 73 75 70 70 6c   Z is.  ** suppl
3c20: 69 65 64 29 20 61 6e 64 20 74 68 65 20 76 61 6c  ied) and the val
3c30: 75 65 20 6f 66 20 5a 20 69 73 20 65 6e 63 6c 6f  ue of Z is enclo
3c40: 73 65 64 20 69 6e 20 64 6f 75 62 6c 65 2d 71 75  sed in double-qu
3c50: 6f 74 65 73 2c 20 74 68 65 6e 0a 20 20 2a 2a 20  otes, then.  ** 
3c60: 5a 20 69 73 20 61 20 73 74 72 69 6e 67 20 6c 69  Z is a string li
3c70: 74 65 72 61 6c 20 69 66 20 69 74 20 64 6f 65 73  teral if it does
3c80: 6e 27 74 20 6d 61 74 63 68 20 61 6e 79 20 63 6f  n't match any co
3c90: 6c 75 6d 6e 20 6e 61 6d 65 73 2e 20 20 49 6e 20  lumn names.  In 
3ca0: 74 68 61 74 0a 20 20 2a 2a 20 63 61 73 65 2c 20  that.  ** case, 
3cb0: 77 65 20 6e 65 65 64 20 74 6f 20 72 65 74 75 72  we need to retur
3cc0: 6e 20 72 69 67 68 74 20 61 77 61 79 20 61 6e 64  n right away and
3cd0: 20 6e 6f 74 20 6d 61 6b 65 20 61 6e 79 20 63 68   not make any ch
3ce0: 61 6e 67 65 73 20 74 6f 0a 20 20 2a 2a 20 70 45  anges to.  ** pE
3cf0: 78 70 72 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 42  xpr..  **.  ** B
3d00: 65 63 61 75 73 65 20 6e 6f 20 72 65 66 65 72 65  ecause no refere
3d10: 6e 63 65 20 77 61 73 20 6d 61 64 65 20 74 6f 20  nce was made to 
3d20: 6f 75 74 65 72 20 63 6f 6e 74 65 78 74 73 2c 20  outer contexts, 
3d30: 74 68 65 20 70 4e 43 2d 3e 6e 52 65 66 0a 20 20  the pNC->nRef.  
3d40: 2a 2a 20 66 69 65 6c 64 73 20 61 72 65 20 6e 6f  ** fields are no
3d50: 74 20 63 68 61 6e 67 65 64 20 69 6e 20 61 6e 79  t changed in any
3d60: 20 63 6f 6e 74 65 78 74 2e 0a 20 20 2a 2f 0a 20   context..  */. 
3d70: 20 69 66 28 20 63 6e 74 3d 3d 30 20 26 26 20 7a   if( cnt==0 && z
3d80: 54 61 62 3d 3d 30 20 29 7b 0a 20 20 20 20 61 73  Tab==0 ){.    as
3d90: 73 65 72 74 28 20 70 45 78 70 72 2d 3e 6f 70 3d  sert( pExpr->op=
3da0: 3d 54 4b 5f 49 44 20 29 3b 0a 20 20 20 20 69 66  =TK_ID );.    if
3db0: 28 20 45 78 70 72 48 61 73 50 72 6f 70 65 72 74  ( ExprHasPropert
3dc0: 79 28 70 45 78 70 72 2c 45 50 5f 44 62 6c 51 75  y(pExpr,EP_DblQu
3dd0: 6f 74 65 64 29 20 29 7b 0a 20 20 20 20 20 20 70  oted) ){.      p
3de0: 45 78 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 53 54  Expr->op = TK_ST
3df0: 52 49 4e 47 3b 0a 20 20 20 20 20 20 70 45 78 70  RING;.      pExp
3e00: 72 2d 3e 70 54 61 62 20 3d 20 30 3b 0a 20 20 20  r->pTab = 0;.   
3e10: 20 20 20 72 65 74 75 72 6e 20 57 52 43 5f 50 72     return WRC_Pr
3e20: 75 6e 65 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69  une;.    }.    i
3e30: 66 28 20 73 71 6c 69 74 65 33 45 78 70 72 49 64  f( sqlite3ExprId
3e40: 54 6f 54 72 75 65 46 61 6c 73 65 28 70 45 78 70  ToTrueFalse(pExp
3e50: 72 29 20 29 7b 0a 20 20 20 20 20 20 72 65 74 75  r) ){.      retu
3e60: 72 6e 20 57 52 43 5f 50 72 75 6e 65 3b 0a 20 20  rn WRC_Prune;.  
3e70: 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 0a 20 20    }.  }..  /*.  
3e80: 2a 2a 20 63 6e 74 3d 3d 30 20 6d 65 61 6e 73 20  ** cnt==0 means 
3e90: 74 68 65 72 65 20 77 61 73 20 6e 6f 74 20 6d 61  there was not ma
3ea0: 74 63 68 2e 20 20 63 6e 74 3e 31 20 6d 65 61 6e  tch.  cnt>1 mean
3eb0: 73 20 74 68 65 72 65 20 77 65 72 65 20 74 77 6f  s there were two
3ec0: 20 6f 72 0a 20 20 2a 2a 20 6d 6f 72 65 20 6d 61   or.  ** more ma
3ed0: 74 63 68 65 73 2e 20 20 45 69 74 68 65 72 20 77  tches.  Either w
3ee0: 61 79 2c 20 77 65 20 68 61 76 65 20 61 6e 20 65  ay, we have an e
3ef0: 72 72 6f 72 2e 0a 20 20 2a 2f 0a 20 20 69 66 28  rror..  */.  if(
3f00: 20 63 6e 74 21 3d 31 20 29 7b 0a 20 20 20 20 63   cnt!=1 ){.    c
3f10: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 45 72 72 3b  onst char *zErr;
3f20: 0a 20 20 20 20 7a 45 72 72 20 3d 20 63 6e 74 3d  .    zErr = cnt=
3f30: 3d 30 20 3f 20 22 6e 6f 20 73 75 63 68 20 63 6f  =0 ? "no such co
3f40: 6c 75 6d 6e 22 20 3a 20 22 61 6d 62 69 67 75 6f  lumn" : "ambiguo
3f50: 75 73 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 22 3b  us column name";
3f60: 0a 20 20 20 20 69 66 28 20 7a 44 62 20 29 7b 0a  .    if( zDb ){.
3f70: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72        sqlite3Err
3f80: 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 25  orMsg(pParse, "%
3f90: 73 3a 20 25 73 2e 25 73 2e 25 73 22 2c 20 7a 45  s: %s.%s.%s", zE
3fa0: 72 72 2c 20 7a 44 62 2c 20 7a 54 61 62 2c 20 7a  rr, zDb, zTab, z
3fb0: 43 6f 6c 29 3b 0a 20 20 20 20 7d 65 6c 73 65 20  Col);.    }else 
3fc0: 69 66 28 20 7a 54 61 62 20 29 7b 0a 20 20 20 20  if( zTab ){.    
3fd0: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73    sqlite3ErrorMs
3fe0: 67 28 70 50 61 72 73 65 2c 20 22 25 73 3a 20 25  g(pParse, "%s: %
3ff0: 73 2e 25 73 22 2c 20 7a 45 72 72 2c 20 7a 54 61  s.%s", zErr, zTa
4000: 62 2c 20 7a 43 6f 6c 29 3b 0a 20 20 20 20 7d 65  b, zCol);.    }e
4010: 6c 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  lse{.      sqlit
4020: 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72 73  e3ErrorMsg(pPars
4030: 65 2c 20 22 25 73 3a 20 25 73 22 2c 20 7a 45 72  e, "%s: %s", zEr
4040: 72 2c 20 7a 43 6f 6c 29 3b 0a 20 20 20 20 7d 0a  r, zCol);.    }.
4050: 20 20 20 20 70 50 61 72 73 65 2d 3e 63 68 65 63      pParse->chec
4060: 6b 53 63 68 65 6d 61 20 3d 20 31 3b 0a 20 20 20  kSchema = 1;.   
4070: 20 70 54 6f 70 4e 43 2d 3e 6e 45 72 72 2b 2b 3b   pTopNC->nErr++;
4080: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 49 66 20 61 20  .  }..  /* If a 
4090: 63 6f 6c 75 6d 6e 20 66 72 6f 6d 20 61 20 74 61  column from a ta
40a0: 62 6c 65 20 69 6e 20 70 53 72 63 4c 69 73 74 20  ble in pSrcList 
40b0: 69 73 20 72 65 66 65 72 65 6e 63 65 64 2c 20 74  is referenced, t
40c0: 68 65 6e 20 72 65 63 6f 72 64 0a 20 20 2a 2a 20  hen record.  ** 
40d0: 74 68 69 73 20 66 61 63 74 20 69 6e 20 74 68 65  this fact in the
40e0: 20 70 53 72 63 4c 69 73 74 2e 61 5b 5d 2e 63 6f   pSrcList.a[].co
40f0: 6c 55 73 65 64 20 62 69 74 6d 61 73 6b 2e 20 20  lUsed bitmask.  
4100: 43 6f 6c 75 6d 6e 20 30 20 63 61 75 73 65 73 0a  Column 0 causes.
4110: 20 20 2a 2a 20 62 69 74 20 30 20 74 6f 20 62 65    ** bit 0 to be
4120: 20 73 65 74 2e 20 20 43 6f 6c 75 6d 6e 20 31 20   set.  Column 1 
4130: 73 65 74 73 20 62 69 74 20 31 2e 20 20 41 6e 64  sets bit 1.  And
4140: 20 73 6f 20 66 6f 72 74 68 2e 20 20 49 66 20 74   so forth.  If t
4150: 68 65 0a 20 20 2a 2a 20 63 6f 6c 75 6d 6e 20 6e  he.  ** column n
4160: 75 6d 62 65 72 20 69 73 20 67 72 65 61 74 65 72  umber is greater
4170: 20 74 68 61 6e 20 74 68 65 20 6e 75 6d 62 65 72   than the number
4180: 20 6f 66 20 62 69 74 73 20 69 6e 20 74 68 65 20   of bits in the 
4190: 62 69 74 6d 61 73 6b 0a 20 20 2a 2a 20 74 68 65  bitmask.  ** the
41a0: 6e 20 73 65 74 20 74 68 65 20 68 69 67 68 2d 6f  n set the high-o
41b0: 72 64 65 72 20 62 69 74 20 6f 66 20 74 68 65 20  rder bit of the 
41c0: 62 69 74 6d 61 73 6b 2e 0a 20 20 2a 2f 0a 20 20  bitmask..  */.  
41d0: 69 66 28 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75  if( pExpr->iColu
41e0: 6d 6e 3e 3d 30 20 26 26 20 70 4d 61 74 63 68 21  mn>=0 && pMatch!
41f0: 3d 30 20 29 7b 0a 20 20 20 20 69 6e 74 20 6e 20  =0 ){.    int n 
4200: 3d 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e  = pExpr->iColumn
4210: 3b 0a 20 20 20 20 74 65 73 74 63 61 73 65 28 20  ;.    testcase( 
4220: 6e 3d 3d 42 4d 53 2d 31 20 29 3b 0a 20 20 20 20  n==BMS-1 );.    
4230: 69 66 28 20 6e 3e 3d 42 4d 53 20 29 7b 0a 20 20  if( n>=BMS ){.  
4240: 20 20 20 20 6e 20 3d 20 42 4d 53 2d 31 3b 0a 20      n = BMS-1;. 
4250: 20 20 20 7d 0a 20 20 20 20 61 73 73 65 72 74 28     }.    assert(
4260: 20 70 4d 61 74 63 68 2d 3e 69 43 75 72 73 6f 72   pMatch->iCursor
4270: 3d 3d 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20  ==pExpr->iTable 
4280: 29 3b 0a 20 20 20 20 70 4d 61 74 63 68 2d 3e 63  );.    pMatch->c
4290: 6f 6c 55 73 65 64 20 7c 3d 20 28 28 42 69 74 6d  olUsed |= ((Bitm
42a0: 61 73 6b 29 31 29 3c 3c 6e 3b 0a 20 20 7d 0a 0a  ask)1)<<n;.  }..
42b0: 20 20 2f 2a 20 43 6c 65 61 6e 20 75 70 20 61 6e    /* Clean up an
42c0: 64 20 72 65 74 75 72 6e 0a 20 20 2a 2f 0a 20 20  d return.  */.  
42d0: 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74  sqlite3ExprDelet
42e0: 65 28 64 62 2c 20 70 45 78 70 72 2d 3e 70 4c 65  e(db, pExpr->pLe
42f0: 66 74 29 3b 0a 20 20 70 45 78 70 72 2d 3e 70 4c  ft);.  pExpr->pL
4300: 65 66 74 20 3d 20 30 3b 0a 20 20 73 71 6c 69 74  eft = 0;.  sqlit
4310: 65 33 45 78 70 72 44 65 6c 65 74 65 28 64 62 2c  e3ExprDelete(db,
4320: 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 3b   pExpr->pRight);
4330: 0a 20 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74  .  pExpr->pRight
4340: 20 3d 20 30 3b 0a 20 20 70 45 78 70 72 2d 3e 6f   = 0;.  pExpr->o
4350: 70 20 3d 20 28 69 73 54 72 69 67 67 65 72 20 3f  p = (isTrigger ?
4360: 20 54 4b 5f 54 52 49 47 47 45 52 20 3a 20 54 4b   TK_TRIGGER : TK
4370: 5f 43 4f 4c 55 4d 4e 29 3b 0a 20 20 45 78 70 72  _COLUMN);.  Expr
4380: 53 65 74 50 72 6f 70 65 72 74 79 28 70 45 78 70  SetProperty(pExp
4390: 72 2c 20 45 50 5f 4c 65 61 66 29 3b 0a 6c 6f 6f  r, EP_Leaf);.loo
43a0: 6b 75 70 6e 61 6d 65 5f 65 6e 64 3a 0a 20 20 69  kupname_end:.  i
43b0: 66 28 20 63 6e 74 3d 3d 31 20 29 7b 0a 20 20 20  f( cnt==1 ){.   
43c0: 20 61 73 73 65 72 74 28 20 70 4e 43 21 3d 30 20   assert( pNC!=0 
43d0: 29 3b 0a 20 20 20 20 69 66 28 20 21 45 78 70 72  );.    if( !Expr
43e0: 48 61 73 50 72 6f 70 65 72 74 79 28 70 45 78 70  HasProperty(pExp
43f0: 72 2c 20 45 50 5f 41 6c 69 61 73 29 20 29 7b 0a  r, EP_Alias) ){.
4400: 20 20 20 20 20 20 73 71 6c 69 74 65 33 41 75 74        sqlite3Aut
4410: 68 52 65 61 64 28 70 50 61 72 73 65 2c 20 70 45  hRead(pParse, pE
4420: 78 70 72 2c 20 70 53 63 68 65 6d 61 2c 20 70 4e  xpr, pSchema, pN
4430: 43 2d 3e 70 53 72 63 4c 69 73 74 29 3b 0a 20 20  C->pSrcList);.  
4440: 20 20 7d 0a 20 20 20 20 2f 2a 20 49 6e 63 72 65    }.    /* Incre
4450: 6d 65 6e 74 20 74 68 65 20 6e 52 65 66 20 76 61  ment the nRef va
4460: 6c 75 65 20 6f 6e 20 61 6c 6c 20 6e 61 6d 65 20  lue on all name 
4470: 63 6f 6e 74 65 78 74 73 20 66 72 6f 6d 20 54 6f  contexts from To
4480: 70 4e 43 20 75 70 20 74 6f 0a 20 20 20 20 2a 2a  pNC up to.    **
4490: 20 74 68 65 20 70 6f 69 6e 74 20 77 68 65 72 65   the point where
44a0: 20 74 68 65 20 6e 61 6d 65 20 6d 61 74 63 68 65   the name matche
44b0: 64 2e 20 2a 2f 0a 20 20 20 20 66 6f 72 28 3b 3b  d. */.    for(;;
44c0: 29 7b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28  ){.      assert(
44d0: 20 70 54 6f 70 4e 43 21 3d 30 20 29 3b 0a 20 20   pTopNC!=0 );.  
44e0: 20 20 20 20 70 54 6f 70 4e 43 2d 3e 6e 52 65 66      pTopNC->nRef
44f0: 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28 20 70 54  ++;.      if( pT
4500: 6f 70 4e 43 3d 3d 70 4e 43 20 29 20 62 72 65 61  opNC==pNC ) brea
4510: 6b 3b 0a 20 20 20 20 20 20 70 54 6f 70 4e 43 20  k;.      pTopNC 
4520: 3d 20 70 54 6f 70 4e 43 2d 3e 70 4e 65 78 74 3b  = pTopNC->pNext;
4530: 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72  .    }.    retur
4540: 6e 20 57 52 43 5f 50 72 75 6e 65 3b 0a 20 20 7d  n WRC_Prune;.  }
4550: 20 65 6c 73 65 20 7b 0a 20 20 20 20 72 65 74 75   else {.    retu
4560: 72 6e 20 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20  rn WRC_Abort;.  
4570: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 6c 6c 6f 63  }.}../*.** Alloc
4580: 61 74 65 20 61 6e 64 20 72 65 74 75 72 6e 20 61  ate and return a
4590: 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 6e 20 65   pointer to an e
45a0: 78 70 72 65 73 73 69 6f 6e 20 74 6f 20 6c 6f 61  xpression to loa
45b0: 64 20 74 68 65 20 63 6f 6c 75 6d 6e 20 69 43 6f  d the column iCo
45c0: 6c 0a 2a 2a 20 66 72 6f 6d 20 64 61 74 61 73 6f  l.** from dataso
45d0: 75 72 63 65 20 69 53 72 63 20 69 6e 20 53 72 63  urce iSrc in Src
45e0: 4c 69 73 74 20 70 53 72 63 2e 0a 2a 2f 0a 45 78  List pSrc..*/.Ex
45f0: 70 72 20 2a 73 71 6c 69 74 65 33 43 72 65 61 74  pr *sqlite3Creat
4600: 65 43 6f 6c 75 6d 6e 45 78 70 72 28 73 71 6c 69  eColumnExpr(sqli
4610: 74 65 33 20 2a 64 62 2c 20 53 72 63 4c 69 73 74  te3 *db, SrcList
4620: 20 2a 70 53 72 63 2c 20 69 6e 74 20 69 53 72 63   *pSrc, int iSrc
4630: 2c 20 69 6e 74 20 69 43 6f 6c 29 7b 0a 20 20 45  , int iCol){.  E
4640: 78 70 72 20 2a 70 20 3d 20 73 71 6c 69 74 65 33  xpr *p = sqlite3
4650: 45 78 70 72 41 6c 6c 6f 63 28 64 62 2c 20 54 4b  ExprAlloc(db, TK
4660: 5f 43 4f 4c 55 4d 4e 2c 20 30 2c 20 30 29 3b 0a  _COLUMN, 0, 0);.
4670: 20 20 69 66 28 20 70 20 29 7b 0a 20 20 20 20 73    if( p ){.    s
4680: 74 72 75 63 74 20 53 72 63 4c 69 73 74 5f 69 74  truct SrcList_it
4690: 65 6d 20 2a 70 49 74 65 6d 20 3d 20 26 70 53 72  em *pItem = &pSr
46a0: 63 2d 3e 61 5b 69 53 72 63 5d 3b 0a 20 20 20 20  c->a[iSrc];.    
46b0: 70 2d 3e 70 54 61 62 20 3d 20 70 49 74 65 6d 2d  p->pTab = pItem-
46c0: 3e 70 54 61 62 3b 0a 20 20 20 20 70 2d 3e 69 54  >pTab;.    p->iT
46d0: 61 62 6c 65 20 3d 20 70 49 74 65 6d 2d 3e 69 43  able = pItem->iC
46e0: 75 72 73 6f 72 3b 0a 20 20 20 20 69 66 28 20 70  ursor;.    if( p
46f0: 2d 3e 70 54 61 62 2d 3e 69 50 4b 65 79 3d 3d 69  ->pTab->iPKey==i
4700: 43 6f 6c 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e  Col ){.      p->
4710: 69 43 6f 6c 75 6d 6e 20 3d 20 2d 31 3b 0a 20 20  iColumn = -1;.  
4720: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 70    }else{.      p
4730: 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20 28 79 6e 56  ->iColumn = (ynV
4740: 61 72 29 69 43 6f 6c 3b 0a 20 20 20 20 20 20 74  ar)iCol;.      t
4750: 65 73 74 63 61 73 65 28 20 69 43 6f 6c 3d 3d 42  estcase( iCol==B
4760: 4d 53 20 29 3b 0a 20 20 20 20 20 20 74 65 73 74  MS );.      test
4770: 63 61 73 65 28 20 69 43 6f 6c 3d 3d 42 4d 53 2d  case( iCol==BMS-
4780: 31 20 29 3b 0a 20 20 20 20 20 20 70 49 74 65 6d  1 );.      pItem
4790: 2d 3e 63 6f 6c 55 73 65 64 20 7c 3d 20 28 28 42  ->colUsed |= ((B
47a0: 69 74 6d 61 73 6b 29 31 29 3c 3c 28 69 43 6f 6c  itmask)1)<<(iCol
47b0: 3e 3d 42 4d 53 20 3f 20 42 4d 53 2d 31 20 3a 20  >=BMS ? BMS-1 : 
47c0: 69 43 6f 6c 29 3b 0a 20 20 20 20 7d 0a 20 20 7d  iCol);.    }.  }
47d0: 0a 20 20 72 65 74 75 72 6e 20 70 3b 0a 7d 0a 0a  .  return p;.}..
47e0: 2f 2a 0a 2a 2a 20 52 65 70 6f 72 74 20 61 6e 20  /*.** Report an 
47f0: 65 72 72 6f 72 20 74 68 61 74 20 61 6e 20 65 78  error that an ex
4800: 70 72 65 73 73 69 6f 6e 20 69 73 20 6e 6f 74 20  pression is not 
4810: 76 61 6c 69 64 20 66 6f 72 20 73 6f 6d 65 20 73  valid for some s
4820: 65 74 20 6f 66 0a 2a 2a 20 70 4e 43 2d 3e 6e 63  et of.** pNC->nc
4830: 46 6c 61 67 73 20 76 61 6c 75 65 73 20 64 65 74  Flags values det
4840: 65 72 6d 69 6e 65 64 20 62 79 20 76 61 6c 69 64  ermined by valid
4850: 4d 61 73 6b 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  Mask..*/.static 
4860: 76 6f 69 64 20 6e 6f 74 56 61 6c 69 64 28 0a 20  void notValid(. 
4870: 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20   Parse *pParse, 
4880: 20 20 20 20 20 20 2f 2a 20 4c 65 61 76 65 20 65        /* Leave e
4890: 72 72 6f 72 20 6d 65 73 73 61 67 65 20 68 65 72  rror message her
48a0: 65 20 2a 2f 0a 20 20 4e 61 6d 65 43 6f 6e 74 65  e */.  NameConte
48b0: 78 74 20 2a 70 4e 43 2c 20 20 20 20 2f 2a 20 54  xt *pNC,    /* T
48c0: 68 65 20 6e 61 6d 65 20 63 6f 6e 74 65 78 74 20  he name context 
48d0: 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  */.  const char 
48e0: 2a 7a 4d 73 67 2c 20 20 20 20 2f 2a 20 54 79 70  *zMsg,    /* Typ
48f0: 65 20 6f 66 20 65 72 72 6f 72 20 2a 2f 0a 20 20  e of error */.  
4900: 69 6e 74 20 76 61 6c 69 64 4d 61 73 6b 20 20 20  int validMask   
4910: 20 20 20 20 20 2f 2a 20 53 65 74 20 6f 66 20 63       /* Set of c
4920: 6f 6e 74 65 78 74 73 20 66 6f 72 20 77 68 69 63  ontexts for whic
4930: 68 20 70 72 6f 68 69 62 69 74 65 64 20 2a 2f 0a  h prohibited */.
4940: 29 7b 0a 20 20 61 73 73 65 72 74 28 20 28 76 61  ){.  assert( (va
4950: 6c 69 64 4d 61 73 6b 26 7e 28 4e 43 5f 49 73 43  lidMask&~(NC_IsC
4960: 68 65 63 6b 7c 4e 43 5f 50 61 72 74 49 64 78 7c  heck|NC_PartIdx|
4970: 4e 43 5f 49 64 78 45 78 70 72 29 29 3d 3d 30 20  NC_IdxExpr))==0 
4980: 29 3b 0a 20 20 69 66 28 20 28 70 4e 43 2d 3e 6e  );.  if( (pNC->n
4990: 63 46 6c 61 67 73 20 26 20 76 61 6c 69 64 4d 61  cFlags & validMa
49a0: 73 6b 29 21 3d 30 20 29 7b 0a 20 20 20 20 63 6f  sk)!=0 ){.    co
49b0: 6e 73 74 20 63 68 61 72 20 2a 7a 49 6e 20 3d 20  nst char *zIn = 
49c0: 22 70 61 72 74 69 61 6c 20 69 6e 64 65 78 20 57  "partial index W
49d0: 48 45 52 45 20 63 6c 61 75 73 65 73 22 3b 0a 20  HERE clauses";. 
49e0: 20 20 20 69 66 28 20 70 4e 43 2d 3e 6e 63 46 6c     if( pNC->ncFl
49f0: 61 67 73 20 26 20 4e 43 5f 49 64 78 45 78 70 72  ags & NC_IdxExpr
4a00: 20 29 20 20 20 20 20 20 7a 49 6e 20 3d 20 22 69   )      zIn = "i
4a10: 6e 64 65 78 20 65 78 70 72 65 73 73 69 6f 6e 73  ndex expressions
4a20: 22 3b 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  ";.#ifndef SQLIT
4a30: 45 5f 4f 4d 49 54 5f 43 48 45 43 4b 0a 20 20 20  E_OMIT_CHECK.   
4a40: 20 65 6c 73 65 20 69 66 28 20 70 4e 43 2d 3e 6e   else if( pNC->n
4a50: 63 46 6c 61 67 73 20 26 20 4e 43 5f 49 73 43 68  cFlags & NC_IsCh
4a60: 65 63 6b 20 29 20 7a 49 6e 20 3d 20 22 43 48 45  eck ) zIn = "CHE
4a70: 43 4b 20 63 6f 6e 73 74 72 61 69 6e 74 73 22 3b  CK constraints";
4a80: 0a 23 65 6e 64 69 66 0a 20 20 20 20 73 71 6c 69  .#endif.    sqli
4a90: 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72  te3ErrorMsg(pPar
4aa0: 73 65 2c 20 22 25 73 20 70 72 6f 68 69 62 69 74  se, "%s prohibit
4ab0: 65 64 20 69 6e 20 25 73 22 2c 20 7a 4d 73 67 2c  ed in %s", zMsg,
4ac0: 20 7a 49 6e 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a   zIn);.  }.}../*
4ad0: 0a 2a 2a 20 45 78 70 72 65 73 73 69 6f 6e 20 70  .** Expression p
4ae0: 20 73 68 6f 75 6c 64 20 65 6e 63 6f 64 65 20 61   should encode a
4af0: 20 66 6c 6f 61 74 69 6e 67 20 70 6f 69 6e 74 20   floating point 
4b00: 76 61 6c 75 65 20 62 65 74 77 65 65 6e 20 31 2e  value between 1.
4b10: 30 20 61 6e 64 20 30 2e 30 2e 0a 2a 2a 20 52 65  0 and 0.0..** Re
4b20: 74 75 72 6e 20 31 30 32 34 20 74 69 6d 65 73 20  turn 1024 times 
4b30: 74 68 69 73 20 76 61 6c 75 65 2e 20 20 4f 72 20  this value.  Or 
4b40: 72 65 74 75 72 6e 20 2d 31 20 69 66 20 70 20 69  return -1 if p i
4b50: 73 20 6e 6f 74 20 61 20 66 6c 6f 61 74 69 6e 67  s not a floating
4b60: 20 70 6f 69 6e 74 0a 2a 2a 20 76 61 6c 75 65 20   point.** value 
4b70: 62 65 74 77 65 65 6e 20 31 2e 30 20 61 6e 64 20  between 1.0 and 
4b80: 30 2e 30 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  0.0..*/.static i
4b90: 6e 74 20 65 78 70 72 50 72 6f 62 61 62 69 6c 69  nt exprProbabili
4ba0: 74 79 28 45 78 70 72 20 2a 70 29 7b 0a 20 20 64  ty(Expr *p){.  d
4bb0: 6f 75 62 6c 65 20 72 20 3d 20 2d 31 2e 30 3b 0a  ouble r = -1.0;.
4bc0: 20 20 69 66 28 20 70 2d 3e 6f 70 21 3d 54 4b 5f    if( p->op!=TK_
4bd0: 46 4c 4f 41 54 20 29 20 72 65 74 75 72 6e 20 2d  FLOAT ) return -
4be0: 31 3b 0a 20 20 73 71 6c 69 74 65 33 41 74 6f 46  1;.  sqlite3AtoF
4bf0: 28 70 2d 3e 75 2e 7a 54 6f 6b 65 6e 2c 20 26 72  (p->u.zToken, &r
4c00: 2c 20 73 71 6c 69 74 65 33 53 74 72 6c 65 6e 33  , sqlite3Strlen3
4c10: 30 28 70 2d 3e 75 2e 7a 54 6f 6b 65 6e 29 2c 20  0(p->u.zToken), 
4c20: 53 51 4c 49 54 45 5f 55 54 46 38 29 3b 0a 20 20  SQLITE_UTF8);.  
4c30: 61 73 73 65 72 74 28 20 72 3e 3d 30 2e 30 20 29  assert( r>=0.0 )
4c40: 3b 0a 20 20 69 66 28 20 72 3e 31 2e 30 20 29 20  ;.  if( r>1.0 ) 
4c50: 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 72 65 74  return -1;.  ret
4c60: 75 72 6e 20 28 69 6e 74 29 28 72 2a 31 33 34 32  urn (int)(r*1342
4c70: 31 37 37 32 38 2e 30 29 3b 0a 7d 0a 0a 2f 2a 0a  17728.0);.}../*.
4c80: 2a 2a 20 54 68 69 73 20 72 6f 75 74 69 6e 65 20  ** This routine 
4c90: 69 73 20 63 61 6c 6c 62 61 63 6b 20 66 6f 72 20  is callback for 
4ca0: 73 71 6c 69 74 65 33 57 61 6c 6b 45 78 70 72 28  sqlite3WalkExpr(
4cb0: 29 2e 0a 2a 2a 0a 2a 2a 20 52 65 73 6f 6c 76 65  )..**.** Resolve
4cc0: 20 73 79 6d 62 6f 6c 69 63 20 6e 61 6d 65 73 20   symbolic names 
4cd0: 69 6e 74 6f 20 54 4b 5f 43 4f 4c 55 4d 4e 20 6f  into TK_COLUMN o
4ce0: 70 65 72 61 74 6f 72 73 20 66 6f 72 20 74 68 65  perators for the
4cf0: 20 63 75 72 72 65 6e 74 0a 2a 2a 20 6e 6f 64 65   current.** node
4d00: 20 69 6e 20 74 68 65 20 65 78 70 72 65 73 73 69   in the expressi
4d10: 6f 6e 20 74 72 65 65 2e 20 20 52 65 74 75 72 6e  on tree.  Return
4d20: 20 30 20 74 6f 20 63 6f 6e 74 69 6e 75 65 20 74   0 to continue t
4d30: 68 65 20 73 65 61 72 63 68 20 64 6f 77 6e 0a 2a  he search down.*
4d40: 2a 20 74 68 65 20 74 72 65 65 20 6f 72 20 32 20  * the tree or 2 
4d50: 74 6f 20 61 62 6f 72 74 20 74 68 65 20 74 72 65  to abort the tre
4d60: 65 20 77 61 6c 6b 2e 0a 2a 2a 0a 2a 2a 20 54 68  e walk..**.** Th
4d70: 69 73 20 72 6f 75 74 69 6e 65 20 61 6c 73 6f 20  is routine also 
4d80: 64 6f 65 73 20 65 72 72 6f 72 20 63 68 65 63 6b  does error check
4d90: 69 6e 67 20 61 6e 64 20 6e 61 6d 65 20 72 65 73  ing and name res
4da0: 6f 6c 75 74 69 6f 6e 20 66 6f 72 0a 2a 2a 20 66  olution for.** f
4db0: 75 6e 63 74 69 6f 6e 20 6e 61 6d 65 73 2e 20 20  unction names.  
4dc0: 54 68 65 20 6f 70 65 72 61 74 6f 72 20 66 6f 72  The operator for
4dd0: 20 61 67 67 72 65 67 61 74 65 20 66 75 6e 63 74   aggregate funct
4de0: 69 6f 6e 73 20 69 73 20 63 68 61 6e 67 65 64 0a  ions is changed.
4df0: 2a 2a 20 74 6f 20 54 4b 5f 41 47 47 5f 46 55 4e  ** to TK_AGG_FUN
4e00: 43 54 49 4f 4e 2e 0a 2a 2f 0a 73 74 61 74 69 63  CTION..*/.static
4e10: 20 69 6e 74 20 72 65 73 6f 6c 76 65 45 78 70 72   int resolveExpr
4e20: 53 74 65 70 28 57 61 6c 6b 65 72 20 2a 70 57 61  Step(Walker *pWa
4e30: 6c 6b 65 72 2c 20 45 78 70 72 20 2a 70 45 78 70  lker, Expr *pExp
4e40: 72 29 7b 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78  r){.  NameContex
4e50: 74 20 2a 70 4e 43 3b 0a 20 20 50 61 72 73 65 20  t *pNC;.  Parse 
4e60: 2a 70 50 61 72 73 65 3b 0a 0a 20 20 70 4e 43 20  *pParse;..  pNC 
4e70: 3d 20 70 57 61 6c 6b 65 72 2d 3e 75 2e 70 4e 43  = pWalker->u.pNC
4e80: 3b 0a 20 20 61 73 73 65 72 74 28 20 70 4e 43 21  ;.  assert( pNC!
4e90: 3d 30 20 29 3b 0a 20 20 70 50 61 72 73 65 20 3d  =0 );.  pParse =
4ea0: 20 70 4e 43 2d 3e 70 50 61 72 73 65 3b 0a 20 20   pNC->pParse;.  
4eb0: 61 73 73 65 72 74 28 20 70 50 61 72 73 65 3d 3d  assert( pParse==
4ec0: 70 57 61 6c 6b 65 72 2d 3e 70 50 61 72 73 65 20  pWalker->pParse 
4ed0: 29 3b 0a 0a 23 69 66 6e 64 65 66 20 4e 44 45 42  );..#ifndef NDEB
4ee0: 55 47 0a 20 20 69 66 28 20 70 4e 43 2d 3e 70 53  UG.  if( pNC->pS
4ef0: 72 63 4c 69 73 74 20 26 26 20 70 4e 43 2d 3e 70  rcList && pNC->p
4f00: 53 72 63 4c 69 73 74 2d 3e 6e 41 6c 6c 6f 63 3e  SrcList->nAlloc>
4f10: 30 20 29 7b 0a 20 20 20 20 53 72 63 4c 69 73 74  0 ){.    SrcList
4f20: 20 2a 70 53 72 63 4c 69 73 74 20 3d 20 70 4e 43   *pSrcList = pNC
4f30: 2d 3e 70 53 72 63 4c 69 73 74 3b 0a 20 20 20 20  ->pSrcList;.    
4f40: 69 6e 74 20 69 3b 0a 20 20 20 20 66 6f 72 28 69  int i;.    for(i
4f50: 3d 30 3b 20 69 3c 70 4e 43 2d 3e 70 53 72 63 4c  =0; i<pNC->pSrcL
4f60: 69 73 74 2d 3e 6e 53 72 63 3b 20 69 2b 2b 29 7b  ist->nSrc; i++){
4f70: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70  .      assert( p
4f80: 53 72 63 4c 69 73 74 2d 3e 61 5b 69 5d 2e 69 43  SrcList->a[i].iC
4f90: 75 72 73 6f 72 3e 3d 30 20 26 26 20 70 53 72 63  ursor>=0 && pSrc
4fa0: 4c 69 73 74 2d 3e 61 5b 69 5d 2e 69 43 75 72 73  List->a[i].iCurs
4fb0: 6f 72 3c 70 50 61 72 73 65 2d 3e 6e 54 61 62 29  or<pParse->nTab)
4fc0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 23 65 6e 64  ;.    }.  }.#end
4fd0: 69 66 0a 20 20 73 77 69 74 63 68 28 20 70 45 78  if.  switch( pEx
4fe0: 70 72 2d 3e 6f 70 20 29 7b 0a 0a 23 69 66 20 64  pr->op ){..#if d
4ff0: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 45 4e  efined(SQLITE_EN
5000: 41 42 4c 45 5f 55 50 44 41 54 45 5f 44 45 4c 45  ABLE_UPDATE_DELE
5010: 54 45 5f 4c 49 4d 49 54 29 20 26 26 20 21 64 65  TE_LIMIT) && !de
5020: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
5030: 54 5f 53 55 42 51 55 45 52 59 29 0a 20 20 20 20  T_SUBQUERY).    
5040: 2f 2a 20 54 68 65 20 73 70 65 63 69 61 6c 20 6f  /* The special o
5050: 70 65 72 61 74 6f 72 20 54 4b 5f 52 4f 57 20 6d  perator TK_ROW m
5060: 65 61 6e 73 20 75 73 65 20 74 68 65 20 72 6f 77  eans use the row
5070: 69 64 20 66 6f 72 20 74 68 65 20 66 69 72 73 74  id for the first
5080: 0a 20 20 20 20 2a 2a 20 63 6f 6c 75 6d 6e 20 69  .    ** column i
5090: 6e 20 74 68 65 20 46 52 4f 4d 20 63 6c 61 75 73  n the FROM claus
50a0: 65 2e 20 20 54 68 69 73 20 69 73 20 75 73 65 64  e.  This is used
50b0: 20 62 79 20 74 68 65 20 4c 49 4d 49 54 20 61 6e   by the LIMIT an
50c0: 64 20 4f 52 44 45 52 20 42 59 0a 20 20 20 20 2a  d ORDER BY.    *
50d0: 2a 20 63 6c 61 75 73 65 20 70 72 6f 63 65 73 73  * clause process
50e0: 69 6e 67 20 6f 6e 20 55 50 44 41 54 45 20 61 6e  ing on UPDATE an
50f0: 64 20 44 45 4c 45 54 45 20 73 74 61 74 65 6d 65  d DELETE stateme
5100: 6e 74 73 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  nts..    */.    
5110: 63 61 73 65 20 54 4b 5f 52 4f 57 3a 20 7b 0a 20  case TK_ROW: {. 
5120: 20 20 20 20 20 53 72 63 4c 69 73 74 20 2a 70 53       SrcList *pS
5130: 72 63 4c 69 73 74 20 3d 20 70 4e 43 2d 3e 70 53  rcList = pNC->pS
5140: 72 63 4c 69 73 74 3b 0a 20 20 20 20 20 20 73 74  rcList;.      st
5150: 72 75 63 74 20 53 72 63 4c 69 73 74 5f 69 74 65  ruct SrcList_ite
5160: 6d 20 2a 70 49 74 65 6d 3b 0a 20 20 20 20 20 20  m *pItem;.      
5170: 61 73 73 65 72 74 28 20 70 53 72 63 4c 69 73 74  assert( pSrcList
5180: 20 26 26 20 70 53 72 63 4c 69 73 74 2d 3e 6e 53   && pSrcList->nS
5190: 72 63 3d 3d 31 20 29 3b 0a 20 20 20 20 20 20 70  rc==1 );.      p
51a0: 49 74 65 6d 20 3d 20 70 53 72 63 4c 69 73 74 2d  Item = pSrcList-
51b0: 3e 61 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74  >a;.      assert
51c0: 28 20 48 61 73 52 6f 77 69 64 28 70 49 74 65 6d  ( HasRowid(pItem
51d0: 2d 3e 70 54 61 62 29 20 26 26 20 70 49 74 65 6d  ->pTab) && pItem
51e0: 2d 3e 70 54 61 62 2d 3e 70 53 65 6c 65 63 74 3d  ->pTab->pSelect=
51f0: 3d 30 20 29 3b 0a 20 20 20 20 20 20 70 45 78 70  =0 );.      pExp
5200: 72 2d 3e 6f 70 20 3d 20 54 4b 5f 43 4f 4c 55 4d  r->op = TK_COLUM
5210: 4e 3b 0a 20 20 20 20 20 20 70 45 78 70 72 2d 3e  N;.      pExpr->
5220: 70 54 61 62 20 3d 20 70 49 74 65 6d 2d 3e 70 54  pTab = pItem->pT
5230: 61 62 3b 0a 20 20 20 20 20 20 70 45 78 70 72 2d  ab;.      pExpr-
5240: 3e 69 54 61 62 6c 65 20 3d 20 70 49 74 65 6d 2d  >iTable = pItem-
5250: 3e 69 43 75 72 73 6f 72 3b 0a 20 20 20 20 20 20  >iCursor;.      
5260: 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d  pExpr->iColumn =
5270: 20 2d 31 3b 0a 20 20 20 20 20 20 70 45 78 70 72   -1;.      pExpr
5280: 2d 3e 61 66 66 69 6e 69 74 79 20 3d 20 53 51 4c  ->affinity = SQL
5290: 49 54 45 5f 41 46 46 5f 49 4e 54 45 47 45 52 3b  ITE_AFF_INTEGER;
52a0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
52b0: 20 20 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 64 65    }.#endif /* de
52c0: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 45 4e 41  fined(SQLITE_ENA
52d0: 42 4c 45 5f 55 50 44 41 54 45 5f 44 45 4c 45 54  BLE_UPDATE_DELET
52e0: 45 5f 4c 49 4d 49 54 29 0a 20 20 20 20 20 20 20  E_LIMIT).       
52f0: 20 20 20 26 26 20 21 64 65 66 69 6e 65 64 28 53     && !defined(S
5300: 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 55 42 51 55  QLITE_OMIT_SUBQU
5310: 45 52 59 29 20 2a 2f 0a 0a 20 20 20 20 2f 2a 20  ERY) */..    /* 
5320: 41 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 3a 20 20  A column name:  
5330: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5340: 20 20 49 44 0a 20 20 20 20 2a 2a 20 4f 72 20 74    ID.    ** Or t
5350: 61 62 6c 65 20 6e 61 6d 65 20 61 6e 64 20 63 6f  able name and co
5360: 6c 75 6d 6e 20 6e 61 6d 65 3a 20 20 20 20 49 44  lumn name:    ID
5370: 2e 49 44 0a 20 20 20 20 2a 2a 20 4f 72 20 61 20  .ID.    ** Or a 
5380: 64 61 74 61 62 61 73 65 2c 20 74 61 62 6c 65 20  database, table 
5390: 61 6e 64 20 63 6f 6c 75 6d 6e 3a 20 20 49 44 2e  and column:  ID.
53a0: 49 44 2e 49 44 0a 20 20 20 20 2a 2a 0a 20 20 20  ID.ID.    **.   
53b0: 20 2a 2a 20 54 68 65 20 54 4b 5f 49 44 20 61 6e   ** The TK_ID an
53c0: 64 20 54 4b 5f 4f 55 54 20 63 61 73 65 73 20 61  d TK_OUT cases a
53d0: 72 65 20 63 6f 6d 62 69 6e 65 64 20 73 6f 20 74  re combined so t
53e0: 68 61 74 20 74 68 65 72 65 20 77 69 6c 6c 20 6f  hat there will o
53f0: 6e 6c 79 0a 20 20 20 20 2a 2a 20 62 65 20 6f 6e  nly.    ** be on
5400: 65 20 63 61 6c 6c 20 74 6f 20 6c 6f 6f 6b 75 70  e call to lookup
5410: 4e 61 6d 65 28 29 2e 20 20 54 68 65 6e 20 74 68  Name().  Then th
5420: 65 20 63 6f 6d 70 69 6c 65 72 20 77 69 6c 6c 20  e compiler will 
5430: 69 6e 2d 6c 69 6e 65 20 0a 20 20 20 20 2a 2a 20  in-line .    ** 
5440: 6c 6f 6f 6b 75 70 4e 61 6d 65 28 29 20 66 6f 72  lookupName() for
5450: 20 61 20 73 69 7a 65 20 72 65 64 75 63 74 69 6f   a size reductio
5460: 6e 20 61 6e 64 20 70 65 72 66 6f 72 6d 61 6e 63  n and performanc
5470: 65 20 69 6e 63 72 65 61 73 65 2e 0a 20 20 20 20  e increase..    
5480: 2a 2f 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49  */.    case TK_I
5490: 44 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 44  D:.    case TK_D
54a0: 4f 54 3a 20 7b 0a 20 20 20 20 20 20 63 6f 6e 73  OT: {.      cons
54b0: 74 20 63 68 61 72 20 2a 7a 43 6f 6c 75 6d 6e 3b  t char *zColumn;
54c0: 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68 61  .      const cha
54d0: 72 20 2a 7a 54 61 62 6c 65 3b 0a 20 20 20 20 20  r *zTable;.     
54e0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62   const char *zDb
54f0: 3b 0a 20 20 20 20 20 20 45 78 70 72 20 2a 70 52  ;.      Expr *pR
5500: 69 67 68 74 3b 0a 0a 20 20 20 20 20 20 69 66 28  ight;..      if(
5510: 20 70 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b 5f 49   pExpr->op==TK_I
5520: 44 20 29 7b 0a 20 20 20 20 20 20 20 20 7a 44 62  D ){.        zDb
5530: 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 7a 54   = 0;.        zT
5540: 61 62 6c 65 20 3d 20 30 3b 0a 20 20 20 20 20 20  able = 0;.      
5550: 20 20 7a 43 6f 6c 75 6d 6e 20 3d 20 70 45 78 70    zColumn = pExp
5560: 72 2d 3e 75 2e 7a 54 6f 6b 65 6e 3b 0a 20 20 20  r->u.zToken;.   
5570: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
5580: 20 20 6e 6f 74 56 61 6c 69 64 28 70 50 61 72 73    notValid(pPars
5590: 65 2c 20 70 4e 43 2c 20 22 74 68 65 20 5c 22 2e  e, pNC, "the \".
55a0: 5c 22 20 6f 70 65 72 61 74 6f 72 22 2c 20 4e 43  \" operator", NC
55b0: 5f 49 64 78 45 78 70 72 29 3b 0a 20 20 20 20 20  _IdxExpr);.     
55c0: 20 20 20 70 52 69 67 68 74 20 3d 20 70 45 78 70     pRight = pExp
55d0: 72 2d 3e 70 52 69 67 68 74 3b 0a 20 20 20 20 20  r->pRight;.     
55e0: 20 20 20 69 66 28 20 70 52 69 67 68 74 2d 3e 6f     if( pRight->o
55f0: 70 3d 3d 54 4b 5f 49 44 20 29 7b 0a 20 20 20 20  p==TK_ID ){.    
5600: 20 20 20 20 20 20 7a 44 62 20 3d 20 30 3b 0a 20        zDb = 0;. 
5610: 20 20 20 20 20 20 20 20 20 7a 54 61 62 6c 65 20           zTable 
5620: 3d 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 2d 3e  = pExpr->pLeft->
5630: 75 2e 7a 54 6f 6b 65 6e 3b 0a 20 20 20 20 20 20  u.zToken;.      
5640: 20 20 20 20 7a 43 6f 6c 75 6d 6e 20 3d 20 70 52      zColumn = pR
5650: 69 67 68 74 2d 3e 75 2e 7a 54 6f 6b 65 6e 3b 0a  ight->u.zToken;.
5660: 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20          }else{. 
5670: 20 20 20 20 20 20 20 20 20 61 73 73 65 72 74 28           assert(
5680: 20 70 52 69 67 68 74 2d 3e 6f 70 3d 3d 54 4b 5f   pRight->op==TK_
5690: 44 4f 54 20 29 3b 0a 20 20 20 20 20 20 20 20 20  DOT );.         
56a0: 20 7a 44 62 20 3d 20 70 45 78 70 72 2d 3e 70 4c   zDb = pExpr->pL
56b0: 65 66 74 2d 3e 75 2e 7a 54 6f 6b 65 6e 3b 0a 20  eft->u.zToken;. 
56c0: 20 20 20 20 20 20 20 20 20 7a 54 61 62 6c 65 20           zTable 
56d0: 3d 20 70 52 69 67 68 74 2d 3e 70 4c 65 66 74 2d  = pRight->pLeft-
56e0: 3e 75 2e 7a 54 6f 6b 65 6e 3b 0a 20 20 20 20 20  >u.zToken;.     
56f0: 20 20 20 20 20 7a 43 6f 6c 75 6d 6e 20 3d 20 70       zColumn = p
5700: 52 69 67 68 74 2d 3e 70 52 69 67 68 74 2d 3e 75  Right->pRight->u
5710: 2e 7a 54 6f 6b 65 6e 3b 0a 20 20 20 20 20 20 20  .zToken;.       
5720: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
5730: 20 72 65 74 75 72 6e 20 6c 6f 6f 6b 75 70 4e 61   return lookupNa
5740: 6d 65 28 70 50 61 72 73 65 2c 20 7a 44 62 2c 20  me(pParse, zDb, 
5750: 7a 54 61 62 6c 65 2c 20 7a 43 6f 6c 75 6d 6e 2c  zTable, zColumn,
5760: 20 70 4e 43 2c 20 70 45 78 70 72 29 3b 0a 20 20   pNC, pExpr);.  
5770: 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 52 65 73 6f    }..    /* Reso
5780: 6c 76 65 20 66 75 6e 63 74 69 6f 6e 20 6e 61 6d  lve function nam
5790: 65 73 0a 20 20 20 20 2a 2f 0a 20 20 20 20 63 61  es.    */.    ca
57a0: 73 65 20 54 4b 5f 46 55 4e 43 54 49 4f 4e 3a 20  se TK_FUNCTION: 
57b0: 7b 0a 20 20 20 20 20 20 45 78 70 72 4c 69 73 74  {.      ExprList
57c0: 20 2a 70 4c 69 73 74 20 3d 20 70 45 78 70 72 2d   *pList = pExpr-
57d0: 3e 78 2e 70 4c 69 73 74 3b 20 20 20 20 2f 2a 20  >x.pList;    /* 
57e0: 54 68 65 20 61 72 67 75 6d 65 6e 74 20 6c 69 73  The argument lis
57f0: 74 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 6e  t */.      int n
5800: 20 3d 20 70 4c 69 73 74 20 3f 20 70 4c 69 73 74   = pList ? pList
5810: 2d 3e 6e 45 78 70 72 20 3a 20 30 3b 20 20 20 20  ->nExpr : 0;    
5820: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67  /* Number of arg
5830: 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 20 20 20 20  uments */.      
5840: 69 6e 74 20 6e 6f 5f 73 75 63 68 5f 66 75 6e 63  int no_such_func
5850: 20 3d 20 30 3b 20 20 20 20 20 20 20 2f 2a 20 54   = 0;       /* T
5860: 72 75 65 20 69 66 20 6e 6f 20 73 75 63 68 20 66  rue if no such f
5870: 75 6e 63 74 69 6f 6e 20 65 78 69 73 74 73 20 2a  unction exists *
5880: 2f 0a 20 20 20 20 20 20 69 6e 74 20 77 72 6f 6e  /.      int wron
5890: 67 5f 6e 75 6d 5f 61 72 67 73 20 3d 20 30 3b 20  g_num_args = 0; 
58a0: 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20 77      /* True if w
58b0: 72 6f 6e 67 20 6e 75 6d 62 65 72 20 6f 66 20 61  rong number of a
58c0: 72 67 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 20 20  rguments */.    
58d0: 20 20 69 6e 74 20 69 73 5f 61 67 67 20 3d 20 30    int is_agg = 0
58e0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ;             /*
58f0: 20 54 72 75 65 20 69 66 20 69 73 20 61 6e 20 61   True if is an a
5900: 67 67 72 65 67 61 74 65 20 66 75 6e 63 74 69 6f  ggregate functio
5910: 6e 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 6e  n */.      int n
5920: 49 64 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  Id;             
5930: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
5940: 20 6f 66 20 63 68 61 72 61 63 74 65 72 73 20 69   of characters i
5950: 6e 20 66 75 6e 63 74 69 6f 6e 20 6e 61 6d 65 20  n function name 
5960: 2a 2f 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 63  */.      const c
5970: 68 61 72 20 2a 7a 49 64 3b 20 20 20 20 20 20 20  har *zId;       
5980: 20 20 20 20 20 2f 2a 20 54 68 65 20 66 75 6e 63       /* The func
5990: 74 69 6f 6e 20 6e 61 6d 65 2e 20 2a 2f 0a 20 20  tion name. */.  
59a0: 20 20 20 20 46 75 6e 63 44 65 66 20 2a 70 44 65      FuncDef *pDe
59b0: 66 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  f;              
59c0: 2f 2a 20 49 6e 66 6f 72 6d 61 74 69 6f 6e 20 61  /* Information a
59d0: 62 6f 75 74 20 74 68 65 20 66 75 6e 63 74 69 6f  bout the functio
59e0: 6e 20 2a 2f 0a 20 20 20 20 20 20 75 38 20 65 6e  n */.      u8 en
59f0: 63 20 3d 20 45 4e 43 28 70 50 61 72 73 65 2d 3e  c = ENC(pParse->
5a00: 64 62 29 3b 20 20 20 2f 2a 20 54 68 65 20 64 61  db);   /* The da
5a10: 74 61 62 61 73 65 20 65 6e 63 6f 64 69 6e 67 20  tabase encoding 
5a20: 2a 2f 0a 0a 20 20 20 20 20 20 61 73 73 65 72 74  */..      assert
5a30: 28 20 21 45 78 70 72 48 61 73 50 72 6f 70 65 72  ( !ExprHasProper
5a40: 74 79 28 70 45 78 70 72 2c 20 45 50 5f 78 49 73  ty(pExpr, EP_xIs
5a50: 53 65 6c 65 63 74 29 20 29 3b 0a 20 20 20 20 20  Select) );.     
5a60: 20 7a 49 64 20 3d 20 70 45 78 70 72 2d 3e 75 2e   zId = pExpr->u.
5a70: 7a 54 6f 6b 65 6e 3b 0a 20 20 20 20 20 20 6e 49  zToken;.      nI
5a80: 64 20 3d 20 73 71 6c 69 74 65 33 53 74 72 6c 65  d = sqlite3Strle
5a90: 6e 33 30 28 7a 49 64 29 3b 0a 20 20 20 20 20 20  n30(zId);.      
5aa0: 70 44 65 66 20 3d 20 73 71 6c 69 74 65 33 46 69  pDef = sqlite3Fi
5ab0: 6e 64 46 75 6e 63 74 69 6f 6e 28 70 50 61 72 73  ndFunction(pPars
5ac0: 65 2d 3e 64 62 2c 20 7a 49 64 2c 20 6e 2c 20 65  e->db, zId, n, e
5ad0: 6e 63 2c 20 30 29 3b 0a 20 20 20 20 20 20 69 66  nc, 0);.      if
5ae0: 28 20 70 44 65 66 3d 3d 30 20 29 7b 0a 20 20 20  ( pDef==0 ){.   
5af0: 20 20 20 20 20 70 44 65 66 20 3d 20 73 71 6c 69       pDef = sqli
5b00: 74 65 33 46 69 6e 64 46 75 6e 63 74 69 6f 6e 28  te3FindFunction(
5b10: 70 50 61 72 73 65 2d 3e 64 62 2c 20 7a 49 64 2c  pParse->db, zId,
5b20: 20 2d 32 2c 20 65 6e 63 2c 20 30 29 3b 0a 20 20   -2, enc, 0);.  
5b30: 20 20 20 20 20 20 69 66 28 20 70 44 65 66 3d 3d        if( pDef==
5b40: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 6e  0 ){.          n
5b50: 6f 5f 73 75 63 68 5f 66 75 6e 63 20 3d 20 31 3b  o_such_func = 1;
5b60: 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a  .        }else{.
5b70: 20 20 20 20 20 20 20 20 20 20 77 72 6f 6e 67 5f            wrong_
5b80: 6e 75 6d 5f 61 72 67 73 20 3d 20 31 3b 0a 20 20  num_args = 1;.  
5b90: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 65        }.      }e
5ba0: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 69 73 5f  lse{.        is_
5bb0: 61 67 67 20 3d 20 70 44 65 66 2d 3e 78 46 69 6e  agg = pDef->xFin
5bc0: 61 6c 69 7a 65 21 3d 30 3b 0a 20 20 20 20 20 20  alize!=0;.      
5bd0: 20 20 69 66 28 20 70 44 65 66 2d 3e 66 75 6e 63    if( pDef->func
5be0: 46 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 46  Flags & SQLITE_F
5bf0: 55 4e 43 5f 55 4e 4c 49 4b 45 4c 59 20 29 7b 0a  UNC_UNLIKELY ){.
5c00: 20 20 20 20 20 20 20 20 20 20 45 78 70 72 53 65            ExprSe
5c10: 74 50 72 6f 70 65 72 74 79 28 70 45 78 70 72 2c  tProperty(pExpr,
5c20: 20 45 50 5f 55 6e 6c 69 6b 65 6c 79 7c 45 50 5f   EP_Unlikely|EP_
5c30: 53 6b 69 70 29 3b 0a 20 20 20 20 20 20 20 20 20  Skip);.         
5c40: 20 69 66 28 20 6e 3d 3d 32 20 29 7b 0a 20 20 20   if( n==2 ){.   
5c50: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
5c60: 69 54 61 62 6c 65 20 3d 20 65 78 70 72 50 72 6f  iTable = exprPro
5c70: 62 61 62 69 6c 69 74 79 28 70 4c 69 73 74 2d 3e  bability(pList->
5c80: 61 5b 31 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20  a[1].pExpr);.   
5c90: 20 20 20 20 20 20 20 20 20 69 66 28 20 70 45 78           if( pEx
5ca0: 70 72 2d 3e 69 54 61 62 6c 65 3c 30 20 29 7b 0a  pr->iTable<0 ){.
5cb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 71                sq
5cc0: 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50  lite3ErrorMsg(pP
5cd0: 61 72 73 65 2c 0a 20 20 20 20 20 20 20 20 20 20  arse,.          
5ce0: 20 20 20 20 20 20 22 73 65 63 6f 6e 64 20 61 72        "second ar
5cf0: 67 75 6d 65 6e 74 20 74 6f 20 6c 69 6b 65 6c 69  gument to likeli
5d00: 68 6f 6f 64 28 29 20 6d 75 73 74 20 62 65 20 61  hood() must be a
5d10: 20 22 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   ".             
5d20: 20 20 20 22 63 6f 6e 73 74 61 6e 74 20 62 65 74     "constant bet
5d30: 77 65 65 6e 20 30 2e 30 20 61 6e 64 20 31 2e 30  ween 0.0 and 1.0
5d40: 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ");.            
5d50: 20 20 70 4e 43 2d 3e 6e 45 72 72 2b 2b 3b 0a 20    pNC->nErr++;. 
5d60: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
5d70: 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20         }else{.  
5d80: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 45 56 49            /* EVI
5d90: 44 45 4e 43 45 2d 4f 46 3a 20 52 2d 36 31 33 30  DENCE-OF: R-6130
5da0: 34 2d 32 39 34 34 39 20 54 68 65 20 75 6e 6c 69  4-29449 The unli
5db0: 6b 65 6c 79 28 58 29 20 66 75 6e 63 74 69 6f 6e  kely(X) function
5dc0: 20 69 73 0a 20 20 20 20 20 20 20 20 20 20 20 20   is.            
5dd0: 2a 2a 20 65 71 75 69 76 61 6c 65 6e 74 20 74 6f  ** equivalent to
5de0: 20 6c 69 6b 65 6c 69 68 6f 6f 64 28 58 2c 20 30   likelihood(X, 0
5df0: 2e 30 36 32 35 29 2e 0a 20 20 20 20 20 20 20 20  .0625)..        
5e00: 20 20 20 20 2a 2a 20 45 56 49 44 45 4e 43 45 2d      ** EVIDENCE-
5e10: 4f 46 3a 20 52 2d 30 31 32 38 33 2d 31 31 36 33  OF: R-01283-1163
5e20: 36 20 54 68 65 20 75 6e 6c 69 6b 65 6c 79 28 58  6 The unlikely(X
5e30: 29 20 66 75 6e 63 74 69 6f 6e 20 69 73 0a 20 20  ) function is.  
5e40: 20 20 20 20 20 20 20 20 20 20 2a 2a 20 73 68 6f            ** sho
5e50: 72 74 2d 68 61 6e 64 20 66 6f 72 20 6c 69 6b 65  rt-hand for like
5e60: 6c 69 68 6f 6f 64 28 58 2c 30 2e 30 36 32 35 29  lihood(X,0.0625)
5e70: 2e 0a 20 20 20 20 20 20 20 20 20 20 20 20 2a 2a  ..            **
5e80: 20 45 56 49 44 45 4e 43 45 2d 4f 46 3a 20 52 2d   EVIDENCE-OF: R-
5e90: 33 36 38 35 30 2d 33 34 31 32 37 20 54 68 65 20  36850-34127 The 
5ea0: 6c 69 6b 65 6c 79 28 58 29 20 66 75 6e 63 74 69  likely(X) functi
5eb0: 6f 6e 20 69 73 20 73 68 6f 72 74 2d 68 61 6e 64  on is short-hand
5ec0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 2a 2a 20  .            ** 
5ed0: 66 6f 72 20 6c 69 6b 65 6c 69 68 6f 6f 64 28 58  for likelihood(X
5ee0: 2c 30 2e 39 33 37 35 29 2e 0a 20 20 20 20 20 20  ,0.9375)..      
5ef0: 20 20 20 20 20 20 2a 2a 20 45 56 49 44 45 4e 43        ** EVIDENC
5f00: 45 2d 4f 46 3a 20 52 2d 35 33 34 33 36 2d 34 30  E-OF: R-53436-40
5f10: 39 37 33 20 54 68 65 20 6c 69 6b 65 6c 79 28 58  973 The likely(X
5f20: 29 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 65 71  ) function is eq
5f30: 75 69 76 61 6c 65 6e 74 0a 20 20 20 20 20 20 20  uivalent.       
5f40: 20 20 20 20 20 2a 2a 20 74 6f 20 6c 69 6b 65 6c       ** to likel
5f50: 69 68 6f 6f 64 28 58 2c 30 2e 39 33 37 35 29 2e  ihood(X,0.9375).
5f60: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20   */.            
5f70: 2f 2a 20 54 55 4e 49 4e 47 3a 20 75 6e 6c 69 6b  /* TUNING: unlik
5f80: 65 6c 79 28 29 20 70 72 6f 62 61 62 69 6c 69 74  ely() probabilit
5f90: 79 20 69 73 20 30 2e 30 36 32 35 2e 20 20 6c 69  y is 0.0625.  li
5fa0: 6b 65 6c 79 28 29 20 69 73 20 30 2e 39 33 37 35  kely() is 0.9375
5fb0: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20   */.            
5fc0: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20  pExpr->iTable = 
5fd0: 70 44 65 66 2d 3e 7a 4e 61 6d 65 5b 30 5d 3d 3d  pDef->zName[0]==
5fe0: 27 75 27 20 3f 20 38 33 38 38 36 30 38 20 3a 20  'u' ? 8388608 : 
5ff0: 31 32 35 38 32 39 31 32 30 3b 0a 20 20 20 20 20  125829120;.     
6000: 20 20 20 20 20 7d 20 20 20 20 20 20 20 20 20 20       }          
6010: 20 20 20 0a 20 20 20 20 20 20 20 20 7d 0a 23 69     .        }.#i
6020: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
6030: 54 5f 41 55 54 48 4f 52 49 5a 41 54 49 4f 4e 0a  T_AUTHORIZATION.
6040: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
6050: 20 20 20 20 69 6e 74 20 61 75 74 68 20 3d 20 73      int auth = s
6060: 71 6c 69 74 65 33 41 75 74 68 43 68 65 63 6b 28  qlite3AuthCheck(
6070: 70 50 61 72 73 65 2c 20 53 51 4c 49 54 45 5f 46  pParse, SQLITE_F
6080: 55 4e 43 54 49 4f 4e 2c 20 30 2c 70 44 65 66 2d  UNCTION, 0,pDef-
6090: 3e 7a 4e 61 6d 65 2c 30 29 3b 0a 20 20 20 20 20  >zName,0);.     
60a0: 20 20 20 20 20 69 66 28 20 61 75 74 68 21 3d 53       if( auth!=S
60b0: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
60c0: 20 20 20 20 20 20 20 20 69 66 28 20 61 75 74 68          if( auth
60d0: 3d 3d 53 51 4c 49 54 45 5f 44 45 4e 59 20 29 7b  ==SQLITE_DENY ){
60e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73  .              s
60f0: 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70  qlite3ErrorMsg(p
6100: 50 61 72 73 65 2c 20 22 6e 6f 74 20 61 75 74 68  Parse, "not auth
6110: 6f 72 69 7a 65 64 20 74 6f 20 75 73 65 20 66 75  orized to use fu
6120: 6e 63 74 69 6f 6e 3a 20 25 73 22 2c 0a 20 20 20  nction: %s",.   
6130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6140: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6150: 20 20 20 70 44 65 66 2d 3e 7a 4e 61 6d 65 29 3b     pDef->zName);
6160: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70  .              p
6170: 4e 43 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20 20  NC->nErr++;.    
6180: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
6190: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 6f 70 20        pExpr->op 
61a0: 3d 20 54 4b 5f 4e 55 4c 4c 3b 0a 20 20 20 20 20  = TK_NULL;.     
61b0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 57 52         return WR
61c0: 43 5f 50 72 75 6e 65 3b 0a 20 20 20 20 20 20 20  C_Prune;.       
61d0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 23     }.        }.#
61e0: 65 6e 64 69 66 0a 20 20 20 20 20 20 20 20 69 66  endif.        if
61f0: 28 20 70 44 65 66 2d 3e 66 75 6e 63 46 6c 61 67  ( pDef->funcFlag
6200: 73 20 26 20 28 53 51 4c 49 54 45 5f 46 55 4e 43  s & (SQLITE_FUNC
6210: 5f 43 4f 4e 53 54 41 4e 54 7c 53 51 4c 49 54 45  _CONSTANT|SQLITE
6220: 5f 46 55 4e 43 5f 53 4c 4f 43 48 4e 47 29 20 29  _FUNC_SLOCHNG) )
6230: 7b 0a 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46  {.          /* F
6240: 6f 72 20 74 68 65 20 70 75 72 70 6f 73 65 73 20  or the purposes 
6250: 6f 66 20 74 68 65 20 45 50 5f 43 6f 6e 73 74 46  of the EP_ConstF
6260: 75 6e 63 20 66 6c 61 67 2c 20 64 61 74 65 20 61  unc flag, date a
6270: 6e 64 20 74 69 6d 65 0a 20 20 20 20 20 20 20 20  nd time.        
6280: 20 20 2a 2a 20 66 75 6e 63 74 69 6f 6e 73 20 61    ** functions a
6290: 6e 64 20 6f 74 68 65 72 20 66 75 6e 63 74 69 6f  nd other functio
62a0: 6e 73 20 74 68 61 74 20 63 68 61 6e 67 65 20 73  ns that change s
62b0: 6c 6f 77 6c 79 20 61 72 65 20 63 6f 6e 73 69 64  lowly are consid
62c0: 65 72 65 64 0a 20 20 20 20 20 20 20 20 20 20 2a  ered.          *
62d0: 2a 20 63 6f 6e 73 74 61 6e 74 20 62 65 63 61 75  * constant becau
62e0: 73 65 20 74 68 65 79 20 61 72 65 20 63 6f 6e 73  se they are cons
62f0: 74 61 6e 74 20 66 6f 72 20 74 68 65 20 64 75 72  tant for the dur
6300: 61 74 69 6f 6e 20 6f 66 20 6f 6e 65 20 71 75 65  ation of one que
6310: 72 79 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20  ry */.          
6320: 45 78 70 72 53 65 74 50 72 6f 70 65 72 74 79 28  ExprSetProperty(
6330: 70 45 78 70 72 2c 45 50 5f 43 6f 6e 73 74 46 75  pExpr,EP_ConstFu
6340: 6e 63 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  nc);.        }. 
6350: 20 20 20 20 20 20 20 69 66 28 20 28 70 44 65 66         if( (pDef
6360: 2d 3e 66 75 6e 63 46 6c 61 67 73 20 26 20 53 51  ->funcFlags & SQ
6370: 4c 49 54 45 5f 46 55 4e 43 5f 43 4f 4e 53 54 41  LITE_FUNC_CONSTA
6380: 4e 54 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  NT)==0 ){.      
6390: 20 20 20 20 2f 2a 20 44 61 74 65 2f 74 69 6d 65      /* Date/time
63a0: 20 66 75 6e 63 74 69 6f 6e 73 20 74 68 61 74 20   functions that 
63b0: 75 73 65 20 27 6e 6f 77 27 2c 20 61 6e 64 20 6f  use 'now', and o
63c0: 74 68 65 72 20 66 75 6e 63 74 69 6f 6e 73 20 6c  ther functions l
63d0: 69 6b 65 0a 20 20 20 20 20 20 20 20 20 20 2a 2a  ike.          **
63e0: 20 73 71 6c 69 74 65 5f 76 65 72 73 69 6f 6e 28   sqlite_version(
63f0: 29 20 74 68 61 74 20 6d 69 67 68 74 20 63 68 61  ) that might cha
6400: 6e 67 65 20 6f 76 65 72 20 74 69 6d 65 20 63 61  nge over time ca
6410: 6e 6e 6f 74 20 62 65 20 75 73 65 64 0a 20 20 20  nnot be used.   
6420: 20 20 20 20 20 20 20 2a 2a 20 69 6e 20 61 6e 20         ** in an 
6430: 69 6e 64 65 78 2e 20 2a 2f 0a 20 20 20 20 20 20  index. */.      
6440: 20 20 20 20 6e 6f 74 56 61 6c 69 64 28 70 50 61      notValid(pPa
6450: 72 73 65 2c 20 70 4e 43 2c 20 22 6e 6f 6e 2d 64  rse, pNC, "non-d
6460: 65 74 65 72 6d 69 6e 69 73 74 69 63 20 66 75 6e  eterministic fun
6470: 63 74 69 6f 6e 73 22 2c 0a 20 20 20 20 20 20 20  ctions",.       
6480: 20 20 20 20 20 20 20 20 20 20 20 20 4e 43 5f 49              NC_I
6490: 64 78 45 78 70 72 7c 4e 43 5f 50 61 72 74 49 64  dxExpr|NC_PartId
64a0: 78 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  x);.        }.  
64b0: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
64c0: 69 73 5f 61 67 67 20 26 26 20 28 70 4e 43 2d 3e  is_agg && (pNC->
64d0: 6e 63 46 6c 61 67 73 20 26 20 4e 43 5f 41 6c 6c  ncFlags & NC_All
64e0: 6f 77 41 67 67 29 3d 3d 30 20 29 7b 0a 20 20 20  owAgg)==0 ){.   
64f0: 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f       sqlite3Erro
6500: 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 6d 69  rMsg(pParse, "mi
6510: 73 75 73 65 20 6f 66 20 61 67 67 72 65 67 61 74  suse of aggregat
6520: 65 20 66 75 6e 63 74 69 6f 6e 20 25 2e 2a 73 28  e function %.*s(
6530: 29 22 2c 20 6e 49 64 2c 7a 49 64 29 3b 0a 20 20  )", nId,zId);.  
6540: 20 20 20 20 20 20 70 4e 43 2d 3e 6e 45 72 72 2b        pNC->nErr+
6550: 2b 3b 0a 20 20 20 20 20 20 20 20 69 73 5f 61 67  +;.        is_ag
6560: 67 20 3d 20 30 3b 0a 20 20 20 20 20 20 7d 65 6c  g = 0;.      }el
6570: 73 65 20 69 66 28 20 6e 6f 5f 73 75 63 68 5f 66  se if( no_such_f
6580: 75 6e 63 20 26 26 20 70 50 61 72 73 65 2d 3e 64  unc && pParse->d
6590: 62 2d 3e 69 6e 69 74 2e 62 75 73 79 3d 3d 30 0a  b->init.busy==0.
65a0: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e  #ifdef SQLITE_EN
65b0: 41 42 4c 45 5f 55 4e 4b 4e 4f 57 4e 5f 53 51 4c  ABLE_UNKNOWN_SQL
65c0: 5f 46 55 4e 43 54 49 4f 4e 0a 20 20 20 20 20 20  _FUNCTION.      
65d0: 20 20 20 20 20 20 20 20 20 20 26 26 20 70 50 61            && pPa
65e0: 72 73 65 2d 3e 65 78 70 6c 61 69 6e 3d 3d 30 0a  rse->explain==0.
65f0: 23 65 6e 64 69 66 0a 20 20 20 20 20 20 29 7b 0a  #endif.      ){.
6600: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 45          sqlite3E
6610: 72 72 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20  rrorMsg(pParse, 
6620: 22 6e 6f 20 73 75 63 68 20 66 75 6e 63 74 69 6f  "no such functio
6630: 6e 3a 20 25 2e 2a 73 22 2c 20 6e 49 64 2c 20 7a  n: %.*s", nId, z
6640: 49 64 29 3b 0a 20 20 20 20 20 20 20 20 70 4e 43  Id);.        pNC
6650: 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20 20 20 20  ->nErr++;.      
6660: 7d 65 6c 73 65 20 69 66 28 20 77 72 6f 6e 67 5f  }else if( wrong_
6670: 6e 75 6d 5f 61 72 67 73 20 29 7b 0a 20 20 20 20  num_args ){.    
6680: 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72      sqlite3Error
6690: 4d 73 67 28 70 50 61 72 73 65 2c 22 77 72 6f 6e  Msg(pParse,"wron
66a0: 67 20 6e 75 6d 62 65 72 20 6f 66 20 61 72 67 75  g number of argu
66b0: 6d 65 6e 74 73 20 74 6f 20 66 75 6e 63 74 69 6f  ments to functio
66c0: 6e 20 25 2e 2a 73 28 29 22 2c 0a 20 20 20 20 20  n %.*s()",.     
66d0: 20 20 20 20 20 20 20 20 6e 49 64 2c 20 7a 49 64          nId, zId
66e0: 29 3b 0a 20 20 20 20 20 20 20 20 70 4e 43 2d 3e  );.        pNC->
66f0: 6e 45 72 72 2b 2b 3b 0a 20 20 20 20 20 20 7d 0a  nErr++;.      }.
6700: 20 20 20 20 20 20 69 66 28 20 69 73 5f 61 67 67        if( is_agg
6710: 20 29 20 70 4e 43 2d 3e 6e 63 46 6c 61 67 73 20   ) pNC->ncFlags 
6720: 26 3d 20 7e 4e 43 5f 41 6c 6c 6f 77 41 67 67 3b  &= ~NC_AllowAgg;
6730: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 57 61  .      sqlite3Wa
6740: 6c 6b 45 78 70 72 4c 69 73 74 28 70 57 61 6c 6b  lkExprList(pWalk
6750: 65 72 2c 20 70 4c 69 73 74 29 3b 0a 20 20 20 20  er, pList);.    
6760: 20 20 69 66 28 20 69 73 5f 61 67 67 20 29 7b 0a    if( is_agg ){.
6770: 20 20 20 20 20 20 20 20 4e 61 6d 65 43 6f 6e 74          NameCont
6780: 65 78 74 20 2a 70 4e 43 32 20 3d 20 70 4e 43 3b  ext *pNC2 = pNC;
6790: 0a 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e  .        pExpr->
67a0: 6f 70 20 3d 20 54 4b 5f 41 47 47 5f 46 55 4e 43  op = TK_AGG_FUNC
67b0: 54 49 4f 4e 3b 0a 20 20 20 20 20 20 20 20 70 45  TION;.        pE
67c0: 78 70 72 2d 3e 6f 70 32 20 3d 20 30 3b 0a 20 20  xpr->op2 = 0;.  
67d0: 20 20 20 20 20 20 77 68 69 6c 65 28 20 70 4e 43        while( pNC
67e0: 32 20 26 26 20 21 73 71 6c 69 74 65 33 46 75 6e  2 && !sqlite3Fun
67f0: 63 74 69 6f 6e 55 73 65 73 54 68 69 73 53 72 63  ctionUsesThisSrc
6800: 28 70 45 78 70 72 2c 20 70 4e 43 32 2d 3e 70 53  (pExpr, pNC2->pS
6810: 72 63 4c 69 73 74 29 20 29 7b 0a 20 20 20 20 20  rcList) ){.     
6820: 20 20 20 20 20 70 45 78 70 72 2d 3e 6f 70 32 2b       pExpr->op2+
6830: 2b 3b 0a 20 20 20 20 20 20 20 20 20 20 70 4e 43  +;.          pNC
6840: 32 20 3d 20 70 4e 43 32 2d 3e 70 4e 65 78 74 3b  2 = pNC2->pNext;
6850: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
6860: 20 20 20 61 73 73 65 72 74 28 20 70 44 65 66 21     assert( pDef!
6870: 3d 30 20 29 3b 0a 20 20 20 20 20 20 20 20 69 66  =0 );.        if
6880: 28 20 70 4e 43 32 20 29 7b 0a 20 20 20 20 20 20  ( pNC2 ){.      
6890: 20 20 20 20 61 73 73 65 72 74 28 20 53 51 4c 49      assert( SQLI
68a0: 54 45 5f 46 55 4e 43 5f 4d 49 4e 4d 41 58 3d 3d  TE_FUNC_MINMAX==
68b0: 4e 43 5f 4d 69 6e 4d 61 78 41 67 67 20 29 3b 0a  NC_MinMaxAgg );.
68c0: 20 20 20 20 20 20 20 20 20 20 74 65 73 74 63 61            testca
68d0: 73 65 28 20 28 70 44 65 66 2d 3e 66 75 6e 63 46  se( (pDef->funcF
68e0: 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 46 55  lags & SQLITE_FU
68f0: 4e 43 5f 4d 49 4e 4d 41 58 29 21 3d 30 20 29 3b  NC_MINMAX)!=0 );
6900: 0a 20 20 20 20 20 20 20 20 20 20 70 4e 43 32 2d  .          pNC2-
6910: 3e 6e 63 46 6c 61 67 73 20 7c 3d 20 4e 43 5f 48  >ncFlags |= NC_H
6920: 61 73 41 67 67 20 7c 20 28 70 44 65 66 2d 3e 66  asAgg | (pDef->f
6930: 75 6e 63 46 6c 61 67 73 20 26 20 53 51 4c 49 54  uncFlags & SQLIT
6940: 45 5f 46 55 4e 43 5f 4d 49 4e 4d 41 58 29 3b 0a  E_FUNC_MINMAX);.
6950: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
6960: 20 20 20 70 4e 43 2d 3e 6e 63 46 6c 61 67 73 20     pNC->ncFlags 
6970: 7c 3d 20 4e 43 5f 41 6c 6c 6f 77 41 67 67 3b 0a  |= NC_AllowAgg;.
6980: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 2f 2a        }.      /*
6990: 20 46 49 58 20 4d 45 3a 20 20 43 6f 6d 70 75 74   FIX ME:  Comput
69a0: 65 20 70 45 78 70 72 2d 3e 61 66 66 69 6e 69 74  e pExpr->affinit
69b0: 79 20 62 61 73 65 64 20 6f 6e 20 74 68 65 20 65  y based on the e
69c0: 78 70 65 63 74 65 64 20 72 65 74 75 72 6e 0a 20  xpected return. 
69d0: 20 20 20 20 20 2a 2a 20 74 79 70 65 20 6f 66 20       ** type of 
69e0: 74 68 65 20 66 75 6e 63 74 69 6f 6e 20 0a 20 20  the function .  
69f0: 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 72 65 74      */.      ret
6a00: 75 72 6e 20 57 52 43 5f 50 72 75 6e 65 3b 0a 20  urn WRC_Prune;. 
6a10: 20 20 20 7d 0a 23 69 66 6e 64 65 66 20 53 51 4c     }.#ifndef SQL
6a20: 49 54 45 5f 4f 4d 49 54 5f 53 55 42 51 55 45 52  ITE_OMIT_SUBQUER
6a30: 59 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 53 45  Y.    case TK_SE
6a40: 4c 45 43 54 3a 0a 20 20 20 20 63 61 73 65 20 54  LECT:.    case T
6a50: 4b 5f 45 58 49 53 54 53 3a 20 20 74 65 73 74 63  K_EXISTS:  testc
6a60: 61 73 65 28 20 70 45 78 70 72 2d 3e 6f 70 3d 3d  ase( pExpr->op==
6a70: 54 4b 5f 45 58 49 53 54 53 20 29 3b 0a 23 65 6e  TK_EXISTS );.#en
6a80: 64 69 66 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  dif.    case TK_
6a90: 49 4e 3a 20 7b 0a 20 20 20 20 20 20 74 65 73 74  IN: {.      test
6aa0: 63 61 73 65 28 20 70 45 78 70 72 2d 3e 6f 70 3d  case( pExpr->op=
6ab0: 3d 54 4b 5f 49 4e 20 29 3b 0a 20 20 20 20 20 20  =TK_IN );.      
6ac0: 69 66 28 20 45 78 70 72 48 61 73 50 72 6f 70 65  if( ExprHasPrope
6ad0: 72 74 79 28 70 45 78 70 72 2c 20 45 50 5f 78 49  rty(pExpr, EP_xI
6ae0: 73 53 65 6c 65 63 74 29 20 29 7b 0a 20 20 20 20  sSelect) ){.    
6af0: 20 20 20 20 69 6e 74 20 6e 52 65 66 20 3d 20 70      int nRef = p
6b00: 4e 43 2d 3e 6e 52 65 66 3b 0a 20 20 20 20 20 20  NC->nRef;.      
6b10: 20 20 6e 6f 74 56 61 6c 69 64 28 70 50 61 72 73    notValid(pPars
6b20: 65 2c 20 70 4e 43 2c 20 22 73 75 62 71 75 65 72  e, pNC, "subquer
6b30: 69 65 73 22 2c 20 4e 43 5f 49 73 43 68 65 63 6b  ies", NC_IsCheck
6b40: 7c 4e 43 5f 50 61 72 74 49 64 78 7c 4e 43 5f 49  |NC_PartIdx|NC_I
6b50: 64 78 45 78 70 72 29 3b 0a 20 20 20 20 20 20 20  dxExpr);.       
6b60: 20 73 71 6c 69 74 65 33 57 61 6c 6b 53 65 6c 65   sqlite3WalkSele
6b70: 63 74 28 70 57 61 6c 6b 65 72 2c 20 70 45 78 70  ct(pWalker, pExp
6b80: 72 2d 3e 78 2e 70 53 65 6c 65 63 74 29 3b 0a 20  r->x.pSelect);. 
6b90: 20 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70         assert( p
6ba0: 4e 43 2d 3e 6e 52 65 66 3e 3d 6e 52 65 66 20 29  NC->nRef>=nRef )
6bb0: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 6e 52  ;.        if( nR
6bc0: 65 66 21 3d 70 4e 43 2d 3e 6e 52 65 66 20 29 7b  ef!=pNC->nRef ){
6bd0: 0a 20 20 20 20 20 20 20 20 20 20 45 78 70 72 53  .          ExprS
6be0: 65 74 50 72 6f 70 65 72 74 79 28 70 45 78 70 72  etProperty(pExpr
6bf0: 2c 20 45 50 5f 56 61 72 53 65 6c 65 63 74 29 3b  , EP_VarSelect);
6c00: 0a 20 20 20 20 20 20 20 20 20 20 70 4e 43 2d 3e  .          pNC->
6c10: 6e 63 46 6c 61 67 73 20 7c 3d 20 4e 43 5f 56 61  ncFlags |= NC_Va
6c20: 72 53 65 6c 65 63 74 3b 0a 20 20 20 20 20 20 20  rSelect;.       
6c30: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
6c40: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
6c50: 20 20 63 61 73 65 20 54 4b 5f 56 41 52 49 41 42    case TK_VARIAB
6c60: 4c 45 3a 20 7b 0a 20 20 20 20 20 20 6e 6f 74 56  LE: {.      notV
6c70: 61 6c 69 64 28 70 50 61 72 73 65 2c 20 70 4e 43  alid(pParse, pNC
6c80: 2c 20 22 70 61 72 61 6d 65 74 65 72 73 22 2c 20  , "parameters", 
6c90: 4e 43 5f 49 73 43 68 65 63 6b 7c 4e 43 5f 50 61  NC_IsCheck|NC_Pa
6ca0: 72 74 49 64 78 7c 4e 43 5f 49 64 78 45 78 70 72  rtIdx|NC_IdxExpr
6cb0: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
6cc0: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
6cd0: 4b 5f 49 53 3a 0a 20 20 20 20 63 61 73 65 20 54  K_IS:.    case T
6ce0: 4b 5f 49 53 4e 4f 54 3a 20 7b 0a 20 20 20 20 20  K_ISNOT: {.     
6cf0: 20 45 78 70 72 20 2a 70 52 69 67 68 74 3b 0a 20   Expr *pRight;. 
6d00: 20 20 20 20 20 61 73 73 65 72 74 28 20 21 45 78       assert( !Ex
6d10: 70 72 48 61 73 50 72 6f 70 65 72 74 79 28 70 45  prHasProperty(pE
6d20: 78 70 72 2c 20 45 50 5f 52 65 64 75 63 65 64 29  xpr, EP_Reduced)
6d30: 20 29 3b 0a 20 20 20 20 20 20 2f 2a 20 48 61 6e   );.      /* Han
6d40: 64 6c 65 20 73 70 65 63 69 61 6c 20 63 61 73 65  dle special case
6d50: 73 20 6f 66 20 22 78 20 49 53 20 54 52 55 45 22  s of "x IS TRUE"
6d60: 2c 20 22 78 20 49 53 20 46 41 4c 53 45 22 2c 20  , "x IS FALSE", 
6d70: 22 78 20 49 53 20 4e 4f 54 20 54 52 55 45 22 2c  "x IS NOT TRUE",
6d80: 0a 20 20 20 20 20 20 2a 2a 20 61 6e 64 20 22 78  .      ** and "x
6d90: 20 49 53 20 4e 4f 54 20 46 41 4c 53 45 22 2e 20   IS NOT FALSE". 
6da0: 2a 2f 0a 20 20 20 20 20 20 69 66 28 20 28 70 52  */.      if( (pR
6db0: 69 67 68 74 20 3d 20 70 45 78 70 72 2d 3e 70 52  ight = pExpr->pR
6dc0: 69 67 68 74 29 2d 3e 6f 70 3d 3d 54 4b 5f 49 44  ight)->op==TK_ID
6dd0: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20   ){.        int 
6de0: 72 63 20 3d 20 72 65 73 6f 6c 76 65 45 78 70 72  rc = resolveExpr
6df0: 53 74 65 70 28 70 57 61 6c 6b 65 72 2c 20 70 52  Step(pWalker, pR
6e00: 69 67 68 74 29 3b 0a 20 20 20 20 20 20 20 20 69  ight);.        i
6e10: 66 28 20 72 63 3d 3d 57 52 43 5f 41 62 6f 72 74  f( rc==WRC_Abort
6e20: 20 29 20 72 65 74 75 72 6e 20 57 52 43 5f 41 62   ) return WRC_Ab
6e30: 6f 72 74 3b 0a 20 20 20 20 20 20 20 20 69 66 28  ort;.        if(
6e40: 20 70 52 69 67 68 74 2d 3e 6f 70 3d 3d 54 4b 5f   pRight->op==TK_
6e50: 54 52 55 45 46 41 4c 53 45 20 29 7b 0a 20 20 20  TRUEFALSE ){.   
6e60: 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 6f 70         pExpr->op
6e70: 32 20 3d 20 70 45 78 70 72 2d 3e 6f 70 3b 0a 20  2 = pExpr->op;. 
6e80: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
6e90: 6f 70 20 3d 20 54 4b 5f 54 52 55 54 48 3b 0a 20  op = TK_TRUTH;. 
6ea0: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
6eb0: 57 52 43 5f 43 6f 6e 74 69 6e 75 65 3b 0a 20 20  WRC_Continue;.  
6ec0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
6ed0: 20 20 20 20 20 20 2f 2a 20 46 61 6c 6c 20 74 68        /* Fall th
6ee0: 72 75 20 2a 2f 0a 20 20 20 20 7d 0a 20 20 20 20  ru */.    }.    
6ef0: 63 61 73 65 20 54 4b 5f 42 45 54 57 45 45 4e 3a  case TK_BETWEEN:
6f00: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 45 51 3a  .    case TK_EQ:
6f10: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 45 3a  .    case TK_NE:
6f20: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 54 3a  .    case TK_LT:
6f30: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 45 3a  .    case TK_LE:
6f40: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 54 3a  .    case TK_GT:
6f50: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 45 3a  .    case TK_GE:
6f60: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 4c 65   {.      int nLe
6f70: 66 74 2c 20 6e 52 69 67 68 74 3b 0a 20 20 20 20  ft, nRight;.    
6f80: 20 20 69 66 28 20 70 50 61 72 73 65 2d 3e 64 62    if( pParse->db
6f90: 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 29  ->mallocFailed )
6fa0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 61 73   break;.      as
6fb0: 73 65 72 74 28 20 70 45 78 70 72 2d 3e 70 4c 65  sert( pExpr->pLe
6fc0: 66 74 21 3d 30 20 29 3b 0a 20 20 20 20 20 20 6e  ft!=0 );.      n
6fd0: 4c 65 66 74 20 3d 20 73 71 6c 69 74 65 33 45 78  Left = sqlite3Ex
6fe0: 70 72 56 65 63 74 6f 72 53 69 7a 65 28 70 45 78  prVectorSize(pEx
6ff0: 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20  pr->pLeft);.    
7000: 20 20 69 66 28 20 70 45 78 70 72 2d 3e 6f 70 3d    if( pExpr->op=
7010: 3d 54 4b 5f 42 45 54 57 45 45 4e 20 29 7b 0a 20  =TK_BETWEEN ){. 
7020: 20 20 20 20 20 20 20 6e 52 69 67 68 74 20 3d 20         nRight = 
7030: 73 71 6c 69 74 65 33 45 78 70 72 56 65 63 74 6f  sqlite3ExprVecto
7040: 72 53 69 7a 65 28 70 45 78 70 72 2d 3e 78 2e 70  rSize(pExpr->x.p
7050: 4c 69 73 74 2d 3e 61 5b 30 5d 2e 70 45 78 70 72  List->a[0].pExpr
7060: 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 6e  );.        if( n
7070: 52 69 67 68 74 3d 3d 6e 4c 65 66 74 20 29 7b 0a  Right==nLeft ){.
7080: 20 20 20 20 20 20 20 20 20 20 6e 52 69 67 68 74            nRight
7090: 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 56 65   = sqlite3ExprVe
70a0: 63 74 6f 72 53 69 7a 65 28 70 45 78 70 72 2d 3e  ctorSize(pExpr->
70b0: 78 2e 70 4c 69 73 74 2d 3e 61 5b 31 5d 2e 70 45  x.pList->a[1].pE
70c0: 78 70 72 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  xpr);.        }.
70d0: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
70e0: 20 20 20 20 20 61 73 73 65 72 74 28 20 70 45 78       assert( pEx
70f0: 70 72 2d 3e 70 52 69 67 68 74 21 3d 30 20 29 3b  pr->pRight!=0 );
7100: 0a 20 20 20 20 20 20 20 20 6e 52 69 67 68 74 20  .        nRight 
7110: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 56 65 63  = sqlite3ExprVec
7120: 74 6f 72 53 69 7a 65 28 70 45 78 70 72 2d 3e 70  torSize(pExpr->p
7130: 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20 7d 0a  Right);.      }.
7140: 20 20 20 20 20 20 69 66 28 20 6e 4c 65 66 74 21        if( nLeft!
7150: 3d 6e 52 69 67 68 74 20 29 7b 0a 20 20 20 20 20  =nRight ){.     
7160: 20 20 20 74 65 73 74 63 61 73 65 28 20 70 45 78     testcase( pEx
7170: 70 72 2d 3e 6f 70 3d 3d 54 4b 5f 45 51 20 29 3b  pr->op==TK_EQ );
7180: 0a 20 20 20 20 20 20 20 20 74 65 73 74 63 61 73  .        testcas
7190: 65 28 20 70 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b  e( pExpr->op==TK
71a0: 5f 4e 45 20 29 3b 0a 20 20 20 20 20 20 20 20 74  _NE );.        t
71b0: 65 73 74 63 61 73 65 28 20 70 45 78 70 72 2d 3e  estcase( pExpr->
71c0: 6f 70 3d 3d 54 4b 5f 4c 54 20 29 3b 0a 20 20 20  op==TK_LT );.   
71d0: 20 20 20 20 20 74 65 73 74 63 61 73 65 28 20 70       testcase( p
71e0: 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b 5f 4c 45 20  Expr->op==TK_LE 
71f0: 29 3b 0a 20 20 20 20 20 20 20 20 74 65 73 74 63  );.        testc
7200: 61 73 65 28 20 70 45 78 70 72 2d 3e 6f 70 3d 3d  ase( pExpr->op==
7210: 54 4b 5f 47 54 20 29 3b 0a 20 20 20 20 20 20 20  TK_GT );.       
7220: 20 74 65 73 74 63 61 73 65 28 20 70 45 78 70 72   testcase( pExpr
7230: 2d 3e 6f 70 3d 3d 54 4b 5f 47 45 20 29 3b 0a 20  ->op==TK_GE );. 
7240: 20 20 20 20 20 20 20 74 65 73 74 63 61 73 65 28         testcase(
7250: 20 70 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b 5f 49   pExpr->op==TK_I
7260: 53 20 29 3b 0a 20 20 20 20 20 20 20 20 74 65 73  S );.        tes
7270: 74 63 61 73 65 28 20 70 45 78 70 72 2d 3e 6f 70  tcase( pExpr->op
7280: 3d 3d 54 4b 5f 49 53 4e 4f 54 20 29 3b 0a 20 20  ==TK_ISNOT );.  
7290: 20 20 20 20 20 20 74 65 73 74 63 61 73 65 28 20        testcase( 
72a0: 70 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b 5f 42 45  pExpr->op==TK_BE
72b0: 54 57 45 45 4e 20 29 3b 0a 20 20 20 20 20 20 20  TWEEN );.       
72c0: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67   sqlite3ErrorMsg
72d0: 28 70 50 61 72 73 65 2c 20 22 72 6f 77 20 76 61  (pParse, "row va
72e0: 6c 75 65 20 6d 69 73 75 73 65 64 22 29 3b 0a 20  lue misused");. 
72f0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65       }.      bre
7300: 61 6b 3b 20 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  ak; .    }.  }. 
7310: 20 72 65 74 75 72 6e 20 28 70 50 61 72 73 65 2d   return (pParse-
7320: 3e 6e 45 72 72 20 7c 7c 20 70 50 61 72 73 65 2d  >nErr || pParse-
7330: 3e 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65  >db->mallocFaile
7340: 64 29 20 3f 20 57 52 43 5f 41 62 6f 72 74 20 3a  d) ? WRC_Abort :
7350: 20 57 52 43 5f 43 6f 6e 74 69 6e 75 65 3b 0a 7d   WRC_Continue;.}
7360: 0a 0a 2f 2a 0a 2a 2a 20 70 45 4c 69 73 74 20 69  ../*.** pEList i
7370: 73 20 61 20 6c 69 73 74 20 6f 66 20 65 78 70 72  s a list of expr
7380: 65 73 73 69 6f 6e 73 20 77 68 69 63 68 20 61 72  essions which ar
7390: 65 20 72 65 61 6c 6c 79 20 74 68 65 20 72 65 73  e really the res
73a0: 75 6c 74 20 73 65 74 20 6f 66 20 74 68 65 0a 2a  ult set of the.*
73b0: 2a 20 61 20 53 45 4c 45 43 54 20 73 74 61 74 65  * a SELECT state
73c0: 6d 65 6e 74 2e 20 20 70 45 20 69 73 20 61 20 74  ment.  pE is a t
73d0: 65 72 6d 20 69 6e 20 61 6e 20 4f 52 44 45 52 20  erm in an ORDER 
73e0: 42 59 20 6f 72 20 47 52 4f 55 50 20 42 59 20 63  BY or GROUP BY c
73f0: 6c 61 75 73 65 2e 0a 2a 2a 20 54 68 69 73 20 72  lause..** This r
7400: 6f 75 74 69 6e 65 20 63 68 65 63 6b 73 20 74 6f  outine checks to
7410: 20 73 65 65 20 69 66 20 70 45 20 69 73 20 61 20   see if pE is a 
7420: 73 69 6d 70 6c 65 20 69 64 65 6e 74 69 66 69 65  simple identifie
7430: 72 20 77 68 69 63 68 20 63 6f 72 72 65 73 70 6f  r which correspo
7440: 6e 64 73 0a 2a 2a 20 74 6f 20 74 68 65 20 41 53  nds.** to the AS
7450: 2d 6e 61 6d 65 20 6f 66 20 6f 6e 65 20 6f 66 20  -name of one of 
7460: 74 68 65 20 74 65 72 6d 73 20 6f 66 20 74 68 65  the terms of the
7470: 20 65 78 70 72 65 73 73 69 6f 6e 20 6c 69 73 74   expression list
7480: 2e 20 20 49 66 20 69 74 20 69 73 2c 0a 2a 2a 20  .  If it is,.** 
7490: 74 68 69 73 20 72 6f 75 74 69 6e 65 20 72 65 74  this routine ret
74a0: 75 72 6e 20 61 6e 20 69 6e 74 65 67 65 72 20 62  urn an integer b
74b0: 65 74 77 65 65 6e 20 31 20 61 6e 64 20 4e 20 77  etween 1 and N w
74c0: 68 65 72 65 20 4e 20 69 73 20 74 68 65 20 6e 75  here N is the nu
74d0: 6d 62 65 72 20 6f 66 0a 2a 2a 20 65 6c 65 6d 65  mber of.** eleme
74e0: 6e 74 73 20 69 6e 20 70 45 4c 69 73 74 2c 20 63  nts in pEList, c
74f0: 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20  orresponding to 
7500: 74 68 65 20 6d 61 74 63 68 69 6e 67 20 65 6e 74  the matching ent
7510: 72 79 2e 20 20 49 66 20 74 68 65 72 65 20 69 73  ry.  If there is
7520: 0a 2a 2a 20 6e 6f 20 6d 61 74 63 68 2c 20 6f 72  .** no match, or
7530: 20 69 66 20 70 45 20 69 73 20 6e 6f 74 20 61 20   if pE is not a 
7540: 73 69 6d 70 6c 65 20 69 64 65 6e 74 69 66 69 65  simple identifie
7550: 72 2c 20 74 68 65 6e 20 74 68 69 73 20 72 6f 75  r, then this rou
7560: 74 69 6e 65 0a 2a 2a 20 72 65 74 75 72 6e 20 30  tine.** return 0
7570: 2e 0a 2a 2a 0a 2a 2a 20 70 45 4c 69 73 74 20 68  ..**.** pEList h
7580: 61 73 20 62 65 65 6e 20 72 65 73 6f 6c 76 65 64  as been resolved
7590: 2e 20 20 70 45 20 68 61 73 20 6e 6f 74 2e 0a 2a  .  pE has not..*
75a0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 72 65 73  /.static int res
75b0: 6f 6c 76 65 41 73 4e 61 6d 65 28 0a 20 20 50 61  olveAsName(.  Pa
75c0: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20  rse *pParse,    
75d0: 20 2f 2a 20 50 61 72 73 69 6e 67 20 63 6f 6e 74   /* Parsing cont
75e0: 65 78 74 20 66 6f 72 20 65 72 72 6f 72 20 6d 65  ext for error me
75f0: 73 73 61 67 65 73 20 2a 2f 0a 20 20 45 78 70 72  ssages */.  Expr
7600: 4c 69 73 74 20 2a 70 45 4c 69 73 74 2c 20 20 2f  List *pEList,  /
7610: 2a 20 4c 69 73 74 20 6f 66 20 65 78 70 72 65 73  * List of expres
7620: 73 69 6f 6e 73 20 74 6f 20 73 63 61 6e 20 2a 2f  sions to scan */
7630: 0a 20 20 45 78 70 72 20 2a 70 45 20 20 20 20 20  .  Expr *pE     
7640: 20 20 20 20 20 20 2f 2a 20 45 78 70 72 65 73 73        /* Express
7650: 69 6f 6e 20 77 65 20 61 72 65 20 74 72 79 69 6e  ion we are tryin
7660: 67 20 74 6f 20 6d 61 74 63 68 20 2a 2f 0a 29 7b  g to match */.){
7670: 0a 20 20 69 6e 74 20 69 3b 20 20 20 20 20 20 20  .  int i;       
7680: 20 20 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f        /* Loop co
7690: 75 6e 74 65 72 20 2a 2f 0a 0a 20 20 55 4e 55 53  unter */..  UNUS
76a0: 45 44 5f 50 41 52 41 4d 45 54 45 52 28 70 50 61  ED_PARAMETER(pPa
76b0: 72 73 65 29 3b 0a 0a 20 20 69 66 28 20 70 45 2d  rse);..  if( pE-
76c0: 3e 6f 70 3d 3d 54 4b 5f 49 44 20 29 7b 0a 20 20  >op==TK_ID ){.  
76d0: 20 20 63 68 61 72 20 2a 7a 43 6f 6c 20 3d 20 70    char *zCol = p
76e0: 45 2d 3e 75 2e 7a 54 6f 6b 65 6e 3b 0a 20 20 20  E->u.zToken;.   
76f0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 45 4c 69   for(i=0; i<pELi
7700: 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b  st->nExpr; i++){
7710: 0a 20 20 20 20 20 20 63 68 61 72 20 2a 7a 41 73  .      char *zAs
7720: 20 3d 20 70 45 4c 69 73 74 2d 3e 61 5b 69 5d 2e   = pEList->a[i].
7730: 7a 4e 61 6d 65 3b 0a 20 20 20 20 20 20 69 66 28  zName;.      if(
7740: 20 7a 41 73 21 3d 30 20 26 26 20 73 71 6c 69 74   zAs!=0 && sqlit
7750: 65 33 53 74 72 49 43 6d 70 28 7a 41 73 2c 20 7a  e3StrICmp(zAs, z
7760: 43 6f 6c 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  Col)==0 ){.     
7770: 20 20 20 72 65 74 75 72 6e 20 69 2b 31 3b 0a 20     return i+1;. 
7780: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d       }.    }.  }
7790: 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a  .  return 0;.}..
77a0: 2f 2a 0a 2a 2a 20 70 45 20 69 73 20 61 20 70 6f  /*.** pE is a po
77b0: 69 6e 74 65 72 20 74 6f 20 61 6e 20 65 78 70 72  inter to an expr
77c0: 65 73 73 69 6f 6e 20 77 68 69 63 68 20 69 73 20  ession which is 
77d0: 61 20 73 69 6e 67 6c 65 20 74 65 72 6d 20 69 6e  a single term in
77e0: 20 74 68 65 0a 2a 2a 20 4f 52 44 45 52 20 42 59   the.** ORDER BY
77f0: 20 6f 66 20 61 20 63 6f 6d 70 6f 75 6e 64 20 53   of a compound S
7800: 45 4c 45 43 54 2e 20 20 54 68 65 20 65 78 70 72  ELECT.  The expr
7810: 65 73 73 69 6f 6e 20 68 61 73 20 6e 6f 74 20 62  ession has not b
7820: 65 65 6e 0a 2a 2a 20 6e 61 6d 65 20 72 65 73 6f  een.** name reso
7830: 6c 76 65 64 2e 0a 2a 2a 0a 2a 2a 20 41 74 20 74  lved..**.** At t
7840: 68 65 20 70 6f 69 6e 74 20 74 68 69 73 20 72 6f  he point this ro
7850: 75 74 69 6e 65 20 69 73 20 63 61 6c 6c 65 64 2c  utine is called,
7860: 20 77 65 20 61 6c 72 65 61 64 79 20 6b 6e 6f 77   we already know
7870: 20 74 68 61 74 20 74 68 65 0a 2a 2a 20 4f 52 44   that the.** ORD
7880: 45 52 20 42 59 20 74 65 72 6d 20 69 73 20 6e 6f  ER BY term is no
7890: 74 20 61 6e 20 69 6e 74 65 67 65 72 20 69 6e 64  t an integer ind
78a0: 65 78 20 69 6e 74 6f 20 74 68 65 20 72 65 73 75  ex into the resu
78b0: 6c 74 20 73 65 74 2e 20 20 54 68 61 74 0a 2a 2a  lt set.  That.**
78c0: 20 63 61 73 65 20 69 73 20 68 61 6e 64 6c 65 64   case is handled
78d0: 20 62 79 20 74 68 65 20 63 61 6c 6c 69 6e 67 20   by the calling 
78e0: 72 6f 75 74 69 6e 65 2e 0a 2a 2a 0a 2a 2a 20 41  routine..**.** A
78f0: 74 74 65 6d 70 74 20 74 6f 20 6d 61 74 63 68 20  ttempt to match 
7900: 70 45 20 61 67 61 69 6e 73 74 20 72 65 73 75 6c  pE against resul
7910: 74 20 73 65 74 20 63 6f 6c 75 6d 6e 73 20 69 6e  t set columns in
7920: 20 74 68 65 20 6c 65 66 74 2d 6d 6f 73 74 0a 2a   the left-most.*
7930: 2a 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65  * SELECT stateme
7940: 6e 74 2e 20 20 52 65 74 75 72 6e 20 74 68 65 20  nt.  Return the 
7950: 69 6e 64 65 78 20 69 20 6f 66 20 74 68 65 20 6d  index i of the m
7960: 61 74 63 68 69 6e 67 20 63 6f 6c 75 6d 6e 2c 0a  atching column,.
7970: 2a 2a 20 61 73 20 61 6e 20 69 6e 64 69 63 61 74  ** as an indicat
7980: 69 6f 6e 20 74 6f 20 74 68 65 20 63 61 6c 6c 65  ion to the calle
7990: 72 20 74 68 61 74 20 69 74 20 73 68 6f 75 6c 64  r that it should
79a0: 20 73 6f 72 74 20 62 79 20 74 68 65 20 69 2d 74   sort by the i-t
79b0: 68 20 63 6f 6c 75 6d 6e 2e 0a 2a 2a 20 54 68 65  h column..** The
79c0: 20 6c 65 66 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d   left-most colum
79d0: 6e 20 69 73 20 31 2e 20 20 49 6e 20 6f 74 68 65  n is 1.  In othe
79e0: 72 20 77 6f 72 64 73 2c 20 74 68 65 20 76 61 6c  r words, the val
79f0: 75 65 20 72 65 74 75 72 6e 65 64 20 69 73 20 74  ue returned is t
7a00: 68 65 0a 2a 2a 20 73 61 6d 65 20 69 6e 74 65 67  he.** same integ
7a10: 65 72 20 76 61 6c 75 65 20 74 68 61 74 20 77 6f  er value that wo
7a20: 75 6c 64 20 62 65 20 75 73 65 64 20 69 6e 20 74  uld be used in t
7a30: 68 65 20 53 51 4c 20 73 74 61 74 65 6d 65 6e 74  he SQL statement
7a40: 20 74 6f 20 69 6e 64 69 63 61 74 65 0a 2a 2a 20   to indicate.** 
7a50: 74 68 65 20 63 6f 6c 75 6d 6e 2e 0a 2a 2a 0a 2a  the column..**.*
7a60: 2a 20 49 66 20 74 68 65 72 65 20 69 73 20 6e 6f  * If there is no
7a70: 20 6d 61 74 63 68 2c 20 72 65 74 75 72 6e 20 30   match, return 0
7a80: 2e 20 20 52 65 74 75 72 6e 20 2d 31 20 69 66 20  .  Return -1 if 
7a90: 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73 2e  an error occurs.
7aa0: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 72  .*/.static int r
7ab0: 65 73 6f 6c 76 65 4f 72 64 65 72 42 79 54 65 72  esolveOrderByTer
7ac0: 6d 54 6f 45 78 70 72 4c 69 73 74 28 0a 20 20 50  mToExprList(.  P
7ad0: 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20  arse *pParse,   
7ae0: 20 20 2f 2a 20 50 61 72 73 69 6e 67 20 63 6f 6e    /* Parsing con
7af0: 74 65 78 74 20 66 6f 72 20 65 72 72 6f 72 20 6d  text for error m
7b00: 65 73 73 61 67 65 73 20 2a 2f 0a 20 20 53 65 6c  essages */.  Sel
7b10: 65 63 74 20 2a 70 53 65 6c 65 63 74 2c 20 20 20  ect *pSelect,   
7b20: 2f 2a 20 54 68 65 20 53 45 4c 45 43 54 20 73 74  /* The SELECT st
7b30: 61 74 65 6d 65 6e 74 20 77 69 74 68 20 74 68 65  atement with the
7b40: 20 4f 52 44 45 52 20 42 59 20 63 6c 61 75 73 65   ORDER BY clause
7b50: 20 2a 2f 0a 20 20 45 78 70 72 20 2a 70 45 20 20   */.  Expr *pE  
7b60: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
7b70: 73 70 65 63 69 66 69 63 20 4f 52 44 45 52 20 42  specific ORDER B
7b80: 59 20 74 65 72 6d 20 2a 2f 0a 29 7b 0a 20 20 69  Y term */.){.  i
7b90: 6e 74 20 69 3b 20 20 20 20 20 20 20 20 20 20 20  nt i;           
7ba0: 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74 65    /* Loop counte
7bb0: 72 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73 74 20  r */.  ExprList 
7bc0: 2a 70 45 4c 69 73 74 3b 20 20 2f 2a 20 54 68 65  *pEList;  /* The
7bd0: 20 63 6f 6c 75 6d 6e 73 20 6f 66 20 74 68 65 20   columns of the 
7be0: 72 65 73 75 6c 74 20 73 65 74 20 2a 2f 0a 20 20  result set */.  
7bf0: 4e 61 6d 65 43 6f 6e 74 65 78 74 20 6e 63 3b 20  NameContext nc; 
7c00: 20 20 20 2f 2a 20 4e 61 6d 65 20 63 6f 6e 74 65     /* Name conte
7c10: 78 74 20 66 6f 72 20 72 65 73 6f 6c 76 69 6e 67  xt for resolving
7c20: 20 70 45 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33   pE */.  sqlite3
7c30: 20 2a 64 62 3b 20 20 20 20 20 20 20 2f 2a 20 44   *db;       /* D
7c40: 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69  atabase connecti
7c50: 6f 6e 20 2a 2f 0a 20 20 69 6e 74 20 72 63 3b 20  on */.  int rc; 
7c60: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 52 65             /* Re
7c70: 74 75 72 6e 20 63 6f 64 65 20 66 72 6f 6d 20 73  turn code from s
7c80: 75 62 70 72 6f 63 65 64 75 72 65 73 20 2a 2f 0a  ubprocedures */.
7c90: 20 20 75 38 20 73 61 76 65 64 53 75 70 70 45 72    u8 savedSuppEr
7ca0: 72 3b 20 20 20 2f 2a 20 53 61 76 65 64 20 76 61  r;   /* Saved va
7cb0: 6c 75 65 20 6f 66 20 64 62 2d 3e 73 75 70 70 72  lue of db->suppr
7cc0: 65 73 73 45 72 72 20 2a 2f 0a 0a 20 20 61 73 73  essErr */..  ass
7cd0: 65 72 74 28 20 73 71 6c 69 74 65 33 45 78 70 72  ert( sqlite3Expr
7ce0: 49 73 49 6e 74 65 67 65 72 28 70 45 2c 20 26 69  IsInteger(pE, &i
7cf0: 29 3d 3d 30 20 29 3b 0a 20 20 70 45 4c 69 73 74  )==0 );.  pEList
7d00: 20 3d 20 70 53 65 6c 65 63 74 2d 3e 70 45 4c 69   = pSelect->pELi
7d10: 73 74 3b 0a 0a 20 20 2f 2a 20 52 65 73 6f 6c 76  st;..  /* Resolv
7d20: 65 20 61 6c 6c 20 6e 61 6d 65 73 20 69 6e 20 74  e all names in t
7d30: 68 65 20 4f 52 44 45 52 20 42 59 20 74 65 72 6d  he ORDER BY term
7d40: 20 65 78 70 72 65 73 73 69 6f 6e 0a 20 20 2a 2f   expression.  */
7d50: 0a 20 20 6d 65 6d 73 65 74 28 26 6e 63 2c 20 30  .  memset(&nc, 0
7d60: 2c 20 73 69 7a 65 6f 66 28 6e 63 29 29 3b 0a 20  , sizeof(nc));. 
7d70: 20 6e 63 2e 70 50 61 72 73 65 20 3d 20 70 50 61   nc.pParse = pPa
7d80: 72 73 65 3b 0a 20 20 6e 63 2e 70 53 72 63 4c 69  rse;.  nc.pSrcLi
7d90: 73 74 20 3d 20 70 53 65 6c 65 63 74 2d 3e 70 53  st = pSelect->pS
7da0: 72 63 3b 0a 20 20 6e 63 2e 70 45 4c 69 73 74 20  rc;.  nc.pEList 
7db0: 3d 20 70 45 4c 69 73 74 3b 0a 20 20 6e 63 2e 6e  = pEList;.  nc.n
7dc0: 63 46 6c 61 67 73 20 3d 20 4e 43 5f 41 6c 6c 6f  cFlags = NC_Allo
7dd0: 77 41 67 67 3b 0a 20 20 6e 63 2e 6e 45 72 72 20  wAgg;.  nc.nErr 
7de0: 3d 20 30 3b 0a 20 20 64 62 20 3d 20 70 50 61 72  = 0;.  db = pPar
7df0: 73 65 2d 3e 64 62 3b 0a 20 20 73 61 76 65 64 53  se->db;.  savedS
7e00: 75 70 70 45 72 72 20 3d 20 64 62 2d 3e 73 75 70  uppErr = db->sup
7e10: 70 72 65 73 73 45 72 72 3b 0a 20 20 64 62 2d 3e  pressErr;.  db->
7e20: 73 75 70 70 72 65 73 73 45 72 72 20 3d 20 31 3b  suppressErr = 1;
7e30: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 52  .  rc = sqlite3R
7e40: 65 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65 73 28  esolveExprNames(
7e50: 26 6e 63 2c 20 70 45 29 3b 0a 20 20 64 62 2d 3e  &nc, pE);.  db->
7e60: 73 75 70 70 72 65 73 73 45 72 72 20 3d 20 73 61  suppressErr = sa
7e70: 76 65 64 53 75 70 70 45 72 72 3b 0a 20 20 69 66  vedSuppErr;.  if
7e80: 28 20 72 63 20 29 20 72 65 74 75 72 6e 20 30 3b  ( rc ) return 0;
7e90: 0a 0a 20 20 2f 2a 20 54 72 79 20 74 6f 20 6d 61  ..  /* Try to ma
7ea0: 74 63 68 20 74 68 65 20 4f 52 44 45 52 20 42 59  tch the ORDER BY
7eb0: 20 65 78 70 72 65 73 73 69 6f 6e 20 61 67 61 69   expression agai
7ec0: 6e 73 74 20 61 6e 20 65 78 70 72 65 73 73 69 6f  nst an expressio
7ed0: 6e 0a 20 20 2a 2a 20 69 6e 20 74 68 65 20 72 65  n.  ** in the re
7ee0: 73 75 6c 74 20 73 65 74 2e 20 20 52 65 74 75 72  sult set.  Retur
7ef0: 6e 20 61 6e 20 31 2d 62 61 73 65 64 20 69 6e 64  n an 1-based ind
7f00: 65 78 20 6f 66 20 74 68 65 20 6d 61 74 63 68 69  ex of the matchi
7f10: 6e 67 0a 20 20 2a 2a 20 72 65 73 75 6c 74 2d 73  ng.  ** result-s
7f20: 65 74 20 65 6e 74 72 79 2e 0a 20 20 2a 2f 0a 20  et entry..  */. 
7f30: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 45 4c 69   for(i=0; i<pELi
7f40: 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b  st->nExpr; i++){
7f50: 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33  .    if( sqlite3
7f60: 45 78 70 72 43 6f 6d 70 61 72 65 28 30 2c 20 70  ExprCompare(0, p
7f70: 45 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70  EList->a[i].pExp
7f80: 72 2c 20 70 45 2c 20 2d 31 29 3c 32 20 29 7b 0a  r, pE, -1)<2 ){.
7f90: 20 20 20 20 20 20 72 65 74 75 72 6e 20 69 2b 31        return i+1
7fa0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f  ;.    }.  }..  /
7fb0: 2a 20 49 66 20 6e 6f 20 6d 61 74 63 68 2c 20 72  * If no match, r
7fc0: 65 74 75 72 6e 20 30 2e 20 2a 2f 0a 20 20 72 65  eturn 0. */.  re
7fd0: 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  turn 0;.}../*.**
7fe0: 20 47 65 6e 65 72 61 74 65 20 61 6e 20 4f 52 44   Generate an ORD
7ff0: 45 52 20 42 59 20 6f 72 20 47 52 4f 55 50 20 42  ER BY or GROUP B
8000: 59 20 74 65 72 6d 20 6f 75 74 2d 6f 66 2d 72 61  Y term out-of-ra
8010: 6e 67 65 20 65 72 72 6f 72 2e 0a 2a 2f 0a 73 74  nge error..*/.st
8020: 61 74 69 63 20 76 6f 69 64 20 72 65 73 6f 6c 76  atic void resolv
8030: 65 4f 75 74 4f 66 52 61 6e 67 65 45 72 72 6f 72  eOutOfRangeError
8040: 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73  (.  Parse *pPars
8050: 65 2c 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68  e,         /* Th
8060: 65 20 65 72 72 6f 72 20 63 6f 6e 74 65 78 74 20  e error context 
8070: 69 6e 74 6f 20 77 68 69 63 68 20 74 6f 20 77 72  into which to wr
8080: 69 74 65 20 74 68 65 20 65 72 72 6f 72 20 2a 2f  ite the error */
8090: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
80a0: 54 79 70 65 2c 20 20 20 20 20 2f 2a 20 22 4f 52  Type,     /* "OR
80b0: 44 45 52 22 20 6f 72 20 22 47 52 4f 55 50 22 20  DER" or "GROUP" 
80c0: 2a 2f 0a 20 20 69 6e 74 20 69 2c 20 20 20 20 20  */.  int i,     
80d0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
80e0: 68 65 20 69 6e 64 65 78 20 28 31 2d 62 61 73 65  he index (1-base
80f0: 64 29 20 6f 66 20 74 68 65 20 74 65 72 6d 20 6f  d) of the term o
8100: 75 74 20 6f 66 20 72 61 6e 67 65 20 2a 2f 0a 20  ut of range */. 
8110: 20 69 6e 74 20 6d 78 20 20 20 20 20 20 20 20 20   int mx         
8120: 20 20 20 20 20 20 20 20 2f 2a 20 4c 61 72 67 65          /* Large
8130: 73 74 20 70 65 72 6d 69 73 73 69 62 6c 65 20 76  st permissible v
8140: 61 6c 75 65 20 6f 66 20 69 20 2a 2f 0a 29 7b 0a  alue of i */.){.
8150: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73    sqlite3ErrorMs
8160: 67 28 70 50 61 72 73 65 2c 20 0a 20 20 20 20 22  g(pParse, .    "
8170: 25 72 20 25 73 20 42 59 20 74 65 72 6d 20 6f 75  %r %s BY term ou
8180: 74 20 6f 66 20 72 61 6e 67 65 20 2d 20 73 68 6f  t of range - sho
8190: 75 6c 64 20 62 65 20 22 0a 20 20 20 20 22 62 65  uld be ".    "be
81a0: 74 77 65 65 6e 20 31 20 61 6e 64 20 25 64 22 2c  tween 1 and %d",
81b0: 20 69 2c 20 7a 54 79 70 65 2c 20 6d 78 29 3b 0a   i, zType, mx);.
81c0: 7d 0a 0a 2f 2a 0a 2a 2a 20 41 6e 61 6c 79 7a 65  }../*.** Analyze
81d0: 20 74 68 65 20 4f 52 44 45 52 20 42 59 20 63 6c   the ORDER BY cl
81e0: 61 75 73 65 20 69 6e 20 61 20 63 6f 6d 70 6f 75  ause in a compou
81f0: 6e 64 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d  nd SELECT statem
8200: 65 6e 74 2e 20 20 20 4d 6f 64 69 66 79 0a 2a 2a  ent.   Modify.**
8210: 20 65 61 63 68 20 74 65 72 6d 20 6f 66 20 74 68   each term of th
8220: 65 20 4f 52 44 45 52 20 42 59 20 63 6c 61 75 73  e ORDER BY claus
8230: 65 20 69 73 20 61 20 63 6f 6e 73 74 61 6e 74 20  e is a constant 
8240: 69 6e 74 65 67 65 72 20 62 65 74 77 65 65 6e 20  integer between 
8250: 31 0a 2a 2a 20 61 6e 64 20 4e 20 77 68 65 72 65  1.** and N where
8260: 20 4e 20 69 73 20 74 68 65 20 6e 75 6d 62 65 72   N is the number
8270: 20 6f 66 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 74   of columns in t
8280: 68 65 20 63 6f 6d 70 6f 75 6e 64 20 53 45 4c 45  he compound SELE
8290: 43 54 2e 0a 2a 2a 0a 2a 2a 20 4f 52 44 45 52 20  CT..**.** ORDER 
82a0: 42 59 20 74 65 72 6d 73 20 74 68 61 74 20 61 72  BY terms that ar
82b0: 65 20 61 6c 72 65 61 64 79 20 61 6e 20 69 6e 74  e already an int
82c0: 65 67 65 72 20 62 65 74 77 65 65 6e 20 31 20 61  eger between 1 a
82d0: 6e 64 20 4e 20 61 72 65 0a 2a 2a 20 75 6e 6d 6f  nd N are.** unmo
82e0: 64 69 66 69 65 64 2e 20 20 4f 52 44 45 52 20 42  dified.  ORDER B
82f0: 59 20 74 65 72 6d 73 20 74 68 61 74 20 61 72 65  Y terms that are
8300: 20 69 6e 74 65 67 65 72 73 20 6f 75 74 73 69 64   integers outsid
8310: 65 20 74 68 65 20 72 61 6e 67 65 20 6f 66 0a 2a  e the range of.*
8320: 2a 20 31 20 74 68 72 6f 75 67 68 20 4e 20 67 65  * 1 through N ge
8330: 6e 65 72 61 74 65 20 61 6e 20 65 72 72 6f 72 2e  nerate an error.
8340: 20 20 4f 52 44 45 52 20 42 59 20 74 65 72 6d 73    ORDER BY terms
8350: 20 74 68 61 74 20 61 72 65 20 65 78 70 72 65 73   that are expres
8360: 73 69 6f 6e 73 0a 2a 2a 20 61 72 65 20 6d 61 74  sions.** are mat
8370: 63 68 65 64 20 61 67 61 69 6e 73 74 20 72 65 73  ched against res
8380: 75 6c 74 20 73 65 74 20 65 78 70 72 65 73 73 69  ult set expressi
8390: 6f 6e 73 20 6f 66 20 63 6f 6d 70 6f 75 6e 64 20  ons of compound 
83a0: 53 45 4c 45 43 54 0a 2a 2a 20 62 65 67 69 6e 6e  SELECT.** beginn
83b0: 69 6e 67 20 77 69 74 68 20 74 68 65 20 6c 65 66  ing with the lef
83c0: 74 2d 6d 6f 73 74 20 53 45 4c 45 43 54 20 61 6e  t-most SELECT an
83d0: 64 20 77 6f 72 6b 69 6e 67 20 74 6f 77 61 72 64  d working toward
83e0: 20 74 68 65 20 72 69 67 68 74 2e 0a 2a 2a 20 41   the right..** A
83f0: 74 20 74 68 65 20 66 69 72 73 74 20 6d 61 74 63  t the first matc
8400: 68 2c 20 74 68 65 20 4f 52 44 45 52 20 42 59 20  h, the ORDER BY 
8410: 65 78 70 72 65 73 73 69 6f 6e 20 69 73 20 74 72  expression is tr
8420: 61 6e 73 66 6f 72 6d 65 64 20 69 6e 74 6f 0a 2a  ansformed into.*
8430: 2a 20 74 68 65 20 69 6e 74 65 67 65 72 20 63 6f  * the integer co
8440: 6c 75 6d 6e 20 6e 75 6d 62 65 72 2e 0a 2a 2a 0a  lumn number..**.
8450: 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 6e 75  ** Return the nu
8460: 6d 62 65 72 20 6f 66 20 65 72 72 6f 72 73 20 73  mber of errors s
8470: 65 65 6e 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  een..*/.static i
8480: 6e 74 20 72 65 73 6f 6c 76 65 43 6f 6d 70 6f 75  nt resolveCompou
8490: 6e 64 4f 72 64 65 72 42 79 28 0a 20 20 50 61 72  ndOrderBy(.  Par
84a0: 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20 20  se *pParse,     
84b0: 20 20 20 2f 2a 20 50 61 72 73 69 6e 67 20 63 6f     /* Parsing co
84c0: 6e 74 65 78 74 2e 20 20 4c 65 61 76 65 20 65 72  ntext.  Leave er
84d0: 72 6f 72 20 6d 65 73 73 61 67 65 73 20 68 65 72  ror messages her
84e0: 65 20 2a 2f 0a 20 20 53 65 6c 65 63 74 20 2a 70  e */.  Select *p
84f0: 53 65 6c 65 63 74 20 20 20 20 20 20 20 2f 2a 20  Select       /* 
8500: 54 68 65 20 53 45 4c 45 43 54 20 73 74 61 74 65  The SELECT state
8510: 6d 65 6e 74 20 63 6f 6e 74 61 69 6e 69 6e 67 20  ment containing 
8520: 74 68 65 20 4f 52 44 45 52 20 42 59 20 2a 2f 0a  the ORDER BY */.
8530: 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 45 78  ){.  int i;.  Ex
8540: 70 72 4c 69 73 74 20 2a 70 4f 72 64 65 72 42 79  prList *pOrderBy
8550: 3b 0a 20 20 45 78 70 72 4c 69 73 74 20 2a 70 45  ;.  ExprList *pE
8560: 4c 69 73 74 3b 0a 20 20 73 71 6c 69 74 65 33 20  List;.  sqlite3 
8570: 2a 64 62 3b 0a 20 20 69 6e 74 20 6d 6f 72 65 54  *db;.  int moreT
8580: 6f 44 6f 20 3d 20 31 3b 0a 0a 20 20 70 4f 72 64  oDo = 1;..  pOrd
8590: 65 72 42 79 20 3d 20 70 53 65 6c 65 63 74 2d 3e  erBy = pSelect->
85a0: 70 4f 72 64 65 72 42 79 3b 0a 20 20 69 66 28 20  pOrderBy;.  if( 
85b0: 70 4f 72 64 65 72 42 79 3d 3d 30 20 29 20 72 65  pOrderBy==0 ) re
85c0: 74 75 72 6e 20 30 3b 0a 20 20 64 62 20 3d 20 70  turn 0;.  db = p
85d0: 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 69 66 28  Parse->db;.  if(
85e0: 20 70 4f 72 64 65 72 42 79 2d 3e 6e 45 78 70 72   pOrderBy->nExpr
85f0: 3e 64 62 2d 3e 61 4c 69 6d 69 74 5b 53 51 4c 49  >db->aLimit[SQLI
8600: 54 45 5f 4c 49 4d 49 54 5f 43 4f 4c 55 4d 4e 5d  TE_LIMIT_COLUMN]
8610: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45   ){.    sqlite3E
8620: 72 72 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20  rrorMsg(pParse, 
8630: 22 74 6f 6f 20 6d 61 6e 79 20 74 65 72 6d 73 20  "too many terms 
8640: 69 6e 20 4f 52 44 45 52 20 42 59 20 63 6c 61 75  in ORDER BY clau
8650: 73 65 22 29 3b 0a 20 20 20 20 72 65 74 75 72 6e  se");.    return
8660: 20 31 3b 0a 20 20 7d 0a 20 20 66 6f 72 28 69 3d   1;.  }.  for(i=
8670: 30 3b 20 69 3c 70 4f 72 64 65 72 42 79 2d 3e 6e  0; i<pOrderBy->n
8680: 45 78 70 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  Expr; i++){.    
8690: 70 4f 72 64 65 72 42 79 2d 3e 61 5b 69 5d 2e 64  pOrderBy->a[i].d
86a0: 6f 6e 65 20 3d 20 30 3b 0a 20 20 7d 0a 20 20 70  one = 0;.  }.  p
86b0: 53 65 6c 65 63 74 2d 3e 70 4e 65 78 74 20 3d 20  Select->pNext = 
86c0: 30 3b 0a 20 20 77 68 69 6c 65 28 20 70 53 65 6c  0;.  while( pSel
86d0: 65 63 74 2d 3e 70 50 72 69 6f 72 20 29 7b 0a 20  ect->pPrior ){. 
86e0: 20 20 20 70 53 65 6c 65 63 74 2d 3e 70 50 72 69     pSelect->pPri
86f0: 6f 72 2d 3e 70 4e 65 78 74 20 3d 20 70 53 65 6c  or->pNext = pSel
8700: 65 63 74 3b 0a 20 20 20 20 70 53 65 6c 65 63 74  ect;.    pSelect
8710: 20 3d 20 70 53 65 6c 65 63 74 2d 3e 70 50 72 69   = pSelect->pPri
8720: 6f 72 3b 0a 20 20 7d 0a 20 20 77 68 69 6c 65 28  or;.  }.  while(
8730: 20 70 53 65 6c 65 63 74 20 26 26 20 6d 6f 72 65   pSelect && more
8740: 54 6f 44 6f 20 29 7b 0a 20 20 20 20 73 74 72 75  ToDo ){.    stru
8750: 63 74 20 45 78 70 72 4c 69 73 74 5f 69 74 65 6d  ct ExprList_item
8760: 20 2a 70 49 74 65 6d 3b 0a 20 20 20 20 6d 6f 72   *pItem;.    mor
8770: 65 54 6f 44 6f 20 3d 20 30 3b 0a 20 20 20 20 70  eToDo = 0;.    p
8780: 45 4c 69 73 74 20 3d 20 70 53 65 6c 65 63 74 2d  EList = pSelect-
8790: 3e 70 45 4c 69 73 74 3b 0a 20 20 20 20 61 73 73  >pEList;.    ass
87a0: 65 72 74 28 20 70 45 4c 69 73 74 21 3d 30 20 29  ert( pEList!=0 )
87b0: 3b 0a 20 20 20 20 66 6f 72 28 69 3d 30 2c 20 70  ;.    for(i=0, p
87c0: 49 74 65 6d 3d 70 4f 72 64 65 72 42 79 2d 3e 61  Item=pOrderBy->a
87d0: 3b 20 69 3c 70 4f 72 64 65 72 42 79 2d 3e 6e 45  ; i<pOrderBy->nE
87e0: 78 70 72 3b 20 69 2b 2b 2c 20 70 49 74 65 6d 2b  xpr; i++, pItem+
87f0: 2b 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 43  +){.      int iC
8800: 6f 6c 20 3d 20 2d 31 3b 0a 20 20 20 20 20 20 45  ol = -1;.      E
8810: 78 70 72 20 2a 70 45 2c 20 2a 70 44 75 70 3b 0a  xpr *pE, *pDup;.
8820: 20 20 20 20 20 20 69 66 28 20 70 49 74 65 6d 2d        if( pItem-
8830: 3e 64 6f 6e 65 20 29 20 63 6f 6e 74 69 6e 75 65  >done ) continue
8840: 3b 0a 20 20 20 20 20 20 70 45 20 3d 20 73 71 6c  ;.      pE = sql
8850: 69 74 65 33 45 78 70 72 53 6b 69 70 43 6f 6c 6c  ite3ExprSkipColl
8860: 61 74 65 28 70 49 74 65 6d 2d 3e 70 45 78 70 72  ate(pItem->pExpr
8870: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 73 71 6c  );.      if( sql
8880: 69 74 65 33 45 78 70 72 49 73 49 6e 74 65 67 65  ite3ExprIsIntege
8890: 72 28 70 45 2c 20 26 69 43 6f 6c 29 20 29 7b 0a  r(pE, &iCol) ){.
88a0: 20 20 20 20 20 20 20 20 69 66 28 20 69 43 6f 6c          if( iCol
88b0: 3c 3d 30 20 7c 7c 20 69 43 6f 6c 3e 70 45 4c 69  <=0 || iCol>pELi
88c0: 73 74 2d 3e 6e 45 78 70 72 20 29 7b 0a 20 20 20  st->nExpr ){.   
88d0: 20 20 20 20 20 20 20 72 65 73 6f 6c 76 65 4f 75         resolveOu
88e0: 74 4f 66 52 61 6e 67 65 45 72 72 6f 72 28 70 50  tOfRangeError(pP
88f0: 61 72 73 65 2c 20 22 4f 52 44 45 52 22 2c 20 69  arse, "ORDER", i
8900: 2b 31 2c 20 70 45 4c 69 73 74 2d 3e 6e 45 78 70  +1, pEList->nExp
8910: 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20 72 65  r);.          re
8920: 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20  turn 1;.        
8930: 7d 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20  }.      }else{. 
8940: 20 20 20 20 20 20 20 69 43 6f 6c 20 3d 20 72 65         iCol = re
8950: 73 6f 6c 76 65 41 73 4e 61 6d 65 28 70 50 61 72  solveAsName(pPar
8960: 73 65 2c 20 70 45 4c 69 73 74 2c 20 70 45 29 3b  se, pEList, pE);
8970: 0a 20 20 20 20 20 20 20 20 69 66 28 20 69 43 6f  .        if( iCo
8980: 6c 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  l==0 ){.        
8990: 20 20 70 44 75 70 20 3d 20 73 71 6c 69 74 65 33    pDup = sqlite3
89a0: 45 78 70 72 44 75 70 28 64 62 2c 20 70 45 2c 20  ExprDup(db, pE, 
89b0: 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66  0);.          if
89c0: 28 20 21 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69  ( !db->mallocFai
89d0: 6c 65 64 20 29 7b 0a 20 20 20 20 20 20 20 20 20  led ){.         
89e0: 20 20 20 61 73 73 65 72 74 28 70 44 75 70 29 3b     assert(pDup);
89f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 43 6f  .            iCo
8a00: 6c 20 3d 20 72 65 73 6f 6c 76 65 4f 72 64 65 72  l = resolveOrder
8a10: 42 79 54 65 72 6d 54 6f 45 78 70 72 4c 69 73 74  ByTermToExprList
8a20: 28 70 50 61 72 73 65 2c 20 70 53 65 6c 65 63 74  (pParse, pSelect
8a30: 2c 20 70 44 75 70 29 3b 0a 20 20 20 20 20 20 20  , pDup);.       
8a40: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 73     }.          s
8a50: 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65  qlite3ExprDelete
8a60: 28 64 62 2c 20 70 44 75 70 29 3b 0a 20 20 20 20  (db, pDup);.    
8a70: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
8a80: 20 20 20 20 69 66 28 20 69 43 6f 6c 3e 30 20 29      if( iCol>0 )
8a90: 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20 43 6f 6e  {.        /* Con
8aa0: 76 65 72 74 20 74 68 65 20 4f 52 44 45 52 20 42  vert the ORDER B
8ab0: 59 20 74 65 72 6d 20 69 6e 74 6f 20 61 6e 20 69  Y term into an i
8ac0: 6e 74 65 67 65 72 20 63 6f 6c 75 6d 6e 20 6e 75  nteger column nu
8ad0: 6d 62 65 72 20 69 43 6f 6c 2c 0a 20 20 20 20 20  mber iCol,.     
8ae0: 20 20 20 2a 2a 20 74 61 6b 69 6e 67 20 63 61 72     ** taking car
8af0: 65 20 74 6f 20 70 72 65 73 65 72 76 65 20 74 68  e to preserve th
8b00: 65 20 43 4f 4c 4c 41 54 45 20 63 6c 61 75 73 65  e COLLATE clause
8b10: 20 69 66 20 69 74 20 65 78 69 73 74 73 20 2a 2f   if it exists */
8b20: 0a 20 20 20 20 20 20 20 20 45 78 70 72 20 2a 70  .        Expr *p
8b30: 4e 65 77 20 3d 20 73 71 6c 69 74 65 33 45 78 70  New = sqlite3Exp
8b40: 72 28 64 62 2c 20 54 4b 5f 49 4e 54 45 47 45 52  r(db, TK_INTEGER
8b50: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 69 66  , 0);.        if
8b60: 28 20 70 4e 65 77 3d 3d 30 20 29 20 72 65 74 75  ( pNew==0 ) retu
8b70: 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20 70 4e  rn 1;.        pN
8b80: 65 77 2d 3e 66 6c 61 67 73 20 7c 3d 20 45 50 5f  ew->flags |= EP_
8b90: 49 6e 74 56 61 6c 75 65 3b 0a 20 20 20 20 20 20  IntValue;.      
8ba0: 20 20 70 4e 65 77 2d 3e 75 2e 69 56 61 6c 75 65    pNew->u.iValue
8bb0: 20 3d 20 69 43 6f 6c 3b 0a 20 20 20 20 20 20 20   = iCol;.       
8bc0: 20 69 66 28 20 70 49 74 65 6d 2d 3e 70 45 78 70   if( pItem->pExp
8bd0: 72 3d 3d 70 45 20 29 7b 0a 20 20 20 20 20 20 20  r==pE ){.       
8be0: 20 20 20 70 49 74 65 6d 2d 3e 70 45 78 70 72 20     pItem->pExpr 
8bf0: 3d 20 70 4e 65 77 3b 0a 20 20 20 20 20 20 20 20  = pNew;.        
8c00: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20  }else{.         
8c10: 20 45 78 70 72 20 2a 70 50 61 72 65 6e 74 20 3d   Expr *pParent =
8c20: 20 70 49 74 65 6d 2d 3e 70 45 78 70 72 3b 0a 20   pItem->pExpr;. 
8c30: 20 20 20 20 20 20 20 20 20 61 73 73 65 72 74 28           assert(
8c40: 20 70 50 61 72 65 6e 74 2d 3e 6f 70 3d 3d 54 4b   pParent->op==TK
8c50: 5f 43 4f 4c 4c 41 54 45 20 29 3b 0a 20 20 20 20  _COLLATE );.    
8c60: 20 20 20 20 20 20 77 68 69 6c 65 28 20 70 50 61        while( pPa
8c70: 72 65 6e 74 2d 3e 70 4c 65 66 74 2d 3e 6f 70 3d  rent->pLeft->op=
8c80: 3d 54 4b 5f 43 4f 4c 4c 41 54 45 20 29 20 70 50  =TK_COLLATE ) pP
8c90: 61 72 65 6e 74 20 3d 20 70 50 61 72 65 6e 74 2d  arent = pParent-
8ca0: 3e 70 4c 65 66 74 3b 0a 20 20 20 20 20 20 20 20  >pLeft;.        
8cb0: 20 20 61 73 73 65 72 74 28 20 70 50 61 72 65 6e    assert( pParen
8cc0: 74 2d 3e 70 4c 65 66 74 3d 3d 70 45 20 29 3b 0a  t->pLeft==pE );.
8cd0: 20 20 20 20 20 20 20 20 20 20 70 50 61 72 65 6e            pParen
8ce0: 74 2d 3e 70 4c 65 66 74 20 3d 20 70 4e 65 77 3b  t->pLeft = pNew;
8cf0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
8d00: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65     sqlite3ExprDe
8d10: 6c 65 74 65 28 64 62 2c 20 70 45 29 3b 0a 20 20  lete(db, pE);.  
8d20: 20 20 20 20 20 20 70 49 74 65 6d 2d 3e 75 2e 78        pItem->u.x
8d30: 2e 69 4f 72 64 65 72 42 79 43 6f 6c 20 3d 20 28  .iOrderByCol = (
8d40: 75 31 36 29 69 43 6f 6c 3b 0a 20 20 20 20 20 20  u16)iCol;.      
8d50: 20 20 70 49 74 65 6d 2d 3e 64 6f 6e 65 20 3d 20    pItem->done = 
8d60: 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a  1;.      }else{.
8d70: 20 20 20 20 20 20 20 20 6d 6f 72 65 54 6f 44 6f          moreToDo
8d80: 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20   = 1;.      }.  
8d90: 20 20 7d 0a 20 20 20 20 70 53 65 6c 65 63 74 20    }.    pSelect 
8da0: 3d 20 70 53 65 6c 65 63 74 2d 3e 70 4e 65 78 74  = pSelect->pNext
8db0: 3b 0a 20 20 7d 0a 20 20 66 6f 72 28 69 3d 30 3b  ;.  }.  for(i=0;
8dc0: 20 69 3c 70 4f 72 64 65 72 42 79 2d 3e 6e 45 78   i<pOrderBy->nEx
8dd0: 70 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66  pr; i++){.    if
8de0: 28 20 70 4f 72 64 65 72 42 79 2d 3e 61 5b 69 5d  ( pOrderBy->a[i]
8df0: 2e 64 6f 6e 65 3d 3d 30 20 29 7b 0a 20 20 20 20  .done==0 ){.    
8e00: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73    sqlite3ErrorMs
8e10: 67 28 70 50 61 72 73 65 2c 20 22 25 72 20 4f 52  g(pParse, "%r OR
8e20: 44 45 52 20 42 59 20 74 65 72 6d 20 64 6f 65 73  DER BY term does
8e30: 20 6e 6f 74 20 6d 61 74 63 68 20 61 6e 79 20 22   not match any "
8e40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 22 63 6f  .            "co
8e50: 6c 75 6d 6e 20 69 6e 20 74 68 65 20 72 65 73 75  lumn in the resu
8e60: 6c 74 20 73 65 74 22 2c 20 69 2b 31 29 3b 0a 20  lt set", i+1);. 
8e70: 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20       return 1;. 
8e80: 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72     }.  }.  retur
8e90: 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 68  n 0;.}../*.** Ch
8ea0: 65 63 6b 20 65 76 65 72 79 20 74 65 72 6d 20 69  eck every term i
8eb0: 6e 20 74 68 65 20 4f 52 44 45 52 20 42 59 20 6f  n the ORDER BY o
8ec0: 72 20 47 52 4f 55 50 20 42 59 20 63 6c 61 75 73  r GROUP BY claus
8ed0: 65 20 70 4f 72 64 65 72 42 79 20 6f 66 0a 2a 2a  e pOrderBy of.**
8ee0: 20 74 68 65 20 53 45 4c 45 43 54 20 73 74 61 74   the SELECT stat
8ef0: 65 6d 65 6e 74 20 70 53 65 6c 65 63 74 2e 20 20  ement pSelect.  
8f00: 49 66 20 61 6e 79 20 74 65 72 6d 20 69 73 20 72  If any term is r
8f10: 65 66 65 72 65 6e 63 65 20 74 6f 20 61 0a 2a 2a  eference to a.**
8f20: 20 72 65 73 75 6c 74 20 73 65 74 20 65 78 70 72   result set expr
8f30: 65 73 73 69 6f 6e 20 28 61 73 20 64 65 74 65 72  ession (as deter
8f40: 6d 69 6e 65 64 20 62 79 20 74 68 65 20 45 78 70  mined by the Exp
8f50: 72 4c 69 73 74 2e 61 2e 75 2e 78 2e 69 4f 72 64  rList.a.u.x.iOrd
8f60: 65 72 42 79 43 6f 6c 0a 2a 2a 20 66 69 65 6c 64  erByCol.** field
8f70: 29 20 74 68 65 6e 20 63 6f 6e 76 65 72 74 20 74  ) then convert t
8f80: 68 61 74 20 74 65 72 6d 20 69 6e 74 6f 20 61 20  hat term into a 
8f90: 63 6f 70 79 20 6f 66 20 74 68 65 20 63 6f 72 72  copy of the corr
8fa0: 65 73 70 6f 6e 64 69 6e 67 20 72 65 73 75 6c 74  esponding result
8fb0: 20 73 65 74 0a 2a 2a 20 63 6f 6c 75 6d 6e 2e 0a   set.** column..
8fc0: 2a 2a 0a 2a 2a 20 49 66 20 61 6e 79 20 65 72 72  **.** If any err
8fd0: 6f 72 73 20 61 72 65 20 64 65 74 65 63 74 65 64  ors are detected
8fe0: 2c 20 61 64 64 20 61 6e 20 65 72 72 6f 72 20 6d  , add an error m
8ff0: 65 73 73 61 67 65 20 74 6f 20 70 50 61 72 73 65  essage to pParse
9000: 20 61 6e 64 0a 2a 2a 20 72 65 74 75 72 6e 20 6e   and.** return n
9010: 6f 6e 2d 7a 65 72 6f 2e 20 20 52 65 74 75 72 6e  on-zero.  Return
9020: 20 7a 65 72 6f 20 69 66 20 6e 6f 20 65 72 72 6f   zero if no erro
9030: 72 73 20 61 72 65 20 73 65 65 6e 2e 0a 2a 2f 0a  rs are seen..*/.
9040: 69 6e 74 20 73 71 6c 69 74 65 33 52 65 73 6f 6c  int sqlite3Resol
9050: 76 65 4f 72 64 65 72 47 72 6f 75 70 42 79 28 0a  veOrderGroupBy(.
9060: 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c    Parse *pParse,
9070: 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73 69          /* Parsi
9080: 6e 67 20 63 6f 6e 74 65 78 74 2e 20 20 4c 65 61  ng context.  Lea
9090: 76 65 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65  ve error message
90a0: 73 20 68 65 72 65 20 2a 2f 0a 20 20 53 65 6c 65  s here */.  Sele
90b0: 63 74 20 2a 70 53 65 6c 65 63 74 2c 20 20 20 20  ct *pSelect,    
90c0: 20 20 2f 2a 20 54 68 65 20 53 45 4c 45 43 54 20    /* The SELECT 
90d0: 73 74 61 74 65 6d 65 6e 74 20 63 6f 6e 74 61 69  statement contai
90e0: 6e 69 6e 67 20 74 68 65 20 63 6c 61 75 73 65 20  ning the clause 
90f0: 2a 2f 0a 20 20 45 78 70 72 4c 69 73 74 20 2a 70  */.  ExprList *p
9100: 4f 72 64 65 72 42 79 2c 20 20 20 2f 2a 20 54 68  OrderBy,   /* Th
9110: 65 20 4f 52 44 45 52 20 42 59 20 6f 72 20 47 52  e ORDER BY or GR
9120: 4f 55 50 20 42 59 20 63 6c 61 75 73 65 20 74 6f  OUP BY clause to
9130: 20 62 65 20 70 72 6f 63 65 73 73 65 64 20 2a 2f   be processed */
9140: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
9150: 54 79 70 65 20 20 20 20 20 2f 2a 20 22 4f 52 44  Type     /* "ORD
9160: 45 52 22 20 6f 72 20 22 47 52 4f 55 50 22 20 2a  ER" or "GROUP" *
9170: 2f 0a 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20  /.){.  int i;.  
9180: 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70 50  sqlite3 *db = pP
9190: 61 72 73 65 2d 3e 64 62 3b 0a 20 20 45 78 70 72  arse->db;.  Expr
91a0: 4c 69 73 74 20 2a 70 45 4c 69 73 74 3b 0a 20 20  List *pEList;.  
91b0: 73 74 72 75 63 74 20 45 78 70 72 4c 69 73 74 5f  struct ExprList_
91c0: 69 74 65 6d 20 2a 70 49 74 65 6d 3b 0a 0a 20 20  item *pItem;..  
91d0: 69 66 28 20 70 4f 72 64 65 72 42 79 3d 3d 30 20  if( pOrderBy==0 
91e0: 7c 7c 20 70 50 61 72 73 65 2d 3e 64 62 2d 3e 6d  || pParse->db->m
91f0: 61 6c 6c 6f 63 46 61 69 6c 65 64 20 29 20 72 65  allocFailed ) re
9200: 74 75 72 6e 20 30 3b 0a 20 20 69 66 28 20 70 4f  turn 0;.  if( pO
9210: 72 64 65 72 42 79 2d 3e 6e 45 78 70 72 3e 64 62  rderBy->nExpr>db
9220: 2d 3e 61 4c 69 6d 69 74 5b 53 51 4c 49 54 45 5f  ->aLimit[SQLITE_
9230: 4c 49 4d 49 54 5f 43 4f 4c 55 4d 4e 5d 20 29 7b  LIMIT_COLUMN] ){
9240: 0a 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f  .    sqlite3Erro
9250: 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 74 6f  rMsg(pParse, "to
9260: 6f 20 6d 61 6e 79 20 74 65 72 6d 73 20 69 6e 20  o many terms in 
9270: 25 73 20 42 59 20 63 6c 61 75 73 65 22 2c 20 7a  %s BY clause", z
9280: 54 79 70 65 29 3b 0a 20 20 20 20 72 65 74 75 72  Type);.    retur
9290: 6e 20 31 3b 0a 20 20 7d 0a 20 20 70 45 4c 69 73  n 1;.  }.  pELis
92a0: 74 20 3d 20 70 53 65 6c 65 63 74 2d 3e 70 45 4c  t = pSelect->pEL
92b0: 69 73 74 3b 0a 20 20 61 73 73 65 72 74 28 20 70  ist;.  assert( p
92c0: 45 4c 69 73 74 21 3d 30 20 29 3b 20 20 2f 2a 20  EList!=0 );  /* 
92d0: 73 71 6c 69 74 65 33 53 65 6c 65 63 74 4e 65 77  sqlite3SelectNew
92e0: 28 29 20 67 75 61 72 61 6e 74 65 65 73 20 74 68  () guarantees th
92f0: 69 73 20 2a 2f 0a 20 20 66 6f 72 28 69 3d 30 2c  is */.  for(i=0,
9300: 20 70 49 74 65 6d 3d 70 4f 72 64 65 72 42 79 2d   pItem=pOrderBy-
9310: 3e 61 3b 20 69 3c 70 4f 72 64 65 72 42 79 2d 3e  >a; i<pOrderBy->
9320: 6e 45 78 70 72 3b 20 69 2b 2b 2c 20 70 49 74 65  nExpr; i++, pIte
9330: 6d 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 70 49  m++){.    if( pI
9340: 74 65 6d 2d 3e 75 2e 78 2e 69 4f 72 64 65 72 42  tem->u.x.iOrderB
9350: 79 43 6f 6c 20 29 7b 0a 20 20 20 20 20 20 69 66  yCol ){.      if
9360: 28 20 70 49 74 65 6d 2d 3e 75 2e 78 2e 69 4f 72  ( pItem->u.x.iOr
9370: 64 65 72 42 79 43 6f 6c 3e 70 45 4c 69 73 74 2d  derByCol>pEList-
9380: 3e 6e 45 78 70 72 20 29 7b 0a 20 20 20 20 20 20  >nExpr ){.      
9390: 20 20 72 65 73 6f 6c 76 65 4f 75 74 4f 66 52 61    resolveOutOfRa
93a0: 6e 67 65 45 72 72 6f 72 28 70 50 61 72 73 65 2c  ngeError(pParse,
93b0: 20 7a 54 79 70 65 2c 20 69 2b 31 2c 20 70 45 4c   zType, i+1, pEL
93c0: 69 73 74 2d 3e 6e 45 78 70 72 29 3b 0a 20 20 20  ist->nExpr);.   
93d0: 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20       return 1;. 
93e0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65 73       }.      res
93f0: 6f 6c 76 65 41 6c 69 61 73 28 70 50 61 72 73 65  olveAlias(pParse
9400: 2c 20 70 45 4c 69 73 74 2c 20 70 49 74 65 6d 2d  , pEList, pItem-
9410: 3e 75 2e 78 2e 69 4f 72 64 65 72 42 79 43 6f 6c  >u.x.iOrderByCol
9420: 2d 31 2c 20 70 49 74 65 6d 2d 3e 70 45 78 70 72  -1, pItem->pExpr
9430: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
9440: 20 20 20 20 20 7a 54 79 70 65 2c 30 29 3b 0a 20       zType,0);. 
9450: 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72     }.  }.  retur
9460: 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 70 4f  n 0;.}../*.** pO
9470: 72 64 65 72 42 79 20 69 73 20 61 6e 20 4f 52 44  rderBy is an ORD
9480: 45 52 20 42 59 20 6f 72 20 47 52 4f 55 50 20 42  ER BY or GROUP B
9490: 59 20 63 6c 61 75 73 65 20 69 6e 20 53 45 4c 45  Y clause in SELE
94a0: 43 54 20 73 74 61 74 65 6d 65 6e 74 20 70 53 65  CT statement pSe
94b0: 6c 65 63 74 2e 0a 2a 2a 20 54 68 65 20 4e 61 6d  lect..** The Nam
94c0: 65 20 63 6f 6e 74 65 78 74 20 6f 66 20 74 68 65  e context of the
94d0: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
94e0: 74 20 69 73 20 70 4e 43 2e 20 20 7a 54 79 70 65  t is pNC.  zType
94f0: 20 69 73 20 65 69 74 68 65 72 0a 2a 2a 20 22 4f   is either.** "O
9500: 52 44 45 52 22 20 6f 72 20 22 47 52 4f 55 50 22  RDER" or "GROUP"
9510: 20 64 65 70 65 6e 64 69 6e 67 20 6f 6e 20 77 68   depending on wh
9520: 69 63 68 20 74 79 70 65 20 6f 66 20 63 6c 61 75  ich type of clau
9530: 73 65 20 70 4f 72 64 65 72 42 79 20 69 73 2e 0a  se pOrderBy is..
9540: 2a 2a 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69  **.** This routi
9550: 6e 65 20 72 65 73 6f 6c 76 65 73 20 65 61 63 68  ne resolves each
9560: 20 74 65 72 6d 20 6f 66 20 74 68 65 20 63 6c 61   term of the cla
9570: 75 73 65 20 69 6e 74 6f 20 61 6e 20 65 78 70 72  use into an expr
9580: 65 73 73 69 6f 6e 2e 0a 2a 2a 20 49 66 20 74 68  ession..** If th
9590: 65 20 6f 72 64 65 72 2d 62 79 20 74 65 72 6d 20  e order-by term 
95a0: 69 73 20 61 6e 20 69 6e 74 65 67 65 72 20 49 20  is an integer I 
95b0: 62 65 74 77 65 65 6e 20 31 20 61 6e 64 20 4e 20  between 1 and N 
95c0: 28 77 68 65 72 65 20 4e 20 69 73 20 74 68 65 0a  (where N is the.
95d0: 2a 2a 20 6e 75 6d 62 65 72 20 6f 66 20 63 6f 6c  ** number of col
95e0: 75 6d 6e 73 20 69 6e 20 74 68 65 20 72 65 73 75  umns in the resu
95f0: 6c 74 20 73 65 74 20 6f 66 20 74 68 65 20 53 45  lt set of the SE
9600: 4c 45 43 54 29 20 74 68 65 6e 20 74 68 65 20 65  LECT) then the e
9610: 78 70 72 65 73 73 69 6f 6e 0a 2a 2a 20 69 6e 20  xpression.** in 
9620: 74 68 65 20 72 65 73 6f 6c 75 74 69 6f 6e 20 69  the resolution i
9630: 73 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20  s a copy of the 
9640: 49 2d 74 68 20 72 65 73 75 6c 74 2d 73 65 74 20  I-th result-set 
9650: 65 78 70 72 65 73 73 69 6f 6e 2e 20 20 49 66 0a  expression.  If.
9660: 2a 2a 20 74 68 65 20 6f 72 64 65 72 2d 62 79 20  ** the order-by 
9670: 74 65 72 6d 20 69 73 20 61 6e 20 69 64 65 6e 74  term is an ident
9680: 69 66 69 65 72 20 74 68 61 74 20 63 6f 72 72 65  ifier that corre
9690: 73 70 6f 6e 64 73 20 74 6f 20 74 68 65 20 41 53  sponds to the AS
96a0: 2d 6e 61 6d 65 20 6f 66 0a 2a 2a 20 61 20 72 65  -name of.** a re
96b0: 73 75 6c 74 2d 73 65 74 20 65 78 70 72 65 73 73  sult-set express
96c0: 69 6f 6e 2c 20 74 68 65 6e 20 74 68 65 20 74 65  ion, then the te
96d0: 72 6d 20 72 65 73 6f 6c 76 65 73 20 74 6f 20 61  rm resolves to a
96e0: 20 63 6f 70 79 20 6f 66 20 74 68 65 0a 2a 2a 20   copy of the.** 
96f0: 72 65 73 75 6c 74 2d 73 65 74 20 65 78 70 72 65  result-set expre
9700: 73 73 69 6f 6e 2e 20 20 4f 74 68 65 72 77 69 73  ssion.  Otherwis
9710: 65 2c 20 74 68 65 20 65 78 70 72 65 73 73 69 6f  e, the expressio
9720: 6e 20 69 73 20 72 65 73 6f 6c 76 65 64 20 69 6e  n is resolved in
9730: 0a 2a 2a 20 74 68 65 20 75 73 75 61 6c 20 77 61  .** the usual wa
9740: 79 20 2d 20 75 73 69 6e 67 20 73 71 6c 69 74 65  y - using sqlite
9750: 33 52 65 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65  3ResolveExprName
9760: 73 28 29 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  s()..**.** This 
9770: 72 6f 75 74 69 6e 65 20 72 65 74 75 72 6e 73 20  routine returns 
9780: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 65 72  the number of er
9790: 72 6f 72 73 2e 20 20 49 66 20 65 72 72 6f 72 73  rors.  If errors
97a0: 20 6f 63 63 75 72 2c 20 74 68 65 6e 0a 2a 2a 20   occur, then.** 
97b0: 61 6e 20 61 70 70 72 6f 70 72 69 61 74 65 20 65  an appropriate e
97c0: 72 72 6f 72 20 6d 65 73 73 61 67 65 20 6d 69 67  rror message mig
97d0: 68 74 20 62 65 20 6c 65 66 74 20 69 6e 20 70 50  ht be left in pP
97e0: 61 72 73 65 2e 20 20 28 4f 4f 4d 20 65 72 72 6f  arse.  (OOM erro
97f0: 72 73 0a 2a 2a 20 65 78 63 65 70 74 65 64 2e 29  rs.** excepted.)
9800: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 72  .*/.static int r
9810: 65 73 6f 6c 76 65 4f 72 64 65 72 47 72 6f 75 70  esolveOrderGroup
9820: 42 79 28 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78  By(.  NameContex
9830: 74 20 2a 70 4e 43 2c 20 20 20 20 20 2f 2a 20 54  t *pNC,     /* T
9840: 68 65 20 6e 61 6d 65 20 63 6f 6e 74 65 78 74 20  he name context 
9850: 6f 66 20 74 68 65 20 53 45 4c 45 43 54 20 73 74  of the SELECT st
9860: 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 53 65 6c  atement */.  Sel
9870: 65 63 74 20 2a 70 53 65 6c 65 63 74 2c 20 20 20  ect *pSelect,   
9880: 20 20 20 2f 2a 20 54 68 65 20 53 45 4c 45 43 54     /* The SELECT
9890: 20 73 74 61 74 65 6d 65 6e 74 20 68 6f 6c 64 69   statement holdi
98a0: 6e 67 20 70 4f 72 64 65 72 42 79 20 2a 2f 0a 20  ng pOrderBy */. 
98b0: 20 45 78 70 72 4c 69 73 74 20 2a 70 4f 72 64 65   ExprList *pOrde
98c0: 72 42 79 2c 20 20 20 2f 2a 20 41 6e 20 4f 52 44  rBy,   /* An ORD
98d0: 45 52 20 42 59 20 6f 72 20 47 52 4f 55 50 20 42  ER BY or GROUP B
98e0: 59 20 63 6c 61 75 73 65 20 74 6f 20 72 65 73 6f  Y clause to reso
98f0: 6c 76 65 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63  lve */.  const c
9900: 68 61 72 20 2a 7a 54 79 70 65 20 20 20 20 20 2f  har *zType     /
9910: 2a 20 45 69 74 68 65 72 20 22 4f 52 44 45 52 22  * Either "ORDER"
9920: 20 6f 72 20 22 47 52 4f 55 50 22 2c 20 61 73 20   or "GROUP", as 
9930: 61 70 70 72 6f 70 72 69 61 74 65 20 2a 2f 0a 29  appropriate */.)
9940: 7b 0a 20 20 69 6e 74 20 69 2c 20 6a 3b 20 20 20  {.  int i, j;   
9950: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9960: 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74     /* Loop count
9970: 65 72 73 20 2a 2f 0a 20 20 69 6e 74 20 69 43 6f  ers */.  int iCo
9980: 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  l;              
9990: 20 20 20 20 20 20 20 20 2f 2a 20 43 6f 6c 75 6d          /* Colum
99a0: 6e 20 6e 75 6d 62 65 72 20 2a 2f 0a 20 20 73 74  n number */.  st
99b0: 72 75 63 74 20 45 78 70 72 4c 69 73 74 5f 69 74  ruct ExprList_it
99c0: 65 6d 20 2a 70 49 74 65 6d 3b 20 20 20 2f 2a 20  em *pItem;   /* 
99d0: 41 20 74 65 72 6d 20 6f 66 20 74 68 65 20 4f 52  A term of the OR
99e0: 44 45 52 20 42 59 20 63 6c 61 75 73 65 20 2a 2f  DER BY clause */
99f0: 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65  .  Parse *pParse
9a00: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
9a10: 20 20 2f 2a 20 50 61 72 73 69 6e 67 20 63 6f 6e    /* Parsing con
9a20: 74 65 78 74 20 2a 2f 0a 20 20 69 6e 74 20 6e 52  text */.  int nR
9a30: 65 73 75 6c 74 3b 20 20 20 20 20 20 20 20 20 20  esult;          
9a40: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62           /* Numb
9a50: 65 72 20 6f 66 20 74 65 72 6d 73 20 69 6e 20 74  er of terms in t
9a60: 68 65 20 72 65 73 75 6c 74 20 73 65 74 20 2a 2f  he result set */
9a70: 0a 0a 20 20 69 66 28 20 70 4f 72 64 65 72 42 79  ..  if( pOrderBy
9a80: 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a  ==0 ) return 0;.
9a90: 20 20 6e 52 65 73 75 6c 74 20 3d 20 70 53 65 6c    nResult = pSel
9aa0: 65 63 74 2d 3e 70 45 4c 69 73 74 2d 3e 6e 45 78  ect->pEList->nEx
9ab0: 70 72 3b 0a 20 20 70 50 61 72 73 65 20 3d 20 70  pr;.  pParse = p
9ac0: 4e 43 2d 3e 70 50 61 72 73 65 3b 0a 20 20 66 6f  NC->pParse;.  fo
9ad0: 72 28 69 3d 30 2c 20 70 49 74 65 6d 3d 70 4f 72  r(i=0, pItem=pOr
9ae0: 64 65 72 42 79 2d 3e 61 3b 20 69 3c 70 4f 72 64  derBy->a; i<pOrd
9af0: 65 72 42 79 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b  erBy->nExpr; i++
9b00: 2c 20 70 49 74 65 6d 2b 2b 29 7b 0a 20 20 20 20  , pItem++){.    
9b10: 45 78 70 72 20 2a 70 45 20 3d 20 70 49 74 65 6d  Expr *pE = pItem
9b20: 2d 3e 70 45 78 70 72 3b 0a 20 20 20 20 45 78 70  ->pExpr;.    Exp
9b30: 72 20 2a 70 45 32 20 3d 20 73 71 6c 69 74 65 33  r *pE2 = sqlite3
9b40: 45 78 70 72 53 6b 69 70 43 6f 6c 6c 61 74 65 28  ExprSkipCollate(
9b50: 70 45 29 3b 0a 20 20 20 20 69 66 28 20 7a 54 79  pE);.    if( zTy
9b60: 70 65 5b 30 5d 21 3d 27 47 27 20 29 7b 0a 20 20  pe[0]!='G' ){.  
9b70: 20 20 20 20 69 43 6f 6c 20 3d 20 72 65 73 6f 6c      iCol = resol
9b80: 76 65 41 73 4e 61 6d 65 28 70 50 61 72 73 65 2c  veAsName(pParse,
9b90: 20 70 53 65 6c 65 63 74 2d 3e 70 45 4c 69 73 74   pSelect->pEList
9ba0: 2c 20 70 45 32 29 3b 0a 20 20 20 20 20 20 69 66  , pE2);.      if
9bb0: 28 20 69 43 6f 6c 3e 30 20 29 7b 0a 20 20 20 20  ( iCol>0 ){.    
9bc0: 20 20 20 20 2f 2a 20 49 66 20 61 6e 20 41 53 2d      /* If an AS-
9bd0: 6e 61 6d 65 20 6d 61 74 63 68 20 69 73 20 66 6f  name match is fo
9be0: 75 6e 64 2c 20 6d 61 72 6b 20 74 68 69 73 20 4f  und, mark this O
9bf0: 52 44 45 52 20 42 59 20 63 6f 6c 75 6d 6e 20 61  RDER BY column a
9c00: 73 20 62 65 69 6e 67 0a 20 20 20 20 20 20 20 20  s being.        
9c10: 2a 2a 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65  ** a copy of the
9c20: 20 69 43 6f 6c 2d 74 68 20 72 65 73 75 6c 74 2d   iCol-th result-
9c30: 73 65 74 20 63 6f 6c 75 6d 6e 2e 20 20 54 68 65  set column.  The
9c40: 20 73 75 62 73 65 71 75 65 6e 74 20 63 61 6c 6c   subsequent call
9c50: 20 74 6f 0a 20 20 20 20 20 20 20 20 2a 2a 20 73   to.        ** s
9c60: 71 6c 69 74 65 33 52 65 73 6f 6c 76 65 4f 72 64  qlite3ResolveOrd
9c70: 65 72 47 72 6f 75 70 42 79 28 29 20 77 69 6c 6c  erGroupBy() will
9c80: 20 63 6f 6e 76 65 72 74 20 74 68 65 20 65 78 70   convert the exp
9c90: 72 65 73 73 69 6f 6e 20 74 6f 20 61 0a 20 20 20  ression to a.   
9ca0: 20 20 20 20 20 2a 2a 20 63 6f 70 79 20 6f 66 20       ** copy of 
9cb0: 74 68 65 20 69 43 6f 6c 2d 74 68 20 72 65 73 75  the iCol-th resu
9cc0: 6c 74 2d 73 65 74 20 65 78 70 72 65 73 73 69 6f  lt-set expressio
9cd0: 6e 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20 70 49  n. */.        pI
9ce0: 74 65 6d 2d 3e 75 2e 78 2e 69 4f 72 64 65 72 42  tem->u.x.iOrderB
9cf0: 79 43 6f 6c 20 3d 20 28 75 31 36 29 69 43 6f 6c  yCol = (u16)iCol
9d00: 3b 0a 20 20 20 20 20 20 20 20 63 6f 6e 74 69 6e  ;.        contin
9d10: 75 65 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ue;.      }.    
9d20: 7d 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  }.    if( sqlite
9d30: 33 45 78 70 72 49 73 49 6e 74 65 67 65 72 28 70  3ExprIsInteger(p
9d40: 45 32 2c 20 26 69 43 6f 6c 29 20 29 7b 0a 20 20  E2, &iCol) ){.  
9d50: 20 20 20 20 2f 2a 20 54 68 65 20 4f 52 44 45 52      /* The ORDER
9d60: 20 42 59 20 74 65 72 6d 20 69 73 20 61 6e 20 69   BY term is an i
9d70: 6e 74 65 67 65 72 20 63 6f 6e 73 74 61 6e 74 2e  nteger constant.
9d80: 20 20 41 67 61 69 6e 2c 20 73 65 74 20 74 68 65    Again, set the
9d90: 20 63 6f 6c 75 6d 6e 0a 20 20 20 20 20 20 2a 2a   column.      **
9da0: 20 6e 75 6d 62 65 72 20 73 6f 20 74 68 61 74 20   number so that 
9db0: 73 71 6c 69 74 65 33 52 65 73 6f 6c 76 65 4f 72  sqlite3ResolveOr
9dc0: 64 65 72 47 72 6f 75 70 42 79 28 29 20 77 69 6c  derGroupBy() wil
9dd0: 6c 20 63 6f 6e 76 65 72 74 20 74 68 65 0a 20 20  l convert the.  
9de0: 20 20 20 20 2a 2a 20 6f 72 64 65 72 2d 62 79 20      ** order-by 
9df0: 74 65 72 6d 20 74 6f 20 61 20 63 6f 70 79 20 6f  term to a copy o
9e00: 66 20 74 68 65 20 72 65 73 75 6c 74 2d 73 65 74  f the result-set
9e10: 20 65 78 70 72 65 73 73 69 6f 6e 20 2a 2f 0a 20   expression */. 
9e20: 20 20 20 20 20 69 66 28 20 69 43 6f 6c 3c 31 20       if( iCol<1 
9e30: 7c 7c 20 69 43 6f 6c 3e 30 78 66 66 66 66 20 29  || iCol>0xffff )
9e40: 7b 0a 20 20 20 20 20 20 20 20 72 65 73 6f 6c 76  {.        resolv
9e50: 65 4f 75 74 4f 66 52 61 6e 67 65 45 72 72 6f 72  eOutOfRangeError
9e60: 28 70 50 61 72 73 65 2c 20 7a 54 79 70 65 2c 20  (pParse, zType, 
9e70: 69 2b 31 2c 20 6e 52 65 73 75 6c 74 29 3b 0a 20  i+1, nResult);. 
9e80: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b         return 1;
9e90: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 70  .      }.      p
9ea0: 49 74 65 6d 2d 3e 75 2e 78 2e 69 4f 72 64 65 72  Item->u.x.iOrder
9eb0: 42 79 43 6f 6c 20 3d 20 28 75 31 36 29 69 43 6f  ByCol = (u16)iCo
9ec0: 6c 3b 0a 20 20 20 20 20 20 63 6f 6e 74 69 6e 75  l;.      continu
9ed0: 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a  e;.    }..    /*
9ee0: 20 4f 74 68 65 72 77 69 73 65 2c 20 74 72 65 61   Otherwise, trea
9ef0: 74 20 74 68 65 20 4f 52 44 45 52 20 42 59 20 74  t the ORDER BY t
9f00: 65 72 6d 20 61 73 20 61 6e 20 6f 72 64 69 6e 61  erm as an ordina
9f10: 72 79 20 65 78 70 72 65 73 73 69 6f 6e 20 2a 2f  ry expression */
9f20: 0a 20 20 20 20 70 49 74 65 6d 2d 3e 75 2e 78 2e  .    pItem->u.x.
9f30: 69 4f 72 64 65 72 42 79 43 6f 6c 20 3d 20 30 3b  iOrderByCol = 0;
9f40: 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33  .    if( sqlite3
9f50: 52 65 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65 73  ResolveExprNames
9f60: 28 70 4e 43 2c 20 70 45 29 20 29 7b 0a 20 20 20  (pNC, pE) ){.   
9f70: 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20     return 1;.   
9f80: 20 7d 0a 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20   }.    for(j=0; 
9f90: 6a 3c 70 53 65 6c 65 63 74 2d 3e 70 45 4c 69 73  j<pSelect->pELis
9fa0: 74 2d 3e 6e 45 78 70 72 3b 20 6a 2b 2b 29 7b 0a  t->nExpr; j++){.
9fb0: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
9fc0: 33 45 78 70 72 43 6f 6d 70 61 72 65 28 30 2c 20  3ExprCompare(0, 
9fd0: 70 45 2c 20 70 53 65 6c 65 63 74 2d 3e 70 45 4c  pE, pSelect->pEL
9fe0: 69 73 74 2d 3e 61 5b 6a 5d 2e 70 45 78 70 72 2c  ist->a[j].pExpr,
9ff0: 20 2d 31 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20   -1)==0 ){.     
a000: 20 20 20 70 49 74 65 6d 2d 3e 75 2e 78 2e 69 4f     pItem->u.x.iO
a010: 72 64 65 72 42 79 43 6f 6c 20 3d 20 6a 2b 31 3b  rderByCol = j+1;
a020: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20  .      }.    }. 
a030: 20 7d 0a 20 20 72 65 74 75 72 6e 20 73 71 6c 69   }.  return sqli
a040: 74 65 33 52 65 73 6f 6c 76 65 4f 72 64 65 72 47  te3ResolveOrderG
a050: 72 6f 75 70 42 79 28 70 50 61 72 73 65 2c 20 70  roupBy(pParse, p
a060: 53 65 6c 65 63 74 2c 20 70 4f 72 64 65 72 42 79  Select, pOrderBy
a070: 2c 20 7a 54 79 70 65 29 3b 0a 7d 0a 0a 2f 2a 0a  , zType);.}../*.
a080: 2a 2a 20 52 65 73 6f 6c 76 65 20 6e 61 6d 65 73  ** Resolve names
a090: 20 69 6e 20 74 68 65 20 53 45 4c 45 43 54 20 73   in the SELECT s
a0a0: 74 61 74 65 6d 65 6e 74 20 70 20 61 6e 64 20 61  tatement p and a
a0b0: 6c 6c 20 6f 66 20 69 74 73 20 64 65 73 63 65 6e  ll of its descen
a0c0: 64 61 6e 74 73 2e 0a 2a 2f 0a 73 74 61 74 69 63  dants..*/.static
a0d0: 20 69 6e 74 20 72 65 73 6f 6c 76 65 53 65 6c 65   int resolveSele
a0e0: 63 74 53 74 65 70 28 57 61 6c 6b 65 72 20 2a 70  ctStep(Walker *p
a0f0: 57 61 6c 6b 65 72 2c 20 53 65 6c 65 63 74 20 2a  Walker, Select *
a100: 70 29 7b 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78  p){.  NameContex
a110: 74 20 2a 70 4f 75 74 65 72 4e 43 3b 20 20 2f 2a  t *pOuterNC;  /*
a120: 20 43 6f 6e 74 65 78 74 20 74 68 61 74 20 63 6f   Context that co
a130: 6e 74 61 69 6e 73 20 74 68 69 73 20 53 45 4c 45  ntains this SELE
a140: 43 54 20 2a 2f 0a 20 20 4e 61 6d 65 43 6f 6e 74  CT */.  NameCont
a150: 65 78 74 20 73 4e 43 3b 20 20 20 20 20 20 20 20  ext sNC;        
a160: 2f 2a 20 4e 61 6d 65 20 63 6f 6e 74 65 78 74 20  /* Name context 
a170: 6f 66 20 74 68 69 73 20 53 45 4c 45 43 54 20 2a  of this SELECT *
a180: 2f 0a 20 20 69 6e 74 20 69 73 43 6f 6d 70 6f 75  /.  int isCompou
a190: 6e 64 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 54  nd;         /* T
a1a0: 72 75 65 20 69 66 20 70 20 69 73 20 61 20 63 6f  rue if p is a co
a1b0: 6d 70 6f 75 6e 64 20 73 65 6c 65 63 74 20 2a 2f  mpound select */
a1c0: 0a 20 20 69 6e 74 20 6e 43 6f 6d 70 6f 75 6e 64  .  int nCompound
a1d0: 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75  ;          /* Nu
a1e0: 6d 62 65 72 20 6f 66 20 63 6f 6d 70 6f 75 6e 64  mber of compound
a1f0: 20 74 65 72 6d 73 20 70 72 6f 63 65 73 73 65 64   terms processed
a200: 20 73 6f 20 66 61 72 20 2a 2f 0a 20 20 50 61 72   so far */.  Par
a210: 73 65 20 2a 70 50 61 72 73 65 3b 20 20 20 20 20  se *pParse;     
a220: 20 20 20 20 20 2f 2a 20 50 61 72 73 69 6e 67 20       /* Parsing 
a230: 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 69 6e 74  context */.  int
a240: 20 69 3b 20 20 20 20 20 20 20 20 20 20 20 20 20   i;             
a250: 20 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75       /* Loop cou
a260: 6e 74 65 72 20 2a 2f 0a 20 20 45 78 70 72 4c 69  nter */.  ExprLi
a270: 73 74 20 2a 70 47 72 6f 75 70 42 79 3b 20 20 20  st *pGroupBy;   
a280: 20 20 2f 2a 20 54 68 65 20 47 52 4f 55 50 20 42    /* The GROUP B
a290: 59 20 63 6c 61 75 73 65 20 2a 2f 0a 20 20 53 65  Y clause */.  Se
a2a0: 6c 65 63 74 20 2a 70 4c 65 66 74 6d 6f 73 74 3b  lect *pLeftmost;
a2b0: 20 20 20 20 20 20 2f 2a 20 4c 65 66 74 2d 6d 6f        /* Left-mo
a2c0: 73 74 20 6f 66 20 53 45 4c 45 43 54 20 6f 66 20  st of SELECT of 
a2d0: 61 20 63 6f 6d 70 6f 75 6e 64 20 2a 2f 0a 20 20  a compound */.  
a2e0: 73 71 6c 69 74 65 33 20 2a 64 62 3b 20 20 20 20  sqlite3 *db;    
a2f0: 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62          /* Datab
a300: 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a  ase connection *
a310: 2f 0a 20 20 0a 0a 20 20 61 73 73 65 72 74 28 20  /.  ..  assert( 
a320: 70 21 3d 30 20 29 3b 0a 20 20 69 66 28 20 70 2d  p!=0 );.  if( p-
a330: 3e 73 65 6c 46 6c 61 67 73 20 26 20 53 46 5f 52  >selFlags & SF_R
a340: 65 73 6f 6c 76 65 64 20 29 7b 0a 20 20 20 20 72  esolved ){.    r
a350: 65 74 75 72 6e 20 57 52 43 5f 50 72 75 6e 65 3b  eturn WRC_Prune;
a360: 0a 20 20 7d 0a 20 20 70 4f 75 74 65 72 4e 43 20  .  }.  pOuterNC 
a370: 3d 20 70 57 61 6c 6b 65 72 2d 3e 75 2e 70 4e 43  = pWalker->u.pNC
a380: 3b 0a 20 20 70 50 61 72 73 65 20 3d 20 70 57 61  ;.  pParse = pWa
a390: 6c 6b 65 72 2d 3e 70 50 61 72 73 65 3b 0a 20 20  lker->pParse;.  
a3a0: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
a3b0: 0a 0a 20 20 2f 2a 20 4e 6f 72 6d 61 6c 6c 79 20  ..  /* Normally 
a3c0: 73 71 6c 69 74 65 33 53 65 6c 65 63 74 45 78 70  sqlite3SelectExp
a3d0: 61 6e 64 28 29 20 77 69 6c 6c 20 62 65 20 63 61  and() will be ca
a3e0: 6c 6c 65 64 20 66 69 72 73 74 20 61 6e 64 20 77  lled first and w
a3f0: 69 6c 6c 20 68 61 76 65 0a 20 20 2a 2a 20 61 6c  ill have.  ** al
a400: 72 65 61 64 79 20 65 78 70 61 6e 64 65 64 20 74  ready expanded t
a410: 68 69 73 20 53 45 4c 45 43 54 2e 20 20 48 6f 77  his SELECT.  How
a420: 65 76 65 72 2c 20 69 66 20 74 68 69 73 20 69 73  ever, if this is
a430: 20 61 20 73 75 62 71 75 65 72 79 20 77 69 74 68   a subquery with
a440: 69 6e 0a 20 20 2a 2a 20 61 6e 20 65 78 70 72 65  in.  ** an expre
a450: 73 73 69 6f 6e 2c 20 73 71 6c 69 74 65 33 52 65  ssion, sqlite3Re
a460: 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65 73 28 29  solveExprNames()
a470: 20 77 69 6c 6c 20 62 65 20 63 61 6c 6c 65 64 20   will be called 
a480: 77 69 74 68 6f 75 74 20 61 0a 20 20 2a 2a 20 70  without a.  ** p
a490: 72 69 6f 72 20 63 61 6c 6c 20 74 6f 20 73 71 6c  rior call to sql
a4a0: 69 74 65 33 53 65 6c 65 63 74 45 78 70 61 6e 64  ite3SelectExpand
a4b0: 28 29 2e 20 20 57 68 65 6e 20 74 68 61 74 20 68  ().  When that h
a4c0: 61 70 70 65 6e 73 2c 20 6c 65 74 0a 20 20 2a 2a  appens, let.  **
a4d0: 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 50 72   sqlite3SelectPr
a4e0: 65 70 28 29 20 64 6f 20 61 6c 6c 20 6f 66 20 74  ep() do all of t
a4f0: 68 65 20 70 72 6f 63 65 73 73 69 6e 67 20 66 6f  he processing fo
a500: 72 20 74 68 69 73 20 53 45 4c 45 43 54 2e 0a 20  r this SELECT.. 
a510: 20 2a 2a 20 73 71 6c 69 74 65 33 53 65 6c 65 63   ** sqlite3Selec
a520: 74 50 72 65 70 28 29 20 77 69 6c 6c 20 69 6e 76  tPrep() will inv
a530: 6f 6b 65 20 62 6f 74 68 20 73 71 6c 69 74 65 33  oke both sqlite3
a540: 53 65 6c 65 63 74 45 78 70 61 6e 64 28 29 20 61  SelectExpand() a
a550: 6e 64 0a 20 20 2a 2a 20 74 68 69 73 20 72 6f 75  nd.  ** this rou
a560: 74 69 6e 65 20 69 6e 20 74 68 65 20 63 6f 72 72  tine in the corr
a570: 65 63 74 20 6f 72 64 65 72 2e 0a 20 20 2a 2f 0a  ect order..  */.
a580: 20 20 69 66 28 20 28 70 2d 3e 73 65 6c 46 6c 61    if( (p->selFla
a590: 67 73 20 26 20 53 46 5f 45 78 70 61 6e 64 65 64  gs & SF_Expanded
a5a0: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73 71 6c 69  )==0 ){.    sqli
a5b0: 74 65 33 53 65 6c 65 63 74 50 72 65 70 28 70 50  te3SelectPrep(pP
a5c0: 61 72 73 65 2c 20 70 2c 20 70 4f 75 74 65 72 4e  arse, p, pOuterN
a5d0: 43 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 28  C);.    return (
a5e0: 70 50 61 72 73 65 2d 3e 6e 45 72 72 20 7c 7c 20  pParse->nErr || 
a5f0: 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64  db->mallocFailed
a600: 29 20 3f 20 57 52 43 5f 41 62 6f 72 74 20 3a 20  ) ? WRC_Abort : 
a610: 57 52 43 5f 50 72 75 6e 65 3b 0a 20 20 7d 0a 0a  WRC_Prune;.  }..
a620: 20 20 69 73 43 6f 6d 70 6f 75 6e 64 20 3d 20 70    isCompound = p
a630: 2d 3e 70 50 72 69 6f 72 21 3d 30 3b 0a 20 20 6e  ->pPrior!=0;.  n
a640: 43 6f 6d 70 6f 75 6e 64 20 3d 20 30 3b 0a 20 20  Compound = 0;.  
a650: 70 4c 65 66 74 6d 6f 73 74 20 3d 20 70 3b 0a 20  pLeftmost = p;. 
a660: 20 77 68 69 6c 65 28 20 70 20 29 7b 0a 20 20 20   while( p ){.   
a670: 20 61 73 73 65 72 74 28 20 28 70 2d 3e 73 65 6c   assert( (p->sel
a680: 46 6c 61 67 73 20 26 20 53 46 5f 45 78 70 61 6e  Flags & SF_Expan
a690: 64 65 64 29 21 3d 30 20 29 3b 0a 20 20 20 20 61  ded)!=0 );.    a
a6a0: 73 73 65 72 74 28 20 28 70 2d 3e 73 65 6c 46 6c  ssert( (p->selFl
a6b0: 61 67 73 20 26 20 53 46 5f 52 65 73 6f 6c 76 65  ags & SF_Resolve
a6c0: 64 29 3d 3d 30 20 29 3b 0a 20 20 20 20 70 2d 3e  d)==0 );.    p->
a6d0: 73 65 6c 46 6c 61 67 73 20 7c 3d 20 53 46 5f 52  selFlags |= SF_R
a6e0: 65 73 6f 6c 76 65 64 3b 0a 0a 20 20 20 20 2f 2a  esolved;..    /*
a6f0: 20 52 65 73 6f 6c 76 65 20 74 68 65 20 65 78 70   Resolve the exp
a700: 72 65 73 73 69 6f 6e 73 20 69 6e 20 74 68 65 20  ressions in the 
a710: 4c 49 4d 49 54 20 61 6e 64 20 4f 46 46 53 45 54  LIMIT and OFFSET
a720: 20 63 6c 61 75 73 65 73 2e 20 54 68 65 73 65 0a   clauses. These.
a730: 20 20 20 20 2a 2a 20 61 72 65 20 6e 6f 74 20 61      ** are not a
a740: 6c 6c 6f 77 65 64 20 74 6f 20 72 65 66 65 72 20  llowed to refer 
a750: 74 6f 20 61 6e 79 20 6e 61 6d 65 73 2c 20 73 6f  to any names, so
a760: 20 70 61 73 73 20 61 6e 20 65 6d 70 74 79 20 4e   pass an empty N
a770: 61 6d 65 43 6f 6e 74 65 78 74 2e 0a 20 20 20 20  ameContext..    
a780: 2a 2f 0a 20 20 20 20 6d 65 6d 73 65 74 28 26 73  */.    memset(&s
a790: 4e 43 2c 20 30 2c 20 73 69 7a 65 6f 66 28 73 4e  NC, 0, sizeof(sN
a7a0: 43 29 29 3b 0a 20 20 20 20 73 4e 43 2e 70 50 61  C));.    sNC.pPa
a7b0: 72 73 65 20 3d 20 70 50 61 72 73 65 3b 0a 20 20  rse = pParse;.  
a7c0: 20 20 69 66 28 20 73 71 6c 69 74 65 33 52 65 73    if( sqlite3Res
a7d0: 6f 6c 76 65 45 78 70 72 4e 61 6d 65 73 28 26 73  olveExprNames(&s
a7e0: 4e 43 2c 20 70 2d 3e 70 4c 69 6d 69 74 29 20 29  NC, p->pLimit) )
a7f0: 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 57  {.      return W
a800: 52 43 5f 41 62 6f 72 74 3b 0a 20 20 20 20 7d 0a  RC_Abort;.    }.
a810: 0a 20 20 20 20 2f 2a 20 49 66 20 74 68 65 20 53  .    /* If the S
a820: 46 5f 43 6f 6e 76 65 72 74 65 64 20 66 6c 61 67  F_Converted flag
a830: 73 20 69 73 20 73 65 74 2c 20 74 68 65 6e 20 74  s is set, then t
a840: 68 69 73 20 53 65 6c 65 63 74 20 6f 62 6a 65 63  his Select objec
a850: 74 20 77 61 73 0a 20 20 20 20 2a 2a 20 77 61 73  t was.    ** was
a860: 20 63 72 65 61 74 65 64 20 62 79 20 74 68 65 20   created by the 
a870: 63 6f 6e 76 65 72 74 43 6f 6d 70 6f 75 6e 64 53  convertCompoundS
a880: 65 6c 65 63 74 54 6f 53 75 62 71 75 65 72 79 28  electToSubquery(
a890: 29 20 66 75 6e 63 74 69 6f 6e 2e 0a 20 20 20 20  ) function..    
a8a0: 2a 2a 20 49 6e 20 74 68 69 73 20 63 61 73 65 20  ** In this case 
a8b0: 74 68 65 20 4f 52 44 45 52 20 42 59 20 63 6c 61  the ORDER BY cla
a8c0: 75 73 65 20 28 70 2d 3e 70 4f 72 64 65 72 42 79  use (p->pOrderBy
a8d0: 29 20 73 68 6f 75 6c 64 20 62 65 20 72 65 73 6f  ) should be reso
a8e0: 6c 76 65 64 0a 20 20 20 20 2a 2a 20 61 73 20 69  lved.    ** as i
a8f0: 66 20 69 74 20 77 65 72 65 20 70 61 72 74 20 6f  f it were part o
a900: 66 20 74 68 65 20 73 75 62 2d 71 75 65 72 79 2c  f the sub-query,
a910: 20 6e 6f 74 20 74 68 65 20 70 61 72 65 6e 74 2e   not the parent.
a920: 20 54 68 69 73 20 62 6c 6f 63 6b 0a 20 20 20 20   This block.    
a930: 2a 2a 20 6d 6f 76 65 73 20 74 68 65 20 70 4f 72  ** moves the pOr
a940: 64 65 72 42 79 20 64 6f 77 6e 20 74 6f 20 74 68  derBy down to th
a950: 65 20 73 75 62 2d 71 75 65 72 79 2e 20 49 74 20  e sub-query. It 
a960: 77 69 6c 6c 20 62 65 20 6d 6f 76 65 64 20 62 61  will be moved ba
a970: 63 6b 0a 20 20 20 20 2a 2a 20 61 66 74 65 72 20  ck.    ** after 
a980: 74 68 65 20 6e 61 6d 65 73 20 68 61 76 65 20 62  the names have b
a990: 65 65 6e 20 72 65 73 6f 6c 76 65 64 2e 20 20 2a  een resolved.  *
a9a0: 2f 0a 20 20 20 20 69 66 28 20 70 2d 3e 73 65 6c  /.    if( p->sel
a9b0: 46 6c 61 67 73 20 26 20 53 46 5f 43 6f 6e 76 65  Flags & SF_Conve
a9c0: 72 74 65 64 20 29 7b 0a 20 20 20 20 20 20 53 65  rted ){.      Se
a9d0: 6c 65 63 74 20 2a 70 53 75 62 20 3d 20 70 2d 3e  lect *pSub = p->
a9e0: 70 53 72 63 2d 3e 61 5b 30 5d 2e 70 53 65 6c 65  pSrc->a[0].pSele
a9f0: 63 74 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74  ct;.      assert
aa00: 28 20 70 2d 3e 70 53 72 63 2d 3e 6e 53 72 63 3d  ( p->pSrc->nSrc=
aa10: 3d 31 20 26 26 20 70 2d 3e 70 4f 72 64 65 72 42  =1 && p->pOrderB
aa20: 79 20 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72  y );.      asser
aa30: 74 28 20 70 53 75 62 2d 3e 70 50 72 69 6f 72 20  t( pSub->pPrior 
aa40: 26 26 20 70 53 75 62 2d 3e 70 4f 72 64 65 72 42  && pSub->pOrderB
aa50: 79 3d 3d 30 20 29 3b 0a 20 20 20 20 20 20 70 53  y==0 );.      pS
aa60: 75 62 2d 3e 70 4f 72 64 65 72 42 79 20 3d 20 70  ub->pOrderBy = p
aa70: 2d 3e 70 4f 72 64 65 72 42 79 3b 0a 20 20 20 20  ->pOrderBy;.    
aa80: 20 20 70 2d 3e 70 4f 72 64 65 72 42 79 20 3d 20    p->pOrderBy = 
aa90: 30 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20  0;.    }.  .    
aaa0: 2f 2a 20 52 65 63 75 72 73 69 76 65 6c 79 20 72  /* Recursively r
aab0: 65 73 6f 6c 76 65 20 6e 61 6d 65 73 20 69 6e 20  esolve names in 
aac0: 61 6c 6c 20 73 75 62 71 75 65 72 69 65 73 0a 20  all subqueries. 
aad0: 20 20 20 2a 2f 0a 20 20 20 20 66 6f 72 28 69 3d     */.    for(i=
aae0: 30 3b 20 69 3c 70 2d 3e 70 53 72 63 2d 3e 6e 53  0; i<p->pSrc->nS
aaf0: 72 63 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  rc; i++){.      
ab00: 73 74 72 75 63 74 20 53 72 63 4c 69 73 74 5f 69  struct SrcList_i
ab10: 74 65 6d 20 2a 70 49 74 65 6d 20 3d 20 26 70 2d  tem *pItem = &p-
ab20: 3e 70 53 72 63 2d 3e 61 5b 69 5d 3b 0a 20 20 20  >pSrc->a[i];.   
ab30: 20 20 20 69 66 28 20 70 49 74 65 6d 2d 3e 70 53     if( pItem->pS
ab40: 65 6c 65 63 74 20 29 7b 0a 20 20 20 20 20 20 20  elect ){.       
ab50: 20 4e 61 6d 65 43 6f 6e 74 65 78 74 20 2a 70 4e   NameContext *pN
ab60: 43 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 55 73  C;         /* Us
ab70: 65 64 20 74 6f 20 69 74 65 72 61 74 65 20 6e 61  ed to iterate na
ab80: 6d 65 20 63 6f 6e 74 65 78 74 73 20 2a 2f 0a 20  me contexts */. 
ab90: 20 20 20 20 20 20 20 69 6e 74 20 6e 52 65 66 20         int nRef 
aba0: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
abb0: 20 2f 2a 20 52 65 66 63 6f 75 6e 74 20 66 6f 72   /* Refcount for
abc0: 20 70 4f 75 74 65 72 4e 43 20 61 6e 64 20 6f 75   pOuterNC and ou
abd0: 74 65 72 20 63 6f 6e 74 65 78 74 73 20 2a 2f 0a  ter contexts */.
abe0: 20 20 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68          const ch
abf0: 61 72 20 2a 7a 53 61 76 65 64 43 6f 6e 74 65 78  ar *zSavedContex
ac00: 74 20 3d 20 70 50 61 72 73 65 2d 3e 7a 41 75 74  t = pParse->zAut
ac10: 68 43 6f 6e 74 65 78 74 3b 0a 0a 20 20 20 20 20  hContext;..     
ac20: 20 20 20 2f 2a 20 43 6f 75 6e 74 20 74 68 65 20     /* Count the 
ac30: 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20  total number of 
ac40: 72 65 66 65 72 65 6e 63 65 73 20 74 6f 20 70 4f  references to pO
ac50: 75 74 65 72 4e 43 20 61 6e 64 20 61 6c 6c 20 6f  uterNC and all o
ac60: 66 20 69 74 73 0a 20 20 20 20 20 20 20 20 2a 2a  f its.        **
ac70: 20 70 61 72 65 6e 74 20 63 6f 6e 74 65 78 74 73   parent contexts
ac80: 2e 20 41 66 74 65 72 20 72 65 73 6f 6c 76 69 6e  . After resolvin
ac90: 67 20 72 65 66 65 72 65 6e 63 65 73 20 74 6f 20  g references to 
aca0: 65 78 70 72 65 73 73 69 6f 6e 73 20 69 6e 0a 20  expressions in. 
acb0: 20 20 20 20 20 20 20 2a 2a 20 70 49 74 65 6d 2d         ** pItem-
acc0: 3e 70 53 65 6c 65 63 74 2c 20 63 68 65 63 6b 20  >pSelect, check 
acd0: 69 66 20 74 68 69 73 20 76 61 6c 75 65 20 68 61  if this value ha
ace0: 73 20 63 68 61 6e 67 65 64 2e 20 49 66 20 73 6f  s changed. If so
acf0: 2c 20 74 68 65 6e 0a 20 20 20 20 20 20 20 20 2a  , then.        *
ad00: 2a 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65  * SELECT stateme
ad10: 6e 74 20 70 49 74 65 6d 2d 3e 70 53 65 6c 65 63  nt pItem->pSelec
ad20: 74 20 6d 75 73 74 20 62 65 20 63 6f 72 72 65 6c  t must be correl
ad30: 61 74 65 64 2e 20 53 65 74 20 74 68 65 0a 20 20  ated. Set the.  
ad40: 20 20 20 20 20 20 2a 2a 20 70 49 74 65 6d 2d 3e        ** pItem->
ad50: 66 67 2e 69 73 43 6f 72 72 65 6c 61 74 65 64 20  fg.isCorrelated 
ad60: 66 6c 61 67 20 69 66 20 74 68 69 73 20 69 73 20  flag if this is 
ad70: 74 68 65 20 63 61 73 65 2e 20 2a 2f 0a 20 20 20  the case. */.   
ad80: 20 20 20 20 20 66 6f 72 28 70 4e 43 3d 70 4f 75       for(pNC=pOu
ad90: 74 65 72 4e 43 3b 20 70 4e 43 3b 20 70 4e 43 3d  terNC; pNC; pNC=
ada0: 70 4e 43 2d 3e 70 4e 65 78 74 29 20 6e 52 65 66  pNC->pNext) nRef
adb0: 20 2b 3d 20 70 4e 43 2d 3e 6e 52 65 66 3b 0a 0a   += pNC->nRef;..
adc0: 20 20 20 20 20 20 20 20 69 66 28 20 70 49 74 65          if( pIte
add0: 6d 2d 3e 7a 4e 61 6d 65 20 29 20 70 50 61 72 73  m->zName ) pPars
ade0: 65 2d 3e 7a 41 75 74 68 43 6f 6e 74 65 78 74 20  e->zAuthContext 
adf0: 3d 20 70 49 74 65 6d 2d 3e 7a 4e 61 6d 65 3b 0a  = pItem->zName;.
ae00: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 52          sqlite3R
ae10: 65 73 6f 6c 76 65 53 65 6c 65 63 74 4e 61 6d 65  esolveSelectName
ae20: 73 28 70 50 61 72 73 65 2c 20 70 49 74 65 6d 2d  s(pParse, pItem-
ae30: 3e 70 53 65 6c 65 63 74 2c 20 70 4f 75 74 65 72  >pSelect, pOuter
ae40: 4e 43 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61  NC);.        pPa
ae50: 72 73 65 2d 3e 7a 41 75 74 68 43 6f 6e 74 65 78  rse->zAuthContex
ae60: 74 20 3d 20 7a 53 61 76 65 64 43 6f 6e 74 65 78  t = zSavedContex
ae70: 74 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70  t;.        if( p
ae80: 50 61 72 73 65 2d 3e 6e 45 72 72 20 7c 7c 20 64  Parse->nErr || d
ae90: 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20  b->mallocFailed 
aea0: 29 20 72 65 74 75 72 6e 20 57 52 43 5f 41 62 6f  ) return WRC_Abo
aeb0: 72 74 3b 0a 0a 20 20 20 20 20 20 20 20 66 6f 72  rt;..        for
aec0: 28 70 4e 43 3d 70 4f 75 74 65 72 4e 43 3b 20 70  (pNC=pOuterNC; p
aed0: 4e 43 3b 20 70 4e 43 3d 70 4e 43 2d 3e 70 4e 65  NC; pNC=pNC->pNe
aee0: 78 74 29 20 6e 52 65 66 20 2d 3d 20 70 4e 43 2d  xt) nRef -= pNC-
aef0: 3e 6e 52 65 66 3b 0a 20 20 20 20 20 20 20 20 61  >nRef;.        a
af00: 73 73 65 72 74 28 20 70 49 74 65 6d 2d 3e 66 67  ssert( pItem->fg
af10: 2e 69 73 43 6f 72 72 65 6c 61 74 65 64 3d 3d 30  .isCorrelated==0
af20: 20 26 26 20 6e 52 65 66 3c 3d 30 20 29 3b 0a 20   && nRef<=0 );. 
af30: 20 20 20 20 20 20 20 70 49 74 65 6d 2d 3e 66 67         pItem->fg
af40: 2e 69 73 43 6f 72 72 65 6c 61 74 65 64 20 3d 20  .isCorrelated = 
af50: 28 6e 52 65 66 21 3d 30 29 3b 0a 20 20 20 20 20  (nRef!=0);.     
af60: 20 7d 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20   }.    }.  .    
af70: 2f 2a 20 53 65 74 20 75 70 20 74 68 65 20 6c 6f  /* Set up the lo
af80: 63 61 6c 20 6e 61 6d 65 2d 63 6f 6e 74 65 78 74  cal name-context
af90: 20 74 6f 20 70 61 73 73 20 74 6f 20 73 71 6c 69   to pass to sqli
afa0: 74 65 33 52 65 73 6f 6c 76 65 45 78 70 72 4e 61  te3ResolveExprNa
afb0: 6d 65 73 28 29 20 74 6f 0a 20 20 20 20 2a 2a 20  mes() to.    ** 
afc0: 72 65 73 6f 6c 76 65 20 74 68 65 20 72 65 73 75  resolve the resu
afd0: 6c 74 2d 73 65 74 20 65 78 70 72 65 73 73 69 6f  lt-set expressio
afe0: 6e 20 6c 69 73 74 2e 0a 20 20 20 20 2a 2f 0a 20  n list..    */. 
aff0: 20 20 20 73 4e 43 2e 6e 63 46 6c 61 67 73 20 3d     sNC.ncFlags =
b000: 20 4e 43 5f 41 6c 6c 6f 77 41 67 67 3b 0a 20 20   NC_AllowAgg;.  
b010: 20 20 73 4e 43 2e 70 53 72 63 4c 69 73 74 20 3d    sNC.pSrcList =
b020: 20 70 2d 3e 70 53 72 63 3b 0a 20 20 20 20 73 4e   p->pSrc;.    sN
b030: 43 2e 70 4e 65 78 74 20 3d 20 70 4f 75 74 65 72  C.pNext = pOuter
b040: 4e 43 3b 0a 20 20 0a 20 20 20 20 2f 2a 20 52 65  NC;.  .    /* Re
b050: 73 6f 6c 76 65 20 6e 61 6d 65 73 20 69 6e 20 74  solve names in t
b060: 68 65 20 72 65 73 75 6c 74 20 73 65 74 2e 20 2a  he result set. *
b070: 2f 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  /.    if( sqlite
b080: 33 52 65 73 6f 6c 76 65 45 78 70 72 4c 69 73 74  3ResolveExprList
b090: 4e 61 6d 65 73 28 26 73 4e 43 2c 20 70 2d 3e 70  Names(&sNC, p->p
b0a0: 45 4c 69 73 74 29 20 29 20 72 65 74 75 72 6e 20  EList) ) return 
b0b0: 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20 0a 20 20  WRC_Abort;.  .  
b0c0: 20 20 2f 2a 20 49 66 20 74 68 65 72 65 20 61 72    /* If there ar
b0d0: 65 20 6e 6f 20 61 67 67 72 65 67 61 74 65 20 66  e no aggregate f
b0e0: 75 6e 63 74 69 6f 6e 73 20 69 6e 20 74 68 65 20  unctions in the 
b0f0: 72 65 73 75 6c 74 2d 73 65 74 2c 20 61 6e 64 20  result-set, and 
b100: 6e 6f 20 47 52 4f 55 50 20 42 59 20 0a 20 20 20  no GROUP BY .   
b110: 20 2a 2a 20 65 78 70 72 65 73 73 69 6f 6e 2c 20   ** expression, 
b120: 64 6f 20 6e 6f 74 20 61 6c 6c 6f 77 20 61 67 67  do not allow agg
b130: 72 65 67 61 74 65 73 20 69 6e 20 61 6e 79 20 6f  regates in any o
b140: 66 20 74 68 65 20 6f 74 68 65 72 20 65 78 70 72  f the other expr
b150: 65 73 73 69 6f 6e 73 2e 0a 20 20 20 20 2a 2f 0a  essions..    */.
b160: 20 20 20 20 61 73 73 65 72 74 28 20 28 70 2d 3e      assert( (p->
b170: 73 65 6c 46 6c 61 67 73 20 26 20 53 46 5f 41 67  selFlags & SF_Ag
b180: 67 72 65 67 61 74 65 29 3d 3d 30 20 29 3b 0a 20  gregate)==0 );. 
b190: 20 20 20 70 47 72 6f 75 70 42 79 20 3d 20 70 2d     pGroupBy = p-
b1a0: 3e 70 47 72 6f 75 70 42 79 3b 0a 20 20 20 20 69  >pGroupBy;.    i
b1b0: 66 28 20 70 47 72 6f 75 70 42 79 20 7c 7c 20 28  f( pGroupBy || (
b1c0: 73 4e 43 2e 6e 63 46 6c 61 67 73 20 26 20 4e 43  sNC.ncFlags & NC
b1d0: 5f 48 61 73 41 67 67 29 21 3d 30 20 29 7b 0a 20  _HasAgg)!=0 ){. 
b1e0: 20 20 20 20 20 61 73 73 65 72 74 28 20 4e 43 5f       assert( NC_
b1f0: 4d 69 6e 4d 61 78 41 67 67 3d 3d 53 46 5f 4d 69  MinMaxAgg==SF_Mi
b200: 6e 4d 61 78 41 67 67 20 29 3b 0a 20 20 20 20 20  nMaxAgg );.     
b210: 20 70 2d 3e 73 65 6c 46 6c 61 67 73 20 7c 3d 20   p->selFlags |= 
b220: 53 46 5f 41 67 67 72 65 67 61 74 65 20 7c 20 28  SF_Aggregate | (
b230: 73 4e 43 2e 6e 63 46 6c 61 67 73 26 4e 43 5f 4d  sNC.ncFlags&NC_M
b240: 69 6e 4d 61 78 41 67 67 29 3b 0a 20 20 20 20 7d  inMaxAgg);.    }
b250: 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 4e 43 2e  else{.      sNC.
b260: 6e 63 46 6c 61 67 73 20 26 3d 20 7e 4e 43 5f 41  ncFlags &= ~NC_A
b270: 6c 6c 6f 77 41 67 67 3b 0a 20 20 20 20 7d 0a 20  llowAgg;.    }. 
b280: 20 0a 20 20 20 20 2f 2a 20 49 66 20 61 20 48 41   .    /* If a HA
b290: 56 49 4e 47 20 63 6c 61 75 73 65 20 69 73 20 70  VING clause is p
b2a0: 72 65 73 65 6e 74 2c 20 74 68 65 6e 20 74 68 65  resent, then the
b2b0: 72 65 20 6d 75 73 74 20 62 65 20 61 20 47 52 4f  re must be a GRO
b2c0: 55 50 20 42 59 20 63 6c 61 75 73 65 2e 0a 20 20  UP BY clause..  
b2d0: 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 70 2d 3e    */.    if( p->
b2e0: 70 48 61 76 69 6e 67 20 26 26 20 21 70 47 72 6f  pHaving && !pGro
b2f0: 75 70 42 79 20 29 7b 0a 20 20 20 20 20 20 73 71  upBy ){.      sq
b300: 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50  lite3ErrorMsg(pP
b310: 61 72 73 65 2c 20 22 61 20 47 52 4f 55 50 20 42  arse, "a GROUP B
b320: 59 20 63 6c 61 75 73 65 20 69 73 20 72 65 71 75  Y clause is requ
b330: 69 72 65 64 20 62 65 66 6f 72 65 20 48 41 56 49  ired before HAVI
b340: 4e 47 22 29 3b 0a 20 20 20 20 20 20 72 65 74 75  NG");.      retu
b350: 72 6e 20 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20  rn WRC_Abort;.  
b360: 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 41 64    }.  .    /* Ad
b370: 64 20 74 68 65 20 6f 75 74 70 75 74 20 63 6f 6c  d the output col
b380: 75 6d 6e 20 6c 69 73 74 20 74 6f 20 74 68 65 20  umn list to the 
b390: 6e 61 6d 65 2d 63 6f 6e 74 65 78 74 20 62 65 66  name-context bef
b3a0: 6f 72 65 20 70 61 72 73 69 6e 67 20 74 68 65 0a  ore parsing the.
b3b0: 20 20 20 20 2a 2a 20 6f 74 68 65 72 20 65 78 70      ** other exp
b3c0: 72 65 73 73 69 6f 6e 73 20 69 6e 20 74 68 65 20  ressions in the 
b3d0: 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74  SELECT statement
b3e0: 2e 20 54 68 69 73 20 69 73 20 73 6f 20 74 68 61  . This is so tha
b3f0: 74 0a 20 20 20 20 2a 2a 20 65 78 70 72 65 73 73  t.    ** express
b400: 69 6f 6e 73 20 69 6e 20 74 68 65 20 57 48 45 52  ions in the WHER
b410: 45 20 63 6c 61 75 73 65 20 28 65 74 63 2e 29 20  E clause (etc.) 
b420: 63 61 6e 20 72 65 66 65 72 20 74 6f 20 65 78 70  can refer to exp
b430: 72 65 73 73 69 6f 6e 73 20 62 79 0a 20 20 20 20  ressions by.    
b440: 2a 2a 20 61 6c 69 61 73 65 73 20 69 6e 20 74 68  ** aliases in th
b450: 65 20 72 65 73 75 6c 74 20 73 65 74 2e 0a 20 20  e result set..  
b460: 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 4d 69 6e 6f    **.    ** Mino
b470: 72 20 70 6f 69 6e 74 3a 20 49 66 20 74 68 69 73  r point: If this
b480: 20 69 73 20 74 68 65 20 63 61 73 65 2c 20 74 68   is the case, th
b490: 65 6e 20 74 68 65 20 65 78 70 72 65 73 73 69 6f  en the expressio
b4a0: 6e 20 77 69 6c 6c 20 62 65 0a 20 20 20 20 2a 2a  n will be.    **
b4b0: 20 72 65 2d 65 76 61 6c 75 61 74 65 64 20 66 6f   re-evaluated fo
b4c0: 72 20 65 61 63 68 20 72 65 66 65 72 65 6e 63 65  r each reference
b4d0: 20 74 6f 20 69 74 2e 0a 20 20 20 20 2a 2f 0a 20   to it..    */. 
b4e0: 20 20 20 73 4e 43 2e 70 45 4c 69 73 74 20 3d 20     sNC.pEList = 
b4f0: 70 2d 3e 70 45 4c 69 73 74 3b 0a 20 20 20 20 69  p->pEList;.    i
b500: 66 28 20 73 71 6c 69 74 65 33 52 65 73 6f 6c 76  f( sqlite3Resolv
b510: 65 45 78 70 72 4e 61 6d 65 73 28 26 73 4e 43 2c  eExprNames(&sNC,
b520: 20 70 2d 3e 70 48 61 76 69 6e 67 29 20 29 20 72   p->pHaving) ) r
b530: 65 74 75 72 6e 20 57 52 43 5f 41 62 6f 72 74 3b  eturn WRC_Abort;
b540: 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33  .    if( sqlite3
b550: 52 65 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65 73  ResolveExprNames
b560: 28 26 73 4e 43 2c 20 70 2d 3e 70 57 68 65 72 65  (&sNC, p->pWhere
b570: 29 20 29 20 72 65 74 75 72 6e 20 57 52 43 5f 41  ) ) return WRC_A
b580: 62 6f 72 74 3b 0a 0a 20 20 20 20 2f 2a 20 52 65  bort;..    /* Re
b590: 73 6f 6c 76 65 20 6e 61 6d 65 73 20 69 6e 20 74  solve names in t
b5a0: 61 62 6c 65 2d 76 61 6c 75 65 64 2d 66 75 6e 63  able-valued-func
b5b0: 74 69 6f 6e 20 61 72 67 75 6d 65 6e 74 73 20 2a  tion arguments *
b5c0: 2f 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69  /.    for(i=0; i
b5d0: 3c 70 2d 3e 70 53 72 63 2d 3e 6e 53 72 63 3b 20  <p->pSrc->nSrc; 
b5e0: 69 2b 2b 29 7b 0a 20 20 20 20 20 20 73 74 72 75  i++){.      stru
b5f0: 63 74 20 53 72 63 4c 69 73 74 5f 69 74 65 6d 20  ct SrcList_item 
b600: 2a 70 49 74 65 6d 20 3d 20 26 70 2d 3e 70 53 72  *pItem = &p->pSr
b610: 63 2d 3e 61 5b 69 5d 3b 0a 20 20 20 20 20 20 69  c->a[i];.      i
b620: 66 28 20 70 49 74 65 6d 2d 3e 66 67 2e 69 73 54  f( pItem->fg.isT
b630: 61 62 46 75 6e 63 0a 20 20 20 20 20 20 20 26 26  abFunc.       &&
b640: 20 73 71 6c 69 74 65 33 52 65 73 6f 6c 76 65 45   sqlite3ResolveE
b650: 78 70 72 4c 69 73 74 4e 61 6d 65 73 28 26 73 4e  xprListNames(&sN
b660: 43 2c 20 70 49 74 65 6d 2d 3e 75 31 2e 70 46 75  C, pItem->u1.pFu
b670: 6e 63 41 72 67 29 20 0a 20 20 20 20 20 20 29 7b  ncArg) .      ){
b680: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
b690: 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20 20 20 20  WRC_Abort;.     
b6a0: 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a   }.    }..    /*
b6b0: 20 54 68 65 20 4f 52 44 45 52 20 42 59 20 61 6e   The ORDER BY an
b6c0: 64 20 47 52 4f 55 50 20 42 59 20 63 6c 61 75 73  d GROUP BY claus
b6d0: 65 73 20 6d 61 79 20 6e 6f 74 20 72 65 66 65 72  es may not refer
b6e0: 20 74 6f 20 74 65 72 6d 73 20 69 6e 0a 20 20 20   to terms in.   
b6f0: 20 2a 2a 20 6f 75 74 65 72 20 71 75 65 72 69 65   ** outer querie
b700: 73 20 0a 20 20 20 20 2a 2f 0a 20 20 20 20 73 4e  s .    */.    sN
b710: 43 2e 70 4e 65 78 74 20 3d 20 30 3b 0a 20 20 20  C.pNext = 0;.   
b720: 20 73 4e 43 2e 6e 63 46 6c 61 67 73 20 7c 3d 20   sNC.ncFlags |= 
b730: 4e 43 5f 41 6c 6c 6f 77 41 67 67 3b 0a 0a 20 20  NC_AllowAgg;..  
b740: 20 20 2f 2a 20 49 66 20 74 68 69 73 20 69 73 20    /* If this is 
b750: 61 20 63 6f 6e 76 65 72 74 65 64 20 63 6f 6d 70  a converted comp
b760: 6f 75 6e 64 20 71 75 65 72 79 2c 20 6d 6f 76 65  ound query, move
b770: 20 74 68 65 20 4f 52 44 45 52 20 42 59 20 63 6c   the ORDER BY cl
b780: 61 75 73 65 20 66 72 6f 6d 20 0a 20 20 20 20 2a  ause from .    *
b790: 2a 20 74 68 65 20 73 75 62 2d 71 75 65 72 79 20  * the sub-query 
b7a0: 62 61 63 6b 20 74 6f 20 74 68 65 20 70 61 72 65  back to the pare
b7b0: 6e 74 20 71 75 65 72 79 2e 20 41 74 20 74 68 69  nt query. At thi
b7c0: 73 20 70 6f 69 6e 74 20 65 61 63 68 20 74 65 72  s point each ter
b7d0: 6d 0a 20 20 20 20 2a 2a 20 77 69 74 68 69 6e 20  m.    ** within 
b7e0: 74 68 65 20 4f 52 44 45 52 20 42 59 20 63 6c 61  the ORDER BY cla
b7f0: 75 73 65 20 68 61 73 20 62 65 65 6e 20 74 72 61  use has been tra
b800: 6e 73 66 6f 72 6d 65 64 20 74 6f 20 61 6e 20 69  nsformed to an i
b810: 6e 74 65 67 65 72 20 76 61 6c 75 65 2e 0a 20 20  nteger value..  
b820: 20 20 2a 2a 20 54 68 65 73 65 20 69 6e 74 65 67    ** These integ
b830: 65 72 73 20 77 69 6c 6c 20 62 65 20 72 65 70 6c  ers will be repl
b840: 61 63 65 64 20 62 79 20 63 6f 70 69 65 73 20 6f  aced by copies o
b850: 66 20 74 68 65 20 63 6f 72 72 65 73 70 6f 6e 64  f the correspond
b860: 69 6e 67 20 72 65 73 75 6c 74 0a 20 20 20 20 2a  ing result.    *
b870: 2a 20 73 65 74 20 65 78 70 72 65 73 73 69 6f 6e  * set expression
b880: 73 20 62 79 20 74 68 65 20 63 61 6c 6c 20 74 6f  s by the call to
b890: 20 72 65 73 6f 6c 76 65 4f 72 64 65 72 47 72 6f   resolveOrderGro
b8a0: 75 70 42 79 28 29 20 62 65 6c 6f 77 2e 20 20 2a  upBy() below.  *
b8b0: 2f 0a 20 20 20 20 69 66 28 20 70 2d 3e 73 65 6c  /.    if( p->sel
b8c0: 46 6c 61 67 73 20 26 20 53 46 5f 43 6f 6e 76 65  Flags & SF_Conve
b8d0: 72 74 65 64 20 29 7b 0a 20 20 20 20 20 20 53 65  rted ){.      Se
b8e0: 6c 65 63 74 20 2a 70 53 75 62 20 3d 20 70 2d 3e  lect *pSub = p->
b8f0: 70 53 72 63 2d 3e 61 5b 30 5d 2e 70 53 65 6c 65  pSrc->a[0].pSele
b900: 63 74 3b 0a 20 20 20 20 20 20 70 2d 3e 70 4f 72  ct;.      p->pOr
b910: 64 65 72 42 79 20 3d 20 70 53 75 62 2d 3e 70 4f  derBy = pSub->pO
b920: 72 64 65 72 42 79 3b 0a 20 20 20 20 20 20 70 53  rderBy;.      pS
b930: 75 62 2d 3e 70 4f 72 64 65 72 42 79 20 3d 20 30  ub->pOrderBy = 0
b940: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  ;.    }..    /* 
b950: 50 72 6f 63 65 73 73 20 74 68 65 20 4f 52 44 45  Process the ORDE
b960: 52 20 42 59 20 63 6c 61 75 73 65 20 66 6f 72 20  R BY clause for 
b970: 73 69 6e 67 6c 65 74 6f 6e 20 53 45 4c 45 43 54  singleton SELECT
b980: 20 73 74 61 74 65 6d 65 6e 74 73 2e 0a 20 20 20   statements..   
b990: 20 2a 2a 20 54 68 65 20 4f 52 44 45 52 20 42 59   ** The ORDER BY
b9a0: 20 63 6c 61 75 73 65 20 66 6f 72 20 63 6f 6d 70   clause for comp
b9b0: 6f 75 6e 64 73 20 53 45 4c 45 43 54 20 73 74 61  ounds SELECT sta
b9c0: 74 65 6d 65 6e 74 73 20 69 73 20 68 61 6e 64 6c  tements is handl
b9d0: 65 64 0a 20 20 20 20 2a 2a 20 62 65 6c 6f 77 2c  ed.    ** below,
b9e0: 20 61 66 74 65 72 20 61 6c 6c 20 6f 66 20 74 68   after all of th
b9f0: 65 20 72 65 73 75 6c 74 2d 73 65 74 73 20 66 6f  e result-sets fo
ba00: 72 20 61 6c 6c 20 6f 66 20 74 68 65 20 65 6c 65  r all of the ele
ba10: 6d 65 6e 74 73 20 6f 66 0a 20 20 20 20 2a 2a 20  ments of.    ** 
ba20: 74 68 65 20 63 6f 6d 70 6f 75 6e 64 20 68 61 76  the compound hav
ba30: 65 20 62 65 65 6e 20 72 65 73 6f 6c 76 65 64 2e  e been resolved.
ba40: 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 49  .    **.    ** I
ba50: 66 20 74 68 65 72 65 20 69 73 20 61 6e 20 4f 52  f there is an OR
ba60: 44 45 52 20 42 59 20 63 6c 61 75 73 65 20 6f 6e  DER BY clause on
ba70: 20 61 20 74 65 72 6d 20 6f 66 20 61 20 63 6f 6d   a term of a com
ba80: 70 6f 75 6e 64 2d 73 65 6c 65 63 74 20 6f 74 68  pound-select oth
ba90: 65 72 0a 20 20 20 20 2a 2a 20 74 68 61 6e 20 74  er.    ** than t
baa0: 68 65 20 72 69 67 68 74 2d 6d 6f 73 74 20 74 65  he right-most te
bab0: 72 6d 2c 20 74 68 65 6e 20 74 68 61 74 20 69 73  rm, then that is
bac0: 20 61 20 73 79 6e 74 61 78 20 65 72 72 6f 72 2e   a syntax error.
bad0: 20 20 42 75 74 20 74 68 65 20 65 72 72 6f 72 0a    But the error.
bae0: 20 20 20 20 2a 2a 20 69 73 20 6e 6f 74 20 64 65      ** is not de
baf0: 74 65 63 74 65 64 20 75 6e 74 69 6c 20 6d 75 63  tected until muc
bb00: 68 20 6c 61 74 65 72 2c 20 61 6e 64 20 73 6f 20  h later, and so 
bb10: 77 65 20 6e 65 65 64 20 74 6f 20 67 6f 20 61 68  we need to go ah
bb20: 65 61 64 20 61 6e 64 0a 20 20 20 20 2a 2a 20 72  ead and.    ** r
bb30: 65 73 6f 6c 76 65 20 74 68 6f 73 65 20 73 79 6d  esolve those sym
bb40: 62 6f 6c 73 20 6f 6e 20 74 68 65 20 69 6e 63 6f  bols on the inco
bb50: 72 72 65 63 74 20 4f 52 44 45 52 20 42 59 20 66  rrect ORDER BY f
bb60: 6f 72 20 63 6f 6e 73 69 73 74 65 6e 63 79 2e 0a  or consistency..
bb70: 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 69      */.    if( i
bb80: 73 43 6f 6d 70 6f 75 6e 64 3c 3d 6e 43 6f 6d 70  sCompound<=nComp
bb90: 6f 75 6e 64 20 20 2f 2a 20 44 65 66 65 72 20 72  ound  /* Defer r
bba0: 69 67 68 74 2d 6d 6f 73 74 20 4f 52 44 45 52 20  ight-most ORDER 
bbb0: 42 59 20 6f 66 20 61 20 63 6f 6d 70 6f 75 6e 64  BY of a compound
bbc0: 20 2a 2f 0a 20 20 20 20 20 26 26 20 72 65 73 6f   */.     && reso
bbd0: 6c 76 65 4f 72 64 65 72 47 72 6f 75 70 42 79 28  lveOrderGroupBy(
bbe0: 26 73 4e 43 2c 20 70 2c 20 70 2d 3e 70 4f 72 64  &sNC, p, p->pOrd
bbf0: 65 72 42 79 2c 20 22 4f 52 44 45 52 22 29 0a 20  erBy, "ORDER"). 
bc00: 20 20 20 29 7b 0a 20 20 20 20 20 20 72 65 74 75     ){.      retu
bc10: 72 6e 20 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20  rn WRC_Abort;.  
bc20: 20 20 7d 0a 20 20 20 20 69 66 28 20 64 62 2d 3e    }.    if( db->
bc30: 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 29 7b 0a  mallocFailed ){.
bc40: 20 20 20 20 20 20 72 65 74 75 72 6e 20 57 52 43        return WRC
bc50: 5f 41 62 6f 72 74 3b 0a 20 20 20 20 7d 0a 20 20  _Abort;.    }.  
bc60: 0a 20 20 20 20 2f 2a 20 52 65 73 6f 6c 76 65 20  .    /* Resolve 
bc70: 74 68 65 20 47 52 4f 55 50 20 42 59 20 63 6c 61  the GROUP BY cla
bc80: 75 73 65 2e 20 20 41 74 20 74 68 65 20 73 61 6d  use.  At the sam
bc90: 65 20 74 69 6d 65 2c 20 6d 61 6b 65 20 73 75 72  e time, make sur
bca0: 65 20 0a 20 20 20 20 2a 2a 20 74 68 65 20 47 52  e .    ** the GR
bcb0: 4f 55 50 20 42 59 20 63 6c 61 75 73 65 20 64 6f  OUP BY clause do
bcc0: 65 73 20 6e 6f 74 20 63 6f 6e 74 61 69 6e 20 61  es not contain a
bcd0: 67 67 72 65 67 61 74 65 20 66 75 6e 63 74 69 6f  ggregate functio
bce0: 6e 73 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69  ns..    */.    i
bcf0: 66 28 20 70 47 72 6f 75 70 42 79 20 29 7b 0a 20  f( pGroupBy ){. 
bd00: 20 20 20 20 20 73 74 72 75 63 74 20 45 78 70 72       struct Expr
bd10: 4c 69 73 74 5f 69 74 65 6d 20 2a 70 49 74 65 6d  List_item *pItem
bd20: 3b 0a 20 20 20 20 0a 20 20 20 20 20 20 69 66 28  ;.    .      if(
bd30: 20 72 65 73 6f 6c 76 65 4f 72 64 65 72 47 72 6f   resolveOrderGro
bd40: 75 70 42 79 28 26 73 4e 43 2c 20 70 2c 20 70 47  upBy(&sNC, p, pG
bd50: 72 6f 75 70 42 79 2c 20 22 47 52 4f 55 50 22 29  roupBy, "GROUP")
bd60: 20 7c 7c 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61   || db->mallocFa
bd70: 69 6c 65 64 20 29 7b 0a 20 20 20 20 20 20 20 20  iled ){.        
bd80: 72 65 74 75 72 6e 20 57 52 43 5f 41 62 6f 72 74  return WRC_Abort
bd90: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
bda0: 66 6f 72 28 69 3d 30 2c 20 70 49 74 65 6d 3d 70  for(i=0, pItem=p
bdb0: 47 72 6f 75 70 42 79 2d 3e 61 3b 20 69 3c 70 47  GroupBy->a; i<pG
bdc0: 72 6f 75 70 42 79 2d 3e 6e 45 78 70 72 3b 20 69  roupBy->nExpr; i
bdd0: 2b 2b 2c 20 70 49 74 65 6d 2b 2b 29 7b 0a 20 20  ++, pItem++){.  
bde0: 20 20 20 20 20 20 69 66 28 20 45 78 70 72 48 61        if( ExprHa
bdf0: 73 50 72 6f 70 65 72 74 79 28 70 49 74 65 6d 2d  sProperty(pItem-
be00: 3e 70 45 78 70 72 2c 20 45 50 5f 41 67 67 29 20  >pExpr, EP_Agg) 
be10: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  ){.          sql
be20: 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61  ite3ErrorMsg(pPa
be30: 72 73 65 2c 20 22 61 67 67 72 65 67 61 74 65 20  rse, "aggregate 
be40: 66 75 6e 63 74 69 6f 6e 73 20 61 72 65 20 6e 6f  functions are no
be50: 74 20 61 6c 6c 6f 77 65 64 20 69 6e 20 22 0a 20  t allowed in ". 
be60: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 74 68               "th
be70: 65 20 47 52 4f 55 50 20 42 59 20 63 6c 61 75 73  e GROUP BY claus
be80: 65 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 72  e");.          r
be90: 65 74 75 72 6e 20 57 52 43 5f 41 62 6f 72 74 3b  eturn WRC_Abort;
bea0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
beb0: 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a   }.    }..    /*
bec0: 20 49 66 20 74 68 69 73 20 69 73 20 70 61 72 74   If this is part
bed0: 20 6f 66 20 61 20 63 6f 6d 70 6f 75 6e 64 20 53   of a compound S
bee0: 45 4c 45 43 54 2c 20 63 68 65 63 6b 20 74 68 61  ELECT, check tha
bef0: 74 20 69 74 20 68 61 73 20 74 68 65 20 72 69 67  t it has the rig
bf00: 68 74 0a 20 20 20 20 2a 2a 20 6e 75 6d 62 65 72  ht.    ** number
bf10: 20 6f 66 20 65 78 70 72 65 73 73 69 6f 6e 73 20   of expressions 
bf20: 69 6e 20 74 68 65 20 73 65 6c 65 63 74 20 6c 69  in the select li
bf30: 73 74 2e 20 2a 2f 0a 20 20 20 20 69 66 28 20 70  st. */.    if( p
bf40: 2d 3e 70 4e 65 78 74 20 26 26 20 70 2d 3e 70 45  ->pNext && p->pE
bf50: 4c 69 73 74 2d 3e 6e 45 78 70 72 21 3d 70 2d 3e  List->nExpr!=p->
bf60: 70 4e 65 78 74 2d 3e 70 45 4c 69 73 74 2d 3e 6e  pNext->pEList->n
bf70: 45 78 70 72 20 29 7b 0a 20 20 20 20 20 20 73 71  Expr ){.      sq
bf80: 6c 69 74 65 33 53 65 6c 65 63 74 57 72 6f 6e 67  lite3SelectWrong
bf90: 4e 75 6d 54 65 72 6d 73 45 72 72 6f 72 28 70 50  NumTermsError(pP
bfa0: 61 72 73 65 2c 20 70 2d 3e 70 4e 65 78 74 29 3b  arse, p->pNext);
bfb0: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 57 52  .      return WR
bfc0: 43 5f 41 62 6f 72 74 3b 0a 20 20 20 20 7d 0a 0a  C_Abort;.    }..
bfd0: 20 20 20 20 2f 2a 20 41 64 76 61 6e 63 65 20 74      /* Advance t
bfe0: 6f 20 74 68 65 20 6e 65 78 74 20 74 65 72 6d 20  o the next term 
bff0: 6f 66 20 74 68 65 20 63 6f 6d 70 6f 75 6e 64 0a  of the compound.
c000: 20 20 20 20 2a 2f 0a 20 20 20 20 70 20 3d 20 70      */.    p = p
c010: 2d 3e 70 50 72 69 6f 72 3b 0a 20 20 20 20 6e 43  ->pPrior;.    nC
c020: 6f 6d 70 6f 75 6e 64 2b 2b 3b 0a 20 20 7d 0a 0a  ompound++;.  }..
c030: 20 20 2f 2a 20 52 65 73 6f 6c 76 65 20 74 68 65    /* Resolve the
c040: 20 4f 52 44 45 52 20 42 59 20 6f 6e 20 61 20 63   ORDER BY on a c
c050: 6f 6d 70 6f 75 6e 64 20 53 45 4c 45 43 54 20 61  ompound SELECT a
c060: 66 74 65 72 20 61 6c 6c 20 74 65 72 6d 73 20 6f  fter all terms o
c070: 66 0a 20 20 2a 2a 20 74 68 65 20 63 6f 6d 70 6f  f.  ** the compo
c080: 75 6e 64 20 68 61 76 65 20 62 65 65 6e 20 72 65  und have been re
c090: 73 6f 6c 76 65 64 2e 0a 20 20 2a 2f 0a 20 20 69  solved..  */.  i
c0a0: 66 28 20 69 73 43 6f 6d 70 6f 75 6e 64 20 26 26  f( isCompound &&
c0b0: 20 72 65 73 6f 6c 76 65 43 6f 6d 70 6f 75 6e 64   resolveCompound
c0c0: 4f 72 64 65 72 42 79 28 70 50 61 72 73 65 2c 20  OrderBy(pParse, 
c0d0: 70 4c 65 66 74 6d 6f 73 74 29 20 29 7b 0a 20 20  pLeftmost) ){.  
c0e0: 20 20 72 65 74 75 72 6e 20 57 52 43 5f 41 62 6f    return WRC_Abo
c0f0: 72 74 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72  rt;.  }..  retur
c100: 6e 20 57 52 43 5f 50 72 75 6e 65 3b 0a 7d 0a 0a  n WRC_Prune;.}..
c110: 2f 2a 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69  /*.** This routi
c120: 6e 65 20 77 61 6c 6b 73 20 61 6e 20 65 78 70 72  ne walks an expr
c130: 65 73 73 69 6f 6e 20 74 72 65 65 20 61 6e 64 20  ession tree and 
c140: 72 65 73 6f 6c 76 65 73 20 72 65 66 65 72 65 6e  resolves referen
c150: 63 65 73 20 74 6f 0a 2a 2a 20 74 61 62 6c 65 20  ces to.** table 
c160: 63 6f 6c 75 6d 6e 73 20 61 6e 64 20 72 65 73 75  columns and resu
c170: 6c 74 2d 73 65 74 20 63 6f 6c 75 6d 6e 73 2e 20  lt-set columns. 
c180: 20 41 74 20 74 68 65 20 73 61 6d 65 20 74 69 6d   At the same tim
c190: 65 2c 20 64 6f 20 65 72 72 6f 72 0a 2a 2a 20 63  e, do error.** c
c1a0: 68 65 63 6b 69 6e 67 20 6f 6e 20 66 75 6e 63 74  hecking on funct
c1b0: 69 6f 6e 20 75 73 61 67 65 20 61 6e 64 20 73 65  ion usage and se
c1c0: 74 20 61 20 66 6c 61 67 20 69 66 20 61 6e 79 20  t a flag if any 
c1d0: 61 67 67 72 65 67 61 74 65 20 66 75 6e 63 74 69  aggregate functi
c1e0: 6f 6e 73 0a 2a 2a 20 61 72 65 20 73 65 65 6e 2e  ons.** are seen.
c1f0: 0a 2a 2a 0a 2a 2a 20 54 6f 20 72 65 73 6f 6c 76  .**.** To resolv
c200: 65 20 74 61 62 6c 65 20 63 6f 6c 75 6d 6e 73 20  e table columns 
c210: 72 65 66 65 72 65 6e 63 65 73 20 77 65 20 6c 6f  references we lo
c220: 6f 6b 20 66 6f 72 20 6e 6f 64 65 73 20 28 6f 72  ok for nodes (or
c230: 20 73 75 62 74 72 65 65 73 29 20 6f 66 20 74 68   subtrees) of th
c240: 65 20 0a 2a 2a 20 66 6f 72 6d 20 58 2e 59 2e 5a  e .** form X.Y.Z
c250: 20 6f 72 20 59 2e 5a 20 6f 72 20 6a 75 73 74 20   or Y.Z or just 
c260: 5a 20 77 68 65 72 65 0a 2a 2a 0a 2a 2a 20 20 20  Z where.**.**   
c270: 20 20 20 58 3a 20 20 20 54 68 65 20 6e 61 6d 65     X:   The name
c280: 20 6f 66 20 61 20 64 61 74 61 62 61 73 65 2e 20   of a database. 
c290: 20 45 78 3a 20 20 22 6d 61 69 6e 22 20 6f 72 20   Ex:  "main" or 
c2a0: 22 74 65 6d 70 22 20 6f 72 0a 2a 2a 20 20 20 20  "temp" or.**    
c2b0: 20 20 20 20 20 20 20 74 68 65 20 73 79 6d 62 6f         the symbo
c2c0: 6c 69 63 20 6e 61 6d 65 20 61 73 73 69 67 6e 65  lic name assigne
c2d0: 64 20 74 6f 20 61 6e 20 41 54 54 41 43 48 2d 65  d to an ATTACH-e
c2e0: 64 20 64 61 74 61 62 61 73 65 2e 0a 2a 2a 0a 2a  d database..**.*
c2f0: 2a 20 20 20 20 20 20 59 3a 20 20 20 54 68 65 20  *      Y:   The 
c300: 6e 61 6d 65 20 6f 66 20 61 20 74 61 62 6c 65 20  name of a table 
c310: 69 6e 20 61 20 46 52 4f 4d 20 63 6c 61 75 73 65  in a FROM clause
c320: 2e 20 20 4f 72 20 69 6e 20 61 20 74 72 69 67 67  .  Or in a trigg
c330: 65 72 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20  er.**           
c340: 6f 6e 65 20 6f 66 20 74 68 65 20 73 70 65 63 69  one of the speci
c350: 61 6c 20 6e 61 6d 65 73 20 22 6f 6c 64 22 20 6f  al names "old" o
c360: 72 20 22 6e 65 77 22 2e 0a 2a 2a 0a 2a 2a 20 20  r "new"..**.**  
c370: 20 20 20 20 5a 3a 20 20 20 54 68 65 20 6e 61 6d      Z:   The nam
c380: 65 20 6f 66 20 61 20 63 6f 6c 75 6d 6e 20 69 6e  e of a column in
c390: 20 74 61 62 6c 65 20 59 2e 0a 2a 2a 0a 2a 2a 20   table Y..**.** 
c3a0: 54 68 65 20 6e 6f 64 65 20 61 74 20 74 68 65 20  The node at the 
c3b0: 72 6f 6f 74 20 6f 66 20 74 68 65 20 73 75 62 74  root of the subt
c3c0: 72 65 65 20 69 73 20 6d 6f 64 69 66 69 65 64 20  ree is modified 
c3d0: 61 73 20 66 6f 6c 6c 6f 77 73 3a 0a 2a 2a 0a 2a  as follows:.**.*
c3e0: 2a 20 20 20 20 45 78 70 72 2e 6f 70 20 20 20 20  *    Expr.op    
c3f0: 20 20 20 20 43 68 61 6e 67 65 64 20 74 6f 20 54      Changed to T
c400: 4b 5f 43 4f 4c 55 4d 4e 0a 2a 2a 20 20 20 20 45  K_COLUMN.**    E
c410: 78 70 72 2e 70 54 61 62 20 20 20 20 20 20 50 6f  xpr.pTab      Po
c420: 69 6e 74 73 20 74 6f 20 74 68 65 20 54 61 62 6c  ints to the Tabl
c430: 65 20 6f 62 6a 65 63 74 20 66 6f 72 20 58 2e 59  e object for X.Y
c440: 0a 2a 2a 20 20 20 20 45 78 70 72 2e 69 43 6f 6c  .**    Expr.iCol
c450: 75 6d 6e 20 20 20 54 68 65 20 63 6f 6c 75 6d 6e  umn   The column
c460: 20 69 6e 64 65 78 20 69 6e 20 58 2e 59 2e 20 20   index in X.Y.  
c470: 2d 31 20 66 6f 72 20 74 68 65 20 72 6f 77 69 64  -1 for the rowid
c480: 2e 0a 2a 2a 20 20 20 20 45 78 70 72 2e 69 54 61  ..**    Expr.iTa
c490: 62 6c 65 20 20 20 20 54 68 65 20 56 44 42 45 20  ble    The VDBE 
c4a0: 63 75 72 73 6f 72 20 6e 75 6d 62 65 72 20 66 6f  cursor number fo
c4b0: 72 20 58 2e 59 0a 2a 2a 0a 2a 2a 0a 2a 2a 20 54  r X.Y.**.**.** T
c4c0: 6f 20 72 65 73 6f 6c 76 65 20 72 65 73 75 6c 74  o resolve result
c4d0: 2d 73 65 74 20 72 65 66 65 72 65 6e 63 65 73 2c  -set references,
c4e0: 20 6c 6f 6f 6b 20 66 6f 72 20 65 78 70 72 65 73   look for expres
c4f0: 73 69 6f 6e 20 6e 6f 64 65 73 20 6f 66 20 74 68  sion nodes of th
c500: 65 0a 2a 2a 20 66 6f 72 6d 20 5a 20 28 77 69 74  e.** form Z (wit
c510: 68 20 6e 6f 20 58 20 61 6e 64 20 59 20 70 72 65  h no X and Y pre
c520: 66 69 78 29 20 77 68 65 72 65 20 74 68 65 20 5a  fix) where the Z
c530: 20 6d 61 74 63 68 65 73 20 74 68 65 20 72 69 67   matches the rig
c540: 68 74 2d 68 61 6e 64 0a 2a 2a 20 73 69 7a 65 20  ht-hand.** size 
c550: 6f 66 20 61 6e 20 41 53 20 63 6c 61 75 73 65 20  of an AS clause 
c560: 69 6e 20 74 68 65 20 72 65 73 75 6c 74 2d 73 65  in the result-se
c570: 74 20 6f 66 20 61 20 53 45 4c 45 43 54 2e 20 20  t of a SELECT.  
c580: 54 68 65 20 5a 20 65 78 70 72 65 73 73 69 6f 6e  The Z expression
c590: 0a 2a 2a 20 69 73 20 72 65 70 6c 61 63 65 64 20  .** is replaced 
c5a0: 62 79 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65  by a copy of the
c5b0: 20 6c 65 66 74 2d 68 61 6e 64 20 73 69 64 65 20   left-hand side 
c5c0: 6f 66 20 74 68 65 20 72 65 73 75 6c 74 2d 73 65  of the result-se
c5d0: 74 20 65 78 70 72 65 73 73 69 6f 6e 2e 0a 2a 2a  t expression..**
c5e0: 20 54 61 62 6c 65 2d 6e 61 6d 65 20 61 6e 64 20   Table-name and 
c5f0: 66 75 6e 63 74 69 6f 6e 20 72 65 73 6f 6c 75 74  function resolut
c600: 69 6f 6e 20 6f 63 63 75 72 73 20 6f 6e 20 74 68  ion occurs on th
c610: 65 20 73 75 62 73 74 69 74 75 74 65 64 20 65 78  e substituted ex
c620: 70 72 65 73 73 69 6f 6e 0a 2a 2a 20 74 72 65 65  pression.** tree
c630: 2e 20 20 46 6f 72 20 65 78 61 6d 70 6c 65 2c 20  .  For example, 
c640: 69 6e 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 20 53  in:.**.**      S
c650: 45 4c 45 43 54 20 61 2b 62 20 41 53 20 78 2c 20  ELECT a+b AS x, 
c660: 63 2b 64 20 41 53 20 79 20 46 52 4f 4d 20 74 31  c+d AS y FROM t1
c670: 20 4f 52 44 45 52 20 42 59 20 78 3b 0a 2a 2a 0a   ORDER BY x;.**.
c680: 2a 2a 20 54 68 65 20 22 78 22 20 74 65 72 6d 20  ** The "x" term 
c690: 6f 66 20 74 68 65 20 6f 72 64 65 72 20 62 79 20  of the order by 
c6a0: 69 73 20 72 65 70 6c 61 63 65 64 20 62 79 20 22  is replaced by "
c6b0: 61 2b 62 22 20 74 6f 20 72 65 6e 64 65 72 3a 0a  a+b" to render:.
c6c0: 2a 2a 0a 2a 2a 20 20 20 20 20 20 53 45 4c 45 43  **.**      SELEC
c6d0: 54 20 61 2b 62 20 41 53 20 78 2c 20 63 2b 64 20  T a+b AS x, c+d 
c6e0: 41 53 20 79 20 46 52 4f 4d 20 74 31 20 4f 52 44  AS y FROM t1 ORD
c6f0: 45 52 20 42 59 20 61 2b 62 3b 0a 2a 2a 0a 2a 2a  ER BY a+b;.**.**
c700: 20 46 75 6e 63 74 69 6f 6e 20 63 61 6c 6c 73 20   Function calls 
c710: 61 72 65 20 63 68 65 63 6b 65 64 20 74 6f 20 6d  are checked to m
c720: 61 6b 65 20 73 75 72 65 20 74 68 61 74 20 74 68  ake sure that th
c730: 65 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 0a 2a  e function is .*
c740: 2a 20 64 65 66 69 6e 65 64 20 61 6e 64 20 74 68  * defined and th
c750: 61 74 20 74 68 65 20 63 6f 72 72 65 63 74 20 6e  at the correct n
c760: 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e  umber of argumen
c770: 74 73 20 61 72 65 20 73 70 65 63 69 66 69 65 64  ts are specified
c780: 2e 0a 2a 2a 20 49 66 20 74 68 65 20 66 75 6e 63  ..** If the func
c790: 74 69 6f 6e 20 69 73 20 61 6e 20 61 67 67 72 65  tion is an aggre
c7a0: 67 61 74 65 20 66 75 6e 63 74 69 6f 6e 2c 20 74  gate function, t
c7b0: 68 65 6e 20 74 68 65 20 4e 43 5f 48 61 73 41 67  hen the NC_HasAg
c7c0: 67 20 66 6c 61 67 20 69 73 0a 2a 2a 20 73 65 74  g flag is.** set
c7d0: 20 61 6e 64 20 74 68 65 20 6f 70 63 6f 64 65 20   and the opcode 
c7e0: 69 73 20 63 68 61 6e 67 65 64 20 66 72 6f 6d 20  is changed from 
c7f0: 54 4b 5f 46 55 4e 43 54 49 4f 4e 20 74 6f 20 54  TK_FUNCTION to T
c800: 4b 5f 41 47 47 5f 46 55 4e 43 54 49 4f 4e 2e 0a  K_AGG_FUNCTION..
c810: 2a 2a 20 49 66 20 61 6e 20 65 78 70 72 65 73 73  ** If an express
c820: 69 6f 6e 20 63 6f 6e 74 61 69 6e 73 20 61 67 67  ion contains agg
c830: 72 65 67 61 74 65 20 66 75 6e 63 74 69 6f 6e 73  regate functions
c840: 20 74 68 65 6e 20 74 68 65 20 45 50 5f 41 67 67   then the EP_Agg
c850: 0a 2a 2a 20 70 72 6f 70 65 72 74 79 20 6f 6e 20  .** property on 
c860: 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69  the expression i
c870: 73 20 73 65 74 2e 0a 2a 2a 0a 2a 2a 20 41 6e 20  s set..**.** An 
c880: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 69 73  error message is
c890: 20 6c 65 66 74 20 69 6e 20 70 50 61 72 73 65 20   left in pParse 
c8a0: 69 66 20 61 6e 79 74 68 69 6e 67 20 69 73 20 61  if anything is a
c8b0: 6d 69 73 73 2e 20 20 54 68 65 20 6e 75 6d 62 65  miss.  The numbe
c8c0: 72 0a 2a 2a 20 69 66 20 65 72 72 6f 72 73 20 69  r.** if errors i
c8d0: 73 20 72 65 74 75 72 6e 65 64 2e 0a 2a 2f 0a 69  s returned..*/.i
c8e0: 6e 74 20 73 71 6c 69 74 65 33 52 65 73 6f 6c 76  nt sqlite3Resolv
c8f0: 65 45 78 70 72 4e 61 6d 65 73 28 20 0a 20 20 4e  eExprNames( .  N
c900: 61 6d 65 43 6f 6e 74 65 78 74 20 2a 70 4e 43 2c  ameContext *pNC,
c910: 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 73 70         /* Namesp
c920: 61 63 65 20 74 6f 20 72 65 73 6f 6c 76 65 20 65  ace to resolve e
c930: 78 70 72 65 73 73 69 6f 6e 73 20 69 6e 2e 20 2a  xpressions in. *
c940: 2f 0a 20 20 45 78 70 72 20 2a 70 45 78 70 72 20  /.  Expr *pExpr 
c950: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
c960: 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20 74 6f  he expression to
c970: 20 62 65 20 61 6e 61 6c 79 7a 65 64 2e 20 2a 2f   be analyzed. */
c980: 0a 29 7b 0a 20 20 75 31 36 20 73 61 76 65 64 48  .){.  u16 savedH
c990: 61 73 41 67 67 3b 0a 20 20 57 61 6c 6b 65 72 20  asAgg;.  Walker 
c9a0: 77 3b 0a 0a 20 20 69 66 28 20 70 45 78 70 72 3d  w;..  if( pExpr=
c9b0: 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49  =0 ) return SQLI
c9c0: 54 45 5f 4f 4b 3b 0a 20 20 73 61 76 65 64 48 61  TE_OK;.  savedHa
c9d0: 73 41 67 67 20 3d 20 70 4e 43 2d 3e 6e 63 46 6c  sAgg = pNC->ncFl
c9e0: 61 67 73 20 26 20 28 4e 43 5f 48 61 73 41 67 67  ags & (NC_HasAgg
c9f0: 7c 4e 43 5f 4d 69 6e 4d 61 78 41 67 67 29 3b 0a  |NC_MinMaxAgg);.
ca00: 20 20 70 4e 43 2d 3e 6e 63 46 6c 61 67 73 20 26    pNC->ncFlags &
ca10: 3d 20 7e 28 4e 43 5f 48 61 73 41 67 67 7c 4e 43  = ~(NC_HasAgg|NC
ca20: 5f 4d 69 6e 4d 61 78 41 67 67 29 3b 0a 20 20 77  _MinMaxAgg);.  w
ca30: 2e 70 50 61 72 73 65 20 3d 20 70 4e 43 2d 3e 70  .pParse = pNC->p
ca40: 50 61 72 73 65 3b 0a 20 20 77 2e 78 45 78 70 72  Parse;.  w.xExpr
ca50: 43 61 6c 6c 62 61 63 6b 20 3d 20 72 65 73 6f 6c  Callback = resol
ca60: 76 65 45 78 70 72 53 74 65 70 3b 0a 20 20 77 2e  veExprStep;.  w.
ca70: 78 53 65 6c 65 63 74 43 61 6c 6c 62 61 63 6b 20  xSelectCallback 
ca80: 3d 20 72 65 73 6f 6c 76 65 53 65 6c 65 63 74 53  = resolveSelectS
ca90: 74 65 70 3b 0a 20 20 77 2e 78 53 65 6c 65 63 74  tep;.  w.xSelect
caa0: 43 61 6c 6c 62 61 63 6b 32 20 3d 20 30 3b 0a 20  Callback2 = 0;. 
cab0: 20 77 2e 75 2e 70 4e 43 20 3d 20 70 4e 43 3b 0a   w.u.pNC = pNC;.
cac0: 23 69 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 45  #if SQLITE_MAX_E
cad0: 58 50 52 5f 44 45 50 54 48 3e 30 0a 20 20 77 2e  XPR_DEPTH>0.  w.
cae0: 70 50 61 72 73 65 2d 3e 6e 48 65 69 67 68 74 20  pParse->nHeight 
caf0: 2b 3d 20 70 45 78 70 72 2d 3e 6e 48 65 69 67 68  += pExpr->nHeigh
cb00: 74 3b 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  t;.  if( sqlite3
cb10: 45 78 70 72 43 68 65 63 6b 48 65 69 67 68 74 28  ExprCheckHeight(
cb20: 77 2e 70 50 61 72 73 65 2c 20 77 2e 70 50 61 72  w.pParse, w.pPar
cb30: 73 65 2d 3e 6e 48 65 69 67 68 74 29 20 29 7b 0a  se->nHeight) ){.
cb40: 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54      return SQLIT
cb50: 45 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 23 65 6e  E_ERROR;.  }.#en
cb60: 64 69 66 0a 20 20 73 71 6c 69 74 65 33 57 61 6c  dif.  sqlite3Wal
cb70: 6b 45 78 70 72 28 26 77 2c 20 70 45 78 70 72 29  kExpr(&w, pExpr)
cb80: 3b 0a 23 69 66 20 53 51 4c 49 54 45 5f 4d 41 58  ;.#if SQLITE_MAX
cb90: 5f 45 58 50 52 5f 44 45 50 54 48 3e 30 0a 20 20  _EXPR_DEPTH>0.  
cba0: 77 2e 70 50 61 72 73 65 2d 3e 6e 48 65 69 67 68  w.pParse->nHeigh
cbb0: 74 20 2d 3d 20 70 45 78 70 72 2d 3e 6e 48 65 69  t -= pExpr->nHei
cbc0: 67 68 74 3b 0a 23 65 6e 64 69 66 0a 20 20 69 66  ght;.#endif.  if
cbd0: 28 20 70 4e 43 2d 3e 6e 63 46 6c 61 67 73 20 26  ( pNC->ncFlags &
cbe0: 20 4e 43 5f 48 61 73 41 67 67 20 29 7b 0a 20 20   NC_HasAgg ){.  
cbf0: 20 20 45 78 70 72 53 65 74 50 72 6f 70 65 72 74    ExprSetPropert
cc00: 79 28 70 45 78 70 72 2c 20 45 50 5f 41 67 67 29  y(pExpr, EP_Agg)
cc10: 3b 0a 20 20 7d 0a 20 20 70 4e 43 2d 3e 6e 63 46  ;.  }.  pNC->ncF
cc20: 6c 61 67 73 20 7c 3d 20 73 61 76 65 64 48 61 73  lags |= savedHas
cc30: 41 67 67 3b 0a 20 20 72 65 74 75 72 6e 20 70 4e  Agg;.  return pN
cc40: 43 2d 3e 6e 45 72 72 3e 30 20 7c 7c 20 77 2e 70  C->nErr>0 || w.p
cc50: 50 61 72 73 65 2d 3e 6e 45 72 72 3e 30 3b 0a 7d  Parse->nErr>0;.}
cc60: 0a 0a 2f 2a 0a 2a 2a 20 52 65 73 6f 6c 76 65 20  ../*.** Resolve 
cc70: 61 6c 6c 20 6e 61 6d 65 73 20 66 6f 72 20 61 6c  all names for al
cc80: 6c 20 65 78 70 72 65 73 73 69 6f 6e 20 69 6e 20  l expression in 
cc90: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 6c 69  an expression li
cca0: 73 74 2e 20 20 54 68 69 73 20 69 73 0a 2a 2a 20  st.  This is.** 
ccb0: 6a 75 73 74 20 6c 69 6b 65 20 73 71 6c 69 74 65  just like sqlite
ccc0: 33 52 65 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65  3ResolveExprName
ccd0: 73 28 29 20 65 78 63 65 70 74 20 74 68 61 74 20  s() except that 
cce0: 69 74 20 77 6f 72 6b 73 20 66 6f 72 20 61 6e 20  it works for an 
ccf0: 65 78 70 72 65 73 73 69 6f 6e 0a 2a 2a 20 6c 69  expression.** li
cd00: 73 74 20 72 61 74 68 65 72 20 74 68 61 6e 20 61  st rather than a
cd10: 20 73 69 6e 67 6c 65 20 65 78 70 72 65 73 73 69   single expressi
cd20: 6f 6e 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  on..*/.int sqlit
cd30: 65 33 52 65 73 6f 6c 76 65 45 78 70 72 4c 69 73  e3ResolveExprLis
cd40: 74 4e 61 6d 65 73 28 20 0a 20 20 4e 61 6d 65 43  tNames( .  NameC
cd50: 6f 6e 74 65 78 74 20 2a 70 4e 43 2c 20 20 20 20  ontext *pNC,    
cd60: 20 20 20 2f 2a 20 4e 61 6d 65 73 70 61 63 65 20     /* Namespace 
cd70: 74 6f 20 72 65 73 6f 6c 76 65 20 65 78 70 72 65  to resolve expre
cd80: 73 73 69 6f 6e 73 20 69 6e 2e 20 2a 2f 0a 20 20  ssions in. */.  
cd90: 45 78 70 72 4c 69 73 74 20 2a 70 4c 69 73 74 20  ExprList *pList 
cda0: 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 65          /* The e
cdb0: 78 70 72 65 73 73 69 6f 6e 20 6c 69 73 74 20 74  xpression list t
cdc0: 6f 20 62 65 20 61 6e 61 6c 79 7a 65 64 2e 20 2a  o be analyzed. *
cdd0: 2f 0a 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20  /.){.  int i;.  
cde0: 69 66 28 20 70 4c 69 73 74 20 29 7b 0a 20 20 20  if( pList ){.   
cdf0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 4c 69 73   for(i=0; i<pLis
ce00: 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a  t->nExpr; i++){.
ce10: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
ce20: 33 52 65 73 6f 6c 76 65 45 78 70 72 4e 61 6d 65  3ResolveExprName
ce30: 73 28 70 4e 43 2c 20 70 4c 69 73 74 2d 3e 61 5b  s(pNC, pList->a[
ce40: 69 5d 2e 70 45 78 70 72 29 20 29 20 72 65 74 75  i].pExpr) ) retu
ce50: 72 6e 20 57 52 43 5f 41 62 6f 72 74 3b 0a 20 20  rn WRC_Abort;.  
ce60: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
ce70: 20 57 52 43 5f 43 6f 6e 74 69 6e 75 65 3b 0a 7d   WRC_Continue;.}
ce80: 0a 0a 2f 2a 0a 2a 2a 20 52 65 73 6f 6c 76 65 20  ../*.** Resolve 
ce90: 61 6c 6c 20 6e 61 6d 65 73 20 69 6e 20 61 6c 6c  all names in all
cea0: 20 65 78 70 72 65 73 73 69 6f 6e 73 20 6f 66 20   expressions of 
ceb0: 61 20 53 45 4c 45 43 54 20 61 6e 64 20 69 6e 20  a SELECT and in 
cec0: 61 6c 6c 0a 2a 2a 20 64 65 63 65 6e 64 65 6e 74  all.** decendent
ced0: 73 20 6f 66 20 74 68 65 20 53 45 4c 45 43 54 2c  s of the SELECT,
cee0: 20 69 6e 63 6c 75 64 69 6e 67 20 63 6f 6d 70 6f   including compo
cef0: 75 6e 64 73 20 6f 66 66 20 6f 66 20 70 2d 3e 70  unds off of p->p
cf00: 50 72 69 6f 72 2c 0a 2a 2a 20 73 75 62 71 75 65  Prior,.** subque
cf10: 72 69 65 73 20 69 6e 20 65 78 70 72 65 73 73 69  ries in expressi
cf20: 6f 6e 73 2c 20 61 6e 64 20 73 75 62 71 75 65 72  ons, and subquer
cf30: 69 65 73 20 75 73 65 64 20 61 73 20 46 52 4f 4d  ies used as FROM
cf40: 20 63 6c 61 75 73 65 0a 2a 2a 20 74 65 72 6d 73   clause.** terms
cf50: 2e 0a 2a 2a 0a 2a 2a 20 53 65 65 20 73 71 6c 69  ..**.** See sqli
cf60: 74 65 33 52 65 73 6f 6c 76 65 45 78 70 72 4e 61  te3ResolveExprNa
cf70: 6d 65 73 28 29 20 66 6f 72 20 61 20 64 65 73 63  mes() for a desc
cf80: 72 69 70 74 69 6f 6e 20 6f 66 20 74 68 65 20 6b  ription of the k
cf90: 69 6e 64 73 20 6f 66 0a 2a 2a 20 74 72 61 6e 73  inds of.** trans
cfa0: 66 6f 72 6d 61 74 69 6f 6e 73 20 74 68 61 74 20  formations that 
cfb0: 6f 63 63 75 72 2e 0a 2a 2a 0a 2a 2a 20 41 6c 6c  occur..**.** All
cfc0: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
cfd0: 74 73 20 73 68 6f 75 6c 64 20 68 61 76 65 20 62  ts should have b
cfe0: 65 65 6e 20 65 78 70 61 6e 64 65 64 20 75 73 69  een expanded usi
cff0: 6e 67 0a 2a 2a 20 73 71 6c 69 74 65 33 53 65 6c  ng.** sqlite3Sel
d000: 65 63 74 45 78 70 61 6e 64 28 29 20 70 72 69 6f  ectExpand() prio
d010: 72 20 74 6f 20 69 6e 76 6f 6b 69 6e 67 20 74 68  r to invoking th
d020: 69 73 20 72 6f 75 74 69 6e 65 2e 0a 2a 2f 0a 76  is routine..*/.v
d030: 6f 69 64 20 73 71 6c 69 74 65 33 52 65 73 6f 6c  oid sqlite3Resol
d040: 76 65 53 65 6c 65 63 74 4e 61 6d 65 73 28 0a 20  veSelectNames(. 
d050: 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20   Parse *pParse, 
d060: 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70          /* The p
d070: 61 72 73 65 72 20 63 6f 6e 74 65 78 74 20 2a 2f  arser context */
d080: 0a 20 20 53 65 6c 65 63 74 20 2a 70 2c 20 20 20  .  Select *p,   
d090: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65            /* The
d0a0: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
d0b0: 74 20 62 65 69 6e 67 20 63 6f 64 65 64 2e 20 2a  t being coded. *
d0c0: 2f 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78 74 20  /.  NameContext 
d0d0: 2a 70 4f 75 74 65 72 4e 43 20 20 2f 2a 20 4e 61  *pOuterNC  /* Na
d0e0: 6d 65 20 63 6f 6e 74 65 78 74 20 66 6f 72 20 70  me context for p
d0f0: 61 72 65 6e 74 20 53 45 4c 45 43 54 20 73 74 61  arent SELECT sta
d100: 74 65 6d 65 6e 74 20 2a 2f 0a 29 7b 0a 20 20 57  tement */.){.  W
d110: 61 6c 6b 65 72 20 77 3b 0a 0a 20 20 61 73 73 65  alker w;..  asse
d120: 72 74 28 20 70 21 3d 30 20 29 3b 0a 20 20 77 2e  rt( p!=0 );.  w.
d130: 78 45 78 70 72 43 61 6c 6c 62 61 63 6b 20 3d 20  xExprCallback = 
d140: 72 65 73 6f 6c 76 65 45 78 70 72 53 74 65 70 3b  resolveExprStep;
d150: 0a 20 20 77 2e 78 53 65 6c 65 63 74 43 61 6c 6c  .  w.xSelectCall
d160: 62 61 63 6b 20 3d 20 72 65 73 6f 6c 76 65 53 65  back = resolveSe
d170: 6c 65 63 74 53 74 65 70 3b 0a 20 20 77 2e 78 53  lectStep;.  w.xS
d180: 65 6c 65 63 74 43 61 6c 6c 62 61 63 6b 32 20 3d  electCallback2 =
d190: 20 30 3b 0a 20 20 77 2e 70 50 61 72 73 65 20 3d   0;.  w.pParse =
d1a0: 20 70 50 61 72 73 65 3b 0a 20 20 77 2e 75 2e 70   pParse;.  w.u.p
d1b0: 4e 43 20 3d 20 70 4f 75 74 65 72 4e 43 3b 0a 20  NC = pOuterNC;. 
d1c0: 20 73 71 6c 69 74 65 33 57 61 6c 6b 53 65 6c 65   sqlite3WalkSele
d1d0: 63 74 28 26 77 2c 20 70 29 3b 0a 7d 0a 0a 2f 2a  ct(&w, p);.}../*
d1e0: 0a 2a 2a 20 52 65 73 6f 6c 76 65 20 6e 61 6d 65  .** Resolve name
d1f0: 73 20 69 6e 20 65 78 70 72 65 73 73 69 6f 6e 73  s in expressions
d200: 20 74 68 61 74 20 63 61 6e 20 6f 6e 6c 79 20 72   that can only r
d210: 65 66 65 72 65 6e 63 65 20 61 20 73 69 6e 67 6c  eference a singl
d220: 65 20 74 61 62 6c 65 3a 0a 2a 2a 0a 2a 2a 20 20  e table:.**.**  
d230: 20 20 2a 20 20 20 43 48 45 43 4b 20 63 6f 6e 73    *   CHECK cons
d240: 74 72 61 69 6e 74 73 0a 2a 2a 20 20 20 20 2a 20  traints.**    * 
d250: 20 20 57 48 45 52 45 20 63 6c 61 75 73 65 73 20    WHERE clauses 
d260: 6f 6e 20 70 61 72 74 69 61 6c 20 69 6e 64 69 63  on partial indic
d270: 65 73 0a 2a 2a 0a 2a 2a 20 54 68 65 20 45 78 70  es.**.** The Exp
d280: 72 2e 69 54 61 62 6c 65 20 76 61 6c 75 65 20 66  r.iTable value f
d290: 6f 72 20 45 78 70 72 2e 6f 70 3d 3d 54 4b 5f 43  or Expr.op==TK_C
d2a0: 4f 4c 55 4d 4e 20 6e 6f 64 65 73 20 6f 66 20 74  OLUMN nodes of t
d2b0: 68 65 20 65 78 70 72 65 73 73 69 6f 6e 0a 2a 2a  he expression.**
d2c0: 20 69 73 20 73 65 74 20 74 6f 20 2d 31 20 61 6e   is set to -1 an
d2d0: 64 20 74 68 65 20 45 78 70 72 2e 69 43 6f 6c 75  d the Expr.iColu
d2e0: 6d 6e 20 76 61 6c 75 65 20 69 73 20 73 65 74 20  mn value is set 
d2f0: 74 6f 20 74 68 65 20 63 6f 6c 75 6d 6e 20 6e 75  to the column nu
d300: 6d 62 65 72 2e 0a 2a 2a 0a 2a 2a 20 41 6e 79 20  mber..**.** Any 
d310: 65 72 72 6f 72 73 20 63 61 75 73 65 20 61 6e 20  errors cause an 
d320: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 74 6f  error message to
d330: 20 62 65 20 73 65 74 20 69 6e 20 70 50 61 72 73   be set in pPars
d340: 65 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74  e..*/.void sqlit
d350: 65 33 52 65 73 6f 6c 76 65 53 65 6c 66 52 65 66  e3ResolveSelfRef
d360: 65 72 65 6e 63 65 28 0a 20 20 50 61 72 73 65 20  erence(.  Parse 
d370: 2a 70 50 61 72 73 65 2c 20 20 20 20 20 20 2f 2a  *pParse,      /*
d380: 20 50 61 72 73 69 6e 67 20 63 6f 6e 74 65 78 74   Parsing context
d390: 20 2a 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54 61   */.  Table *pTa
d3a0: 62 2c 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65  b,        /* The
d3b0: 20 74 61 62 6c 65 20 62 65 69 6e 67 20 72 65 66   table being ref
d3c0: 65 72 65 6e 63 65 64 20 2a 2f 0a 20 20 69 6e 74  erenced */.  int
d3d0: 20 74 79 70 65 2c 20 20 20 20 20 20 20 20 20 20   type,          
d3e0: 20 2f 2a 20 4e 43 5f 49 73 43 68 65 63 6b 20 6f   /* NC_IsCheck o
d3f0: 72 20 4e 43 5f 50 61 72 74 49 64 78 20 6f 72 20  r NC_PartIdx or 
d400: 4e 43 5f 49 64 78 45 78 70 72 20 2a 2f 0a 20 20  NC_IdxExpr */.  
d410: 45 78 70 72 20 2a 70 45 78 70 72 2c 20 20 20 20  Expr *pExpr,    
d420: 20 20 20 20 2f 2a 20 45 78 70 72 65 73 73 69 6f      /* Expressio
d430: 6e 20 74 6f 20 72 65 73 6f 6c 76 65 2e 20 20 4d  n to resolve.  M
d440: 61 79 20 62 65 20 4e 55 4c 4c 2e 20 2a 2f 0a 20  ay be NULL. */. 
d450: 20 45 78 70 72 4c 69 73 74 20 2a 70 4c 69 73 74   ExprList *pList
d460: 20 20 20 20 20 2f 2a 20 45 78 70 72 65 73 73 69       /* Expressi
d470: 6f 6e 20 6c 69 73 74 20 74 6f 20 72 65 73 6f 6c  on list to resol
d480: 76 65 2e 20 20 4d 61 79 20 62 65 20 4e 55 4c 2e  ve.  May be NUL.
d490: 20 2a 2f 0a 29 7b 0a 20 20 53 72 63 4c 69 73 74   */.){.  SrcList
d4a0: 20 73 53 72 63 3b 20 20 20 20 20 20 20 20 20 20   sSrc;          
d4b0: 20 20 20 20 20 20 20 20 20 2f 2a 20 46 61 6b 65           /* Fake
d4c0: 20 53 72 63 4c 69 73 74 20 66 6f 72 20 70 50 61   SrcList for pPa
d4d0: 72 73 65 2d 3e 70 4e 65 77 54 61 62 6c 65 20 2a  rse->pNewTable *
d4e0: 2f 0a 20 20 4e 61 6d 65 43 6f 6e 74 65 78 74 20  /.  NameContext 
d4f0: 73 4e 43 3b 20 20 20 20 20 20 20 20 20 20 20 20  sNC;            
d500: 20 20 20 20 2f 2a 20 4e 61 6d 65 20 63 6f 6e 74      /* Name cont
d510: 65 78 74 20 66 6f 72 20 70 50 61 72 73 65 2d 3e  ext for pParse->
d520: 70 4e 65 77 54 61 62 6c 65 20 2a 2f 0a 0a 20 20  pNewTable */..  
d530: 61 73 73 65 72 74 28 20 74 79 70 65 3d 3d 4e 43  assert( type==NC
d540: 5f 49 73 43 68 65 63 6b 20 7c 7c 20 74 79 70 65  _IsCheck || type
d550: 3d 3d 4e 43 5f 50 61 72 74 49 64 78 20 7c 7c 20  ==NC_PartIdx || 
d560: 74 79 70 65 3d 3d 4e 43 5f 49 64 78 45 78 70 72  type==NC_IdxExpr
d570: 20 29 3b 0a 20 20 6d 65 6d 73 65 74 28 26 73 4e   );.  memset(&sN
d580: 43 2c 20 30 2c 20 73 69 7a 65 6f 66 28 73 4e 43  C, 0, sizeof(sNC
d590: 29 29 3b 0a 20 20 6d 65 6d 73 65 74 28 26 73 53  ));.  memset(&sS
d5a0: 72 63 2c 20 30 2c 20 73 69 7a 65 6f 66 28 73 53  rc, 0, sizeof(sS
d5b0: 72 63 29 29 3b 0a 20 20 73 53 72 63 2e 6e 53 72  rc));.  sSrc.nSr
d5c0: 63 20 3d 20 31 3b 0a 20 20 73 53 72 63 2e 61 5b  c = 1;.  sSrc.a[
d5d0: 30 5d 2e 7a 4e 61 6d 65 20 3d 20 70 54 61 62 2d  0].zName = pTab-
d5e0: 3e 7a 4e 61 6d 65 3b 0a 20 20 73 53 72 63 2e 61  >zName;.  sSrc.a
d5f0: 5b 30 5d 2e 70 54 61 62 20 3d 20 70 54 61 62 3b  [0].pTab = pTab;
d600: 0a 20 20 73 53 72 63 2e 61 5b 30 5d 2e 69 43 75  .  sSrc.a[0].iCu
d610: 72 73 6f 72 20 3d 20 2d 31 3b 0a 20 20 73 4e 43  rsor = -1;.  sNC
d620: 2e 70 50 61 72 73 65 20 3d 20 70 50 61 72 73 65  .pParse = pParse
d630: 3b 0a 20 20 73 4e 43 2e 70 53 72 63 4c 69 73 74  ;.  sNC.pSrcList
d640: 20 3d 20 26 73 53 72 63 3b 0a 20 20 73 4e 43 2e   = &sSrc;.  sNC.
d650: 6e 63 46 6c 61 67 73 20 3d 20 74 79 70 65 3b 0a  ncFlags = type;.
d660: 20 20 69 66 28 20 73 71 6c 69 74 65 33 52 65 73    if( sqlite3Res
d670: 6f 6c 76 65 45 78 70 72 4e 61 6d 65 73 28 26 73  olveExprNames(&s
d680: 4e 43 2c 20 70 45 78 70 72 29 20 29 20 72 65 74  NC, pExpr) ) ret
d690: 75 72 6e 3b 0a 20 20 69 66 28 20 70 4c 69 73 74  urn;.  if( pList
d6a0: 20 29 20 73 71 6c 69 74 65 33 52 65 73 6f 6c 76   ) sqlite3Resolv
d6b0: 65 45 78 70 72 4c 69 73 74 4e 61 6d 65 73 28 26  eExprListNames(&
d6c0: 73 4e 43 2c 20 70 4c 69 73 74 29 3b 0a 7d 0a     sNC, pList);.}.