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

Artifact 5aa5db4d426e71b7a51edcef5d75969bc377d8f6:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you 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 2a 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 61  tines used for a
01a0: 6e 61 6c 79 7a 69 6e 67 20 65 78 70 72 65 73 73  nalyzing express
01b0: 69 6f 6e 73 20 61 6e 64 0a 2a 2a 20 66 6f 72 20  ions and.** for 
01c0: 67 65 6e 65 72 61 74 69 6e 67 20 56 44 42 45 20  generating VDBE 
01d0: 63 6f 64 65 20 74 68 61 74 20 65 76 61 6c 75 61  code that evalua
01e0: 74 65 73 20 65 78 70 72 65 73 73 69 6f 6e 73 20  tes expressions 
01f0: 69 6e 20 53 51 4c 69 74 65 2e 0a 2a 2a 0a 2a 2a  in SQLite..**.**
0200: 20 24 49 64 3a 20 65 78 70 72 2e 63 2c 76 20 31   $Id: expr.c,v 1
0210: 2e 33 30 20 32 30 30 31 2f 31 30 2f 31 33 20 30  .30 2001/10/13 0
0220: 31 3a 30 36 3a 34 38 20 64 72 68 20 45 78 70 20  1:06:48 drh Exp 
0230: 24 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 73  $.*/.#include "s
0240: 71 6c 69 74 65 49 6e 74 2e 68 22 0a 0a 2f 2a 0a  qliteInt.h"../*.
0250: 2a 2a 20 57 61 6c 6b 20 61 6e 20 65 78 70 72 65  ** Walk an expre
0260: 73 73 69 6f 6e 20 74 72 65 65 2e 20 20 52 65 74  ssion tree.  Ret
0270: 75 72 6e 20 31 20 69 66 20 74 68 65 20 65 78 70  urn 1 if the exp
0280: 72 65 73 73 69 6f 6e 20 69 73 20 63 6f 6e 73 74  ression is const
0290: 61 6e 74 0a 2a 2a 20 61 6e 64 20 30 20 69 66 20  ant.** and 0 if 
02a0: 69 74 20 69 6e 76 6f 6c 76 65 73 20 76 61 72 69  it involves vari
02b0: 61 62 6c 65 73 2e 0a 2a 2f 0a 73 74 61 74 69 63  ables..*/.static
02c0: 20 69 6e 74 20 69 73 43 6f 6e 73 74 61 6e 74 28   int isConstant(
02d0: 45 78 70 72 20 2a 70 29 7b 0a 20 20 73 77 69 74  Expr *p){.  swit
02e0: 63 68 28 20 70 2d 3e 6f 70 20 29 7b 0a 20 20 20  ch( p->op ){.   
02f0: 20 63 61 73 65 20 54 4b 5f 49 44 3a 0a 20 20 20   case TK_ID:.   
0300: 20 63 61 73 65 20 54 4b 5f 43 4f 4c 55 4d 4e 3a   case TK_COLUMN:
0310: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 44 4f 54  .    case TK_DOT
0320: 3a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 30  :.      return 0
0330: 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b  ;.    default: {
0340: 0a 20 20 20 20 20 20 69 66 28 20 70 2d 3e 70 4c  .      if( p->pL
0350: 65 66 74 20 26 26 20 21 69 73 43 6f 6e 73 74 61  eft && !isConsta
0360: 6e 74 28 70 2d 3e 70 4c 65 66 74 29 20 29 20 72  nt(p->pLeft) ) r
0370: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20 69  eturn 0;.      i
0380: 66 28 20 70 2d 3e 70 52 69 67 68 74 20 26 26 20  f( p->pRight && 
0390: 21 69 73 43 6f 6e 73 74 61 6e 74 28 70 2d 3e 70  !isConstant(p->p
03a0: 52 69 67 68 74 29 20 29 20 72 65 74 75 72 6e 20  Right) ) return 
03b0: 30 3b 0a 20 20 20 20 20 20 69 66 28 20 70 2d 3e  0;.      if( p->
03c0: 70 4c 69 73 74 20 29 7b 0a 20 20 20 20 20 20 20  pList ){.       
03d0: 20 69 6e 74 20 69 3b 0a 20 20 20 20 20 20 20 20   int i;.        
03e0: 66 6f 72 28 69 3d 30 3b 20 69 3c 70 2d 3e 70 4c  for(i=0; i<p->pL
03f0: 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29  ist->nExpr; i++)
0400: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  {.          if( 
0410: 21 69 73 43 6f 6e 73 74 61 6e 74 28 70 2d 3e 70  !isConstant(p->p
0420: 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72  List->a[i].pExpr
0430: 29 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  ) ) return 0;.  
0440: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
0450: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
0460: 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20   }.  }.  return 
0470: 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 61 6c 6b  1;.}../*.** Walk
0480: 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20   the expression 
0490: 74 72 65 65 20 61 6e 64 20 70 72 6f 63 65 73 73  tree and process
04a0: 20 6f 70 65 72 61 74 6f 72 73 20 6f 66 20 74 68   operators of th
04b0: 65 20 66 6f 72 6d 3a 0a 2a 2a 0a 2a 2a 20 20 20  e form:.**.**   
04c0: 20 20 20 20 65 78 70 72 20 49 4e 20 28 53 45 4c      expr IN (SEL
04d0: 45 43 54 20 2e 2e 2e 29 0a 2a 2a 0a 2a 2a 20 54  ECT ...).**.** T
04e0: 68 65 73 65 20 6f 70 65 72 61 74 6f 72 73 20 68  hese operators h
04f0: 61 76 65 20 74 6f 20 62 65 20 70 72 6f 63 65 73  ave to be proces
0500: 73 65 64 20 62 65 66 6f 72 65 20 63 6f 6c 75 6d  sed before colum
0510: 6e 20 6e 61 6d 65 73 20 61 72 65 0a 2a 2a 20 72  n names are.** r
0520: 65 73 6f 6c 76 65 64 20 62 65 63 61 75 73 65 20  esolved because 
0530: 65 61 63 68 20 73 75 63 68 20 6f 70 65 72 61 74  each such operat
0540: 6f 72 20 69 6e 63 72 65 6d 65 6e 74 73 20 70 50  or increments pP
0550: 61 72 73 65 2d 3e 6e 54 61 62 0a 2a 2a 20 74 6f  arse->nTab.** to
0560: 20 72 65 73 65 72 76 65 20 63 75 72 73 6f 72 20   reserve cursor 
0570: 6e 75 6d 62 65 72 73 20 66 6f 72 20 69 74 73 20  numbers for its 
0580: 6f 77 6e 20 75 73 65 2e 20 20 42 75 74 20 70 50  own use.  But pP
0590: 61 72 73 65 2d 3e 6e 54 61 62 0a 2a 2a 20 6e 65  arse->nTab.** ne
05a0: 65 64 73 20 74 6f 20 62 65 20 63 6f 6e 73 74 61  eds to be consta
05b0: 6e 74 20 6f 6e 63 65 20 77 65 20 62 65 67 69 6e  nt once we begin
05c0: 20 72 65 73 6f 6c 76 69 6e 67 20 63 6f 6c 75 6d   resolving colum
05d0: 6e 20 6e 61 6d 65 73 2e 0a 2a 2a 0a 2a 2a 20 41  n names..**.** A
05e0: 63 74 75 61 6c 6c 79 2c 20 74 68 65 20 70 72 6f  ctually, the pro
05f0: 63 65 73 73 69 6e 67 20 6f 66 20 49 4e 2d 53 45  cessing of IN-SE
0600: 4c 45 43 54 20 69 73 20 6f 6e 6c 79 20 73 74 61  LECT is only sta
0610: 72 74 65 64 20 62 79 20 74 68 69 73 0a 2a 2a 20  rted by this.** 
0620: 72 6f 75 74 69 6e 65 2e 20 20 54 68 69 73 20 72  routine.  This r
0630: 6f 75 74 69 6e 65 20 61 6c 6c 6f 63 61 74 65 73  outine allocates
0640: 20 61 20 63 75 72 73 6f 72 20 6e 75 6d 62 65 72   a cursor number
0650: 20 74 6f 20 74 68 65 20 49 4e 2d 53 45 4c 45 43   to the IN-SELEC
0660: 54 0a 2a 2a 20 61 6e 64 20 74 68 65 6e 20 6d 6f  T.** and then mo
0670: 76 65 73 20 6f 6e 2e 20 20 54 68 65 20 63 6f 64  ves on.  The cod
0680: 65 20 67 65 6e 65 72 61 74 69 6f 6e 20 69 73 20  e generation is 
0690: 64 6f 6e 65 20 62 79 20 0a 2a 2a 20 73 71 6c 69  done by .** sqli
06a0: 74 65 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73  teExprResolveIds
06b0: 28 29 20 77 68 69 63 68 20 6d 75 73 74 20 62 65  () which must be
06c0: 20 63 61 6c 6c 65 64 20 61 66 74 65 72 77 61 72   called afterwar
06d0: 64 73 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69  ds..*/.void sqli
06e0: 74 65 45 78 70 72 52 65 73 6f 6c 76 65 49 6e 53  teExprResolveInS
06f0: 65 6c 65 63 74 28 50 61 72 73 65 20 2a 70 50 61  elect(Parse *pPa
0700: 72 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70 72  rse, Expr *pExpr
0710: 29 7b 0a 20 20 69 66 28 20 70 45 78 70 72 3d 3d  ){.  if( pExpr==
0720: 30 20 29 20 72 65 74 75 72 6e 3b 0a 20 20 69 66  0 ) return;.  if
0730: 28 20 70 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b 5f  ( pExpr->op==TK_
0740: 49 4e 20 26 26 20 70 45 78 70 72 2d 3e 70 53 65  IN && pExpr->pSe
0750: 6c 65 63 74 21 3d 30 20 29 7b 0a 20 20 20 20 70  lect!=0 ){.    p
0760: 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20 70  Expr->iTable = p
0770: 50 61 72 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20  Parse->nTab++;. 
0780: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 69 66 28 20   }else{.    if( 
0790: 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 29 20 73  pExpr->pLeft ) s
07a0: 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65  qliteExprResolve
07b0: 49 6e 53 65 6c 65 63 74 28 70 50 61 72 73 65 2c  InSelect(pParse,
07c0: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
07d0: 20 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 70      if( pExpr->p
07e0: 52 69 67 68 74 20 29 20 73 71 6c 69 74 65 45 78  Right ) sqliteEx
07f0: 70 72 52 65 73 6f 6c 76 65 49 6e 53 65 6c 65 63  prResolveInSelec
0800: 74 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  t(pParse, pExpr-
0810: 3e 70 52 69 67 68 74 29 3b 0a 20 20 20 20 69 66  >pRight);.    if
0820: 28 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 20 29  ( pExpr->pList )
0830: 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20  {.      int i;. 
0840: 20 20 20 20 20 45 78 70 72 4c 69 73 74 20 2a 70       ExprList *p
0850: 4c 69 73 74 20 3d 20 70 45 78 70 72 2d 3e 70 4c  List = pExpr->pL
0860: 69 73 74 3b 0a 20 20 20 20 20 20 66 6f 72 28 69  ist;.      for(i
0870: 3d 30 3b 20 69 3c 70 4c 69 73 74 2d 3e 6e 45 78  =0; i<pList->nEx
0880: 70 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  pr; i++){.      
0890: 20 20 73 71 6c 69 74 65 45 78 70 72 52 65 73 6f    sqliteExprReso
08a0: 6c 76 65 49 6e 53 65 6c 65 63 74 28 70 50 61 72  lveInSelect(pPar
08b0: 73 65 2c 20 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e  se, pList->a[i].
08c0: 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 7d 0a  pExpr);.      }.
08d0: 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a      }.  }.}../*.
08e0: 2a 2a 20 52 65 74 75 72 6e 20 54 52 55 45 20 69  ** Return TRUE i
08f0: 66 20 74 68 65 20 67 69 76 65 6e 20 73 74 72 69  f the given stri
0900: 6e 67 20 69 73 20 61 20 72 6f 77 2d 69 64 20 63  ng is a row-id c
0910: 6f 6c 75 6d 6e 20 6e 61 6d 65 2e 0a 2a 2f 0a 73  olumn name..*/.s
0920: 74 61 74 69 63 20 69 6e 74 20 73 71 6c 69 74 65  tatic int sqlite
0930: 49 73 52 6f 77 69 64 28 63 6f 6e 73 74 20 63 68  IsRowid(const ch
0940: 61 72 20 2a 7a 29 7b 0a 20 20 69 66 28 20 73 71  ar *z){.  if( sq
0950: 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 2c 20 22  liteStrICmp(z, "
0960: 5f 52 4f 57 49 44 5f 22 29 3d 3d 30 20 29 20 72  _ROWID_")==0 ) r
0970: 65 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20 73  eturn 1;.  if( s
0980: 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 2c 20  qliteStrICmp(z, 
0990: 22 52 4f 57 49 44 22 29 3d 3d 30 20 29 20 72 65  "ROWID")==0 ) re
09a0: 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20 73 71  turn 1;.  if( sq
09b0: 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 2c 20 22  liteStrICmp(z, "
09c0: 4f 49 44 22 29 3d 3d 30 20 29 20 72 65 74 75 72  OID")==0 ) retur
09d0: 6e 20 31 3b 0a 20 20 72 65 74 75 72 6e 20 30 3b  n 1;.  return 0;
09e0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 72  .}../*.** This r
09f0: 6f 75 74 69 6e 65 20 77 61 6c 6b 73 20 61 6e 20  outine walks an 
0a00: 65 78 70 72 65 73 73 69 6f 6e 20 74 72 65 65 20  expression tree 
0a10: 61 6e 64 20 72 65 73 6f 6c 76 65 73 20 72 65 66  and resolves ref
0a20: 65 72 65 6e 63 65 73 20 74 6f 0a 2a 2a 20 74 61  erences to.** ta
0a30: 62 6c 65 20 63 6f 6c 75 6d 6e 73 2e 20 20 4e 6f  ble columns.  No
0a40: 64 65 73 20 6f 66 20 74 68 65 20 66 6f 72 6d 20  des of the form 
0a50: 49 44 2e 49 44 20 6f 72 20 49 44 20 72 65 73 6f  ID.ID or ID reso
0a60: 6c 76 65 20 69 6e 74 6f 20 61 6e 0a 2a 2a 20 69  lve into an.** i
0a70: 6e 64 65 78 20 74 6f 20 74 68 65 20 74 61 62 6c  ndex to the tabl
0a80: 65 20 69 6e 20 74 68 65 20 74 61 62 6c 65 20 6c  e in the table l
0a90: 69 73 74 20 61 6e 64 20 61 20 63 6f 6c 75 6d 6e  ist and a column
0aa0: 20 6f 66 66 73 65 74 2e 20 20 54 68 65 20 6f 70   offset.  The op
0ab0: 63 6f 64 65 0a 2a 2a 20 66 6f 72 20 73 75 63 68  code.** for such
0ac0: 20 6e 6f 64 65 73 20 69 73 20 63 68 61 6e 67 65   nodes is change
0ad0: 64 20 74 6f 20 54 4b 5f 43 4f 4c 55 4d 4e 2e 20  d to TK_COLUMN. 
0ae0: 20 54 68 65 20 69 54 61 62 6c 65 20 76 61 6c 75   The iTable valu
0af0: 65 20 69 73 20 63 68 61 6e 67 65 64 0a 2a 2a 20  e is changed.** 
0b00: 74 6f 20 74 68 65 20 69 6e 64 65 78 20 6f 66 20  to the index of 
0b10: 74 68 65 20 72 65 66 65 72 65 6e 63 65 64 20 74  the referenced t
0b20: 61 62 6c 65 20 69 6e 20 70 54 61 62 4c 69 73 74  able in pTabList
0b30: 20 70 6c 75 73 20 74 68 65 20 70 50 61 72 73 65   plus the pParse
0b40: 2d 3e 6e 54 61 62 0a 2a 2a 20 76 61 6c 75 65 2e  ->nTab.** value.
0b50: 20 20 54 68 65 20 69 43 6f 6c 75 6d 6e 20 76 61    The iColumn va
0b60: 6c 75 65 20 69 73 20 63 68 61 6e 67 65 64 20 74  lue is changed t
0b70: 6f 20 74 68 65 20 69 6e 64 65 78 20 6f 66 20 74  o the index of t
0b80: 68 65 20 63 6f 6c 75 6d 6e 20 6f 66 20 74 68 65  he column of the
0b90: 20 0a 2a 2a 20 72 65 66 65 72 65 6e 63 65 64 20   .** referenced 
0ba0: 74 61 62 6c 65 2e 0a 2a 2a 0a 2a 2a 20 57 65 20  table..**.** We 
0bb0: 61 6c 73 6f 20 63 68 65 63 6b 20 66 6f 72 20 69  also check for i
0bc0: 6e 73 74 61 6e 63 65 73 20 6f 66 20 74 68 65 20  nstances of the 
0bd0: 49 4e 20 6f 70 65 72 61 74 6f 72 2e 20 20 49 4e  IN operator.  IN
0be0: 20 63 6f 6d 65 73 20 69 6e 20 74 77 6f 0a 2a 2a   comes in two.**
0bf0: 20 66 6f 72 6d 73 3a 0a 2a 2a 0a 2a 2a 20 20 20   forms:.**.**   
0c00: 20 20 20 20 20 20 20 20 65 78 70 72 20 49 4e 20          expr IN 
0c10: 28 65 78 70 72 6c 69 73 74 29 0a 2a 2a 20 61 6e  (exprlist).** an
0c20: 64 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20 65  d.**           e
0c30: 78 70 72 20 49 4e 20 28 53 45 4c 45 43 54 20 2e  xpr IN (SELECT .
0c40: 2e 2e 29 0a 2a 2a 0a 2a 2a 20 54 68 65 20 66 69  ..).**.** The fi
0c50: 72 73 74 20 66 6f 72 6d 20 69 73 20 68 61 6e 64  rst form is hand
0c60: 6c 65 64 20 62 79 20 63 72 65 61 74 69 6e 67 20  led by creating 
0c70: 61 20 73 65 74 20 68 6f 6c 64 69 6e 67 20 74 68  a set holding th
0c80: 65 20 6c 69 73 74 0a 2a 2a 20 6f 66 20 61 6c 6c  e list.** of all
0c90: 6f 77 65 64 20 76 61 6c 75 65 73 2e 20 20 54 68  owed values.  Th
0ca0: 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d 20 63 61  e second form ca
0cb0: 75 73 65 73 20 74 68 65 20 53 45 4c 45 43 54 20  uses the SELECT 
0cc0: 74 6f 20 67 65 6e 65 72 61 74 65 20 0a 2a 2a 20  to generate .** 
0cd0: 61 20 74 65 6d 70 6f 72 61 72 79 20 74 61 62 6c  a temporary tabl
0ce0: 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 72 6f  e..**.** This ro
0cf0: 75 74 69 6e 65 20 61 6c 73 6f 20 6c 6f 6f 6b 73  utine also looks
0d00: 20 66 6f 72 20 73 63 61 6c 61 72 20 53 45 4c 45   for scalar SELE
0d10: 43 54 73 20 74 68 61 74 20 61 72 65 20 70 61 72  CTs that are par
0d20: 74 20 6f 66 20 61 6e 20 65 78 70 72 65 73 73 69  t of an expressi
0d30: 6f 6e 2e 0a 2a 2a 20 49 66 20 69 74 20 66 69 6e  on..** If it fin
0d40: 64 73 20 61 6e 79 2c 20 69 74 20 67 65 6e 65 72  ds any, it gener
0d50: 61 74 65 73 20 63 6f 64 65 20 74 6f 20 77 72 69  ates code to wri
0d60: 74 65 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20  te the value of 
0d70: 74 68 61 74 20 73 65 6c 65 63 74 0a 2a 2a 20 69  that select.** i
0d80: 6e 74 6f 20 61 20 6d 65 6d 6f 72 79 20 63 65 6c  nto a memory cel
0d90: 6c 2e 0a 2a 2a 0a 2a 2a 20 55 6e 6b 6e 6f 77 6e  l..**.** Unknown
0da0: 20 63 6f 6c 75 6d 6e 73 20 6f 72 20 74 61 62 6c   columns or tabl
0db0: 65 73 20 70 72 6f 76 6f 6b 65 20 61 6e 20 65 72  es provoke an er
0dc0: 72 6f 72 2e 20 20 54 68 65 20 66 75 6e 63 74 69  ror.  The functi
0dd0: 6f 6e 20 72 65 74 75 72 6e 73 0a 2a 2a 20 74 68  on returns.** th
0de0: 65 20 6e 75 6d 62 65 72 20 6f 66 20 65 72 72 6f  e number of erro
0df0: 72 73 20 73 65 65 6e 20 61 6e 64 20 6c 65 61 76  rs seen and leav
0e00: 65 73 20 61 6e 20 65 72 72 6f 72 20 6d 65 73 73  es an error mess
0e10: 61 67 65 20 6f 6e 20 70 50 61 72 73 65 2d 3e 7a  age on pParse->z
0e20: 45 72 72 4d 73 67 2e 0a 2a 2f 0a 69 6e 74 20 73  ErrMsg..*/.int s
0e30: 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65  qliteExprResolve
0e40: 49 64 73 28 50 61 72 73 65 20 2a 70 50 61 72 73  Ids(Parse *pPars
0e50: 65 2c 20 49 64 4c 69 73 74 20 2a 70 54 61 62 4c  e, IdList *pTabL
0e60: 69 73 74 2c 20 45 78 70 72 20 2a 70 45 78 70 72  ist, Expr *pExpr
0e70: 29 7b 0a 20 20 69 66 28 20 70 45 78 70 72 3d 3d  ){.  if( pExpr==
0e80: 30 20 7c 7c 20 70 54 61 62 4c 69 73 74 3d 3d 30  0 || pTabList==0
0e90: 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 73   ) return 0;.  s
0ea0: 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70  witch( pExpr->op
0eb0: 20 29 7b 0a 20 20 20 20 2f 2a 20 41 20 6c 6f 6e   ){.    /* A lon
0ec0: 65 20 69 64 65 6e 74 69 66 69 65 72 20 2a 2f 0a  e identifier */.
0ed0: 20 20 20 20 63 61 73 65 20 54 4b 5f 49 44 3a 20      case TK_ID: 
0ee0: 7b 0a 20 20 20 20 20 20 69 6e 74 20 63 6e 74 20  {.      int cnt 
0ef0: 3d 20 30 3b 20 20 20 20 20 20 2f 2a 20 4e 75 6d  = 0;      /* Num
0f00: 62 65 72 20 6f 66 20 6d 61 74 63 68 65 73 20 2a  ber of matches *
0f10: 2f 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 20 20  /.      int i;  
0f20: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4c 6f 6f            /* Loo
0f30: 70 20 63 6f 75 6e 74 65 72 20 2a 2f 0a 20 20 20  p counter */.   
0f40: 20 20 20 63 68 61 72 20 2a 7a 20 3d 20 73 71 6c     char *z = sql
0f50: 69 74 65 53 74 72 4e 44 75 70 28 70 45 78 70 72  iteStrNDup(pExpr
0f60: 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72  ->token.z, pExpr
0f70: 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20  ->token.n);.    
0f80: 20 20 69 66 28 20 7a 3d 3d 30 20 29 20 72 65 74    if( z==0 ) ret
0f90: 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 66 6f 72  urn 1;.      for
0fa0: 28 69 3d 30 3b 20 69 3c 70 54 61 62 4c 69 73 74  (i=0; i<pTabList
0fb0: 2d 3e 6e 49 64 3b 20 69 2b 2b 29 7b 0a 20 20 20  ->nId; i++){.   
0fc0: 20 20 20 20 20 69 6e 74 20 6a 3b 0a 20 20 20 20       int j;.    
0fd0: 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 20      Table *pTab 
0fe0: 3d 20 70 54 61 62 4c 69 73 74 2d 3e 61 5b 69 5d  = pTabList->a[i]
0ff0: 2e 70 54 61 62 3b 0a 20 20 20 20 20 20 20 20 69  .pTab;.        i
1000: 66 28 20 70 54 61 62 3d 3d 30 20 29 20 63 6f 6e  f( pTab==0 ) con
1010: 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20 66  tinue;.        f
1020: 6f 72 28 6a 3d 30 3b 20 6a 3c 70 54 61 62 2d 3e  or(j=0; j<pTab->
1030: 6e 43 6f 6c 3b 20 6a 2b 2b 29 7b 0a 20 20 20 20  nCol; j++){.    
1040: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
1050: 53 74 72 49 43 6d 70 28 70 54 61 62 2d 3e 61 43  StrICmp(pTab->aC
1060: 6f 6c 5b 6a 5d 2e 7a 4e 61 6d 65 2c 20 7a 29 3d  ol[j].zName, z)=
1070: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
1080: 20 20 63 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20    cnt++;.       
1090: 20 20 20 20 20 70 45 78 70 72 2d 3e 69 54 61 62       pExpr->iTab
10a0: 6c 65 20 3d 20 69 20 2b 20 70 50 61 72 73 65 2d  le = i + pParse-
10b0: 3e 6e 54 61 62 3b 0a 20 20 20 20 20 20 20 20 20  >nTab;.         
10c0: 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d     pExpr->iColum
10d0: 6e 20 3d 20 6a 3b 0a 20 20 20 20 20 20 20 20 20  n = j;.         
10e0: 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20   }.        }.   
10f0: 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20 63     }.      if( c
1100: 6e 74 3d 3d 30 20 26 26 20 73 71 6c 69 74 65 49  nt==0 && sqliteI
1110: 73 52 6f 77 69 64 28 7a 29 20 29 7b 0a 20 20 20  sRowid(z) ){.   
1120: 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c       pExpr->iCol
1130: 75 6d 6e 20 3d 20 2d 31 3b 0a 20 20 20 20 20 20  umn = -1;.      
1140: 20 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20    pExpr->iTable 
1150: 3d 20 70 50 61 72 73 65 2d 3e 6e 54 61 62 3b 0a  = pParse->nTab;.
1160: 20 20 20 20 20 20 20 20 63 6e 74 20 3d 20 31 20          cnt = 1 
1170: 2b 20 28 70 54 61 62 4c 69 73 74 2d 3e 6e 49 64  + (pTabList->nId
1180: 3e 31 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  >1);.      }.   
1190: 20 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a 29     sqliteFree(z)
11a0: 3b 0a 20 20 20 20 20 20 69 66 28 20 63 6e 74 3d  ;.      if( cnt=
11b0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71  =0 ){.        sq
11c0: 6c 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28 26  liteSetNString(&
11d0: 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 2c  pParse->zErrMsg,
11e0: 20 22 6e 6f 20 73 75 63 68 20 63 6f 6c 75 6d 6e   "no such column
11f0: 3a 20 22 2c 20 2d 31 2c 20 20 0a 20 20 20 20 20  : ", -1,  .     
1200: 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b 65       pExpr->toke
1210: 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65  n.z, pExpr->toke
1220: 6e 2e 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  n.n, 0);.       
1230: 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b   pParse->nErr++;
1240: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
1250: 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  1;.      }else i
1260: 66 28 20 63 6e 74 3e 31 20 29 7b 0a 20 20 20 20  f( cnt>1 ){.    
1270: 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53 74      sqliteSetNSt
1280: 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a 45  ring(&pParse->zE
1290: 72 72 4d 73 67 2c 20 22 61 6d 62 69 67 75 6f 75  rrMsg, "ambiguou
12a0: 73 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 3a 20 22  s column name: "
12b0: 2c 20 2d 31 2c 20 20 0a 20 20 20 20 20 20 20 20  , -1,  .        
12c0: 20 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a    pExpr->token.z
12d0: 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e  , pExpr->token.n
12e0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50  , 0);.        pP
12f0: 61 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20  arse->nErr++;.  
1300: 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a        return 1;.
1310: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 70 45        }.      pE
1320: 78 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 43 4f 4c  xpr->op = TK_COL
1330: 55 4d 4e 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  UMN;.      break
1340: 3b 20 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20  ; .    }.  .    
1350: 2f 2a 20 41 20 74 61 62 6c 65 20 6e 61 6d 65 20  /* A table name 
1360: 61 6e 64 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 3a  and column name:
1370: 20 20 49 44 2e 49 44 20 2a 2f 0a 20 20 20 20 63    ID.ID */.    c
1380: 61 73 65 20 54 4b 5f 44 4f 54 3a 20 7b 0a 20 20  ase TK_DOT: {.  
1390: 20 20 20 20 69 6e 74 20 63 6e 74 20 3d 20 30 3b      int cnt = 0;
13a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
13b0: 4e 75 6d 62 65 72 20 6f 66 20 6d 61 74 63 68 65  Number of matche
13c0: 73 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 63  s */.      int c
13d0: 6e 74 54 61 62 20 3d 20 30 3b 20 20 20 20 20 20  ntTab = 0;      
13e0: 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66      /* Number of
13f0: 20 6d 61 74 63 68 69 6e 67 20 74 61 62 6c 65 73   matching tables
1400: 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 69 3b   */.      int i;
1410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1420: 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74     /* Loop count
1430: 65 72 20 2a 2f 0a 20 20 20 20 20 20 45 78 70 72  er */.      Expr
1440: 20 2a 70 4c 65 66 74 2c 20 2a 70 52 69 67 68 74   *pLeft, *pRight
1450: 3b 20 20 20 20 2f 2a 20 4c 65 66 74 20 61 6e 64  ;    /* Left and
1460: 20 72 69 67 68 74 20 73 75 62 62 72 61 6e 63 68   right subbranch
1470: 65 73 20 6f 66 20 74 68 65 20 65 78 70 72 20 2a  es of the expr *
1480: 2f 0a 20 20 20 20 20 20 63 68 61 72 20 2a 7a 4c  /.      char *zL
1490: 65 66 74 2c 20 2a 7a 52 69 67 68 74 3b 20 20 20  eft, *zRight;   
14a0: 20 2f 2a 20 54 65 78 74 20 6f 66 20 61 6e 20 69   /* Text of an i
14b0: 64 65 6e 74 69 66 69 65 72 20 2a 2f 0a 0a 20 20  dentifier */..  
14c0: 20 20 20 20 70 4c 65 66 74 20 3d 20 70 45 78 70      pLeft = pExp
14d0: 72 2d 3e 70 4c 65 66 74 3b 0a 20 20 20 20 20 20  r->pLeft;.      
14e0: 70 52 69 67 68 74 20 3d 20 70 45 78 70 72 2d 3e  pRight = pExpr->
14f0: 70 52 69 67 68 74 3b 0a 20 20 20 20 20 20 61 73  pRight;.      as
1500: 73 65 72 74 28 20 70 4c 65 66 74 20 26 26 20 70  sert( pLeft && p
1510: 4c 65 66 74 2d 3e 6f 70 3d 3d 54 4b 5f 49 44 20  Left->op==TK_ID 
1520: 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28  );.      assert(
1530: 20 70 52 69 67 68 74 20 26 26 20 70 52 69 67 68   pRight && pRigh
1540: 74 2d 3e 6f 70 3d 3d 54 4b 5f 49 44 20 29 3b 0a  t->op==TK_ID );.
1550: 20 20 20 20 20 20 7a 4c 65 66 74 20 3d 20 73 71        zLeft = sq
1560: 6c 69 74 65 53 74 72 4e 44 75 70 28 70 4c 65 66  liteStrNDup(pLef
1570: 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 4c 65 66  t->token.z, pLef
1580: 74 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20  t->token.n);.   
1590: 20 20 20 7a 52 69 67 68 74 20 3d 20 73 71 6c 69     zRight = sqli
15a0: 74 65 53 74 72 4e 44 75 70 28 70 52 69 67 68 74  teStrNDup(pRight
15b0: 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 52 69 67 68  ->token.z, pRigh
15c0: 74 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20  t->token.n);.   
15d0: 20 20 20 69 66 28 20 7a 4c 65 66 74 3d 3d 30 20     if( zLeft==0 
15e0: 7c 7c 20 7a 52 69 67 68 74 3d 3d 30 20 29 7b 0a  || zRight==0 ){.
15f0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 46 72          sqliteFr
1600: 65 65 28 7a 4c 65 66 74 29 3b 0a 20 20 20 20 20  ee(zLeft);.     
1610: 20 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a 52     sqliteFree(zR
1620: 69 67 68 74 29 3b 0a 20 20 20 20 20 20 20 20 72  ight);.        r
1630: 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 7d  eturn 1;.      }
1640: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 44 65 71  .      sqliteDeq
1650: 75 6f 74 65 28 7a 4c 65 66 74 29 3b 0a 20 20 20  uote(zLeft);.   
1660: 20 20 20 73 71 6c 69 74 65 44 65 71 75 6f 74 65     sqliteDequote
1670: 28 7a 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20  (zRight);.      
1680: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20  pExpr->iTable = 
1690: 2d 31 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d  -1;.      for(i=
16a0: 30 3b 20 69 3c 70 54 61 62 4c 69 73 74 2d 3e 6e  0; i<pTabList->n
16b0: 49 64 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  Id; i++){.      
16c0: 20 20 69 6e 74 20 6a 3b 0a 20 20 20 20 20 20 20    int j;.       
16d0: 20 63 68 61 72 20 2a 7a 54 61 62 3b 0a 20 20 20   char *zTab;.   
16e0: 20 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62       Table *pTab
16f0: 20 3d 20 70 54 61 62 4c 69 73 74 2d 3e 61 5b 69   = pTabList->a[i
1700: 5d 2e 70 54 61 62 3b 0a 20 20 20 20 20 20 20 20  ].pTab;.        
1710: 69 66 28 20 70 54 61 62 3d 3d 30 20 29 20 63 6f  if( pTab==0 ) co
1720: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20  ntinue;.        
1730: 69 66 28 20 70 54 61 62 4c 69 73 74 2d 3e 61 5b  if( pTabList->a[
1740: 69 5d 2e 7a 41 6c 69 61 73 20 29 7b 0a 20 20 20  i].zAlias ){.   
1750: 20 20 20 20 20 20 20 7a 54 61 62 20 3d 20 70 54         zTab = pT
1760: 61 62 4c 69 73 74 2d 3e 61 5b 69 5d 2e 7a 41 6c  abList->a[i].zAl
1770: 69 61 73 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c  ias;.        }el
1780: 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 7a 54  se{.          zT
1790: 61 62 20 3d 20 70 54 61 62 2d 3e 7a 4e 61 6d 65  ab = pTab->zName
17a0: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
17b0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 53 74      if( sqliteSt
17c0: 72 49 43 6d 70 28 7a 54 61 62 2c 20 7a 4c 65 66  rICmp(zTab, zLef
17d0: 74 29 21 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  t)!=0 ) continue
17e0: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 30 3d  ;.        if( 0=
17f0: 3d 28 63 6e 74 54 61 62 2b 2b 29 20 29 20 70 45  =(cntTab++) ) pE
1800: 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20 69 20  xpr->iTable = i 
1810: 2b 20 70 50 61 72 73 65 2d 3e 6e 54 61 62 3b 0a  + pParse->nTab;.
1820: 20 20 20 20 20 20 20 20 66 6f 72 28 6a 3d 30 3b          for(j=0;
1830: 20 6a 3c 70 54 61 62 2d 3e 6e 43 6f 6c 3b 20 6a   j<pTab->nCol; j
1840: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69  ++){.          i
1850: 66 28 20 73 71 6c 69 74 65 53 74 72 49 43 6d 70  f( sqliteStrICmp
1860: 28 70 54 61 62 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a  (pTab->aCol[j].z
1870: 4e 61 6d 65 2c 20 7a 52 69 67 68 74 29 3d 3d 30  Name, zRight)==0
1880: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
1890: 63 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20 20  cnt++;.         
18a0: 20 20 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65     pExpr->iTable
18b0: 20 3d 20 69 20 2b 20 70 50 61 72 73 65 2d 3e 6e   = i + pParse->n
18c0: 54 61 62 3b 0a 20 20 20 20 20 20 20 20 20 20 20  Tab;.           
18d0: 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20   pExpr->iColumn 
18e0: 3d 20 6a 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  = j;.          }
18f0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
1900: 20 7d 0a 20 20 20 20 20 20 69 66 28 20 63 6e 74   }.      if( cnt
1910: 3d 3d 30 20 26 26 20 63 6e 74 54 61 62 3d 3d 31  ==0 && cntTab==1
1920: 20 26 26 20 73 71 6c 69 74 65 49 73 52 6f 77 69   && sqliteIsRowi
1930: 64 28 7a 52 69 67 68 74 29 20 29 7b 0a 20 20 20  d(zRight) ){.   
1940: 20 20 20 20 20 63 6e 74 20 3d 20 31 3b 0a 20 20       cnt = 1;.  
1950: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f        pExpr->iCo
1960: 6c 75 6d 6e 20 3d 20 2d 31 3b 0a 20 20 20 20 20  lumn = -1;.     
1970: 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 46   }.      sqliteF
1980: 72 65 65 28 7a 4c 65 66 74 29 3b 0a 20 20 20 20  ree(zLeft);.    
1990: 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a 52 69    sqliteFree(zRi
19a0: 67 68 74 29 3b 0a 20 20 20 20 20 20 69 66 28 20  ght);.      if( 
19b0: 63 6e 74 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  cnt==0 ){.      
19c0: 20 20 73 71 6c 69 74 65 53 65 74 4e 53 74 72 69    sqliteSetNStri
19d0: 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a 45 72 72  ng(&pParse->zErr
19e0: 4d 73 67 2c 20 22 6e 6f 20 73 75 63 68 20 63 6f  Msg, "no such co
19f0: 6c 75 6d 6e 3a 20 22 2c 20 2d 31 2c 20 20 0a 20  lumn: ", -1,  . 
1a00: 20 20 20 20 20 20 20 20 20 70 4c 65 66 74 2d 3e           pLeft->
1a10: 74 6f 6b 65 6e 2e 7a 2c 20 70 4c 65 66 74 2d 3e  token.z, pLeft->
1a20: 74 6f 6b 65 6e 2e 6e 2c 20 22 2e 22 2c 20 31 2c  token.n, ".", 1,
1a30: 20 0a 20 20 20 20 20 20 20 20 20 20 70 52 69 67   .          pRig
1a40: 68 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 52 69  ht->token.z, pRi
1a50: 67 68 74 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 30 29  ght->token.n, 0)
1a60: 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72 73 65  ;.        pParse
1a70: 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20 20 20 20  ->nErr++;.      
1a80: 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20    return 1;.    
1a90: 20 20 7d 65 6c 73 65 20 69 66 28 20 63 6e 74 3e    }else if( cnt>
1aa0: 31 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  1 ){.        sql
1ab0: 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28 26 70  iteSetNString(&p
1ac0: 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 2c 20  Parse->zErrMsg, 
1ad0: 22 61 6d 62 69 67 75 6f 75 73 20 63 6f 6c 75 6d  "ambiguous colum
1ae0: 6e 20 6e 61 6d 65 3a 20 22 2c 20 2d 31 2c 20 20  n name: ", -1,  
1af0: 0a 20 20 20 20 20 20 20 20 20 20 70 4c 65 66 74  .          pLeft
1b00: 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 4c 65 66 74  ->token.z, pLeft
1b10: 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 22 2e 22 2c 20  ->token.n, ".", 
1b20: 31 2c 0a 20 20 20 20 20 20 20 20 20 20 70 52 69  1,.          pRi
1b30: 67 68 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 52  ght->token.z, pR
1b40: 69 67 68 74 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 30  ight->token.n, 0
1b50: 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72 73  );.        pPars
1b60: 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20 20 20  e->nErr++;.     
1b70: 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20     return 1;.   
1b80: 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74     }.      sqlit
1b90: 65 45 78 70 72 44 65 6c 65 74 65 28 70 4c 65 66  eExprDelete(pLef
1ba0: 74 29 3b 0a 20 20 20 20 20 20 70 45 78 70 72 2d  t);.      pExpr-
1bb0: 3e 70 4c 65 66 74 20 3d 20 30 3b 0a 20 20 20 20  >pLeft = 0;.    
1bc0: 20 20 73 71 6c 69 74 65 45 78 70 72 44 65 6c 65    sqliteExprDele
1bd0: 74 65 28 70 52 69 67 68 74 29 3b 0a 20 20 20 20  te(pRight);.    
1be0: 20 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 20    pExpr->pRight 
1bf0: 3d 20 30 3b 0a 20 20 20 20 20 20 70 45 78 70 72  = 0;.      pExpr
1c00: 2d 3e 6f 70 20 3d 20 54 4b 5f 43 4f 4c 55 4d 4e  ->op = TK_COLUMN
1c10: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
1c20: 20 20 20 7d 0a 0a 20 20 20 20 63 61 73 65 20 54     }..    case T
1c30: 4b 5f 49 4e 3a 20 7b 0a 20 20 20 20 20 20 56 64  K_IN: {.      Vd
1c40: 62 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 47 65  be *v = sqliteGe
1c50: 74 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a 20  tVdbe(pParse);. 
1c60: 20 20 20 20 20 69 66 28 20 76 3d 3d 30 20 29 20       if( v==0 ) 
1c70: 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20  return 1;.      
1c80: 69 66 28 20 73 71 6c 69 74 65 45 78 70 72 52 65  if( sqliteExprRe
1c90: 73 6f 6c 76 65 49 64 73 28 70 50 61 72 73 65 2c  solveIds(pParse,
1ca0: 20 70 54 61 62 4c 69 73 74 2c 20 70 45 78 70 72   pTabList, pExpr
1cb0: 2d 3e 70 4c 65 66 74 29 20 29 7b 0a 20 20 20 20  ->pLeft) ){.    
1cc0: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
1cd0: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
1ce0: 70 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 20 29  pExpr->pSelect )
1cf0: 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20 43 61 73  {.        /* Cas
1d00: 65 20 31 3a 20 20 20 20 20 65 78 70 72 20 49 4e  e 1:     expr IN
1d10: 20 28 53 45 4c 45 43 54 20 2e 2e 2e 29 0a 20 20   (SELECT ...).  
1d20: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20        **.       
1d30: 20 2a 2a 20 47 65 6e 65 72 61 74 65 20 63 6f 64   ** Generate cod
1d40: 65 20 74 6f 20 77 72 69 74 65 20 74 68 65 20 72  e to write the r
1d50: 65 73 75 6c 74 73 20 6f 66 20 74 68 65 20 73 65  esults of the se
1d60: 6c 65 63 74 20 69 6e 74 6f 20 61 20 74 65 6d 70  lect into a temp
1d70: 6f 72 61 72 79 0a 20 20 20 20 20 20 20 20 2a 2a  orary.        **
1d80: 20 74 61 62 6c 65 2e 20 20 54 68 65 20 63 75 72   table.  The cur
1d90: 73 6f 72 20 6e 75 6d 62 65 72 20 6f 66 20 74 68  sor number of th
1da0: 65 20 74 65 6d 70 6f 72 61 72 79 20 74 61 62 6c  e temporary tabl
1db0: 65 20 68 61 73 20 61 6c 72 65 61 64 79 0a 20 20  e has already.  
1dc0: 20 20 20 20 20 20 2a 2a 20 62 65 65 6e 20 70 75        ** been pu
1dd0: 74 20 69 6e 20 69 54 61 62 6c 65 20 62 79 20 73  t in iTable by s
1de0: 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65  qliteExprResolve
1df0: 49 6e 53 65 6c 65 63 74 28 29 2e 0a 20 20 20 20  InSelect()..    
1e00: 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 20 20 73      */.        s
1e10: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
1e20: 2c 20 4f 50 5f 4f 70 65 6e 54 65 6d 70 2c 20 70  , OP_OpenTemp, p
1e30: 45 78 70 72 2d 3e 69 54 61 62 6c 65 2c 20 30 29  Expr->iTable, 0)
1e40: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 73 71  ;.        if( sq
1e50: 6c 69 74 65 53 65 6c 65 63 74 28 70 50 61 72 73  liteSelect(pPars
1e60: 65 2c 20 70 45 78 70 72 2d 3e 70 53 65 6c 65 63  e, pExpr->pSelec
1e70: 74 2c 20 53 52 54 5f 53 65 74 2c 20 70 45 78 70  t, SRT_Set, pExp
1e80: 72 2d 3e 69 54 61 62 6c 65 29 20 29 3b 0a 20 20  r->iTable) );.  
1e90: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 70 45      }else if( pE
1ea0: 78 70 72 2d 3e 70 4c 69 73 74 20 29 7b 0a 20 20  xpr->pList ){.  
1eb0: 20 20 20 20 20 20 2f 2a 20 43 61 73 65 20 32 3a        /* Case 2:
1ec0: 20 20 20 20 20 65 78 70 72 20 49 4e 20 28 65 78       expr IN (ex
1ed0: 70 72 6c 69 73 74 29 0a 20 20 20 20 20 20 20 20  prlist).        
1ee0: 2a 2a 0a 20 20 20 20 20 20 20 20 2a 2a 20 43 72  **.        ** Cr
1ef0: 65 61 74 65 20 61 20 73 65 74 20 74 6f 20 70 75  eate a set to pu
1f00: 74 20 74 68 65 20 65 78 70 72 6c 69 73 74 20 76  t the exprlist v
1f10: 61 6c 75 65 73 20 69 6e 2e 20 20 54 68 65 20 53  alues in.  The S
1f20: 65 74 20 69 64 20 69 73 20 73 74 6f 72 65 64 0a  et id is stored.
1f30: 20 20 20 20 20 20 20 20 2a 2a 20 69 6e 20 69 54          ** in iT
1f40: 61 62 6c 65 2e 0a 20 20 20 20 20 20 20 20 2a 2f  able..        */
1f50: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 2c 20  .        int i, 
1f60: 69 53 65 74 3b 0a 20 20 20 20 20 20 20 20 66 6f  iSet;.        fo
1f70: 72 28 69 3d 30 3b 20 69 3c 70 45 78 70 72 2d 3e  r(i=0; i<pExpr->
1f80: 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b  pList->nExpr; i+
1f90: 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 45 78  +){.          Ex
1fa0: 70 72 20 2a 70 45 32 20 3d 20 70 45 78 70 72 2d  pr *pE2 = pExpr-
1fb0: 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78  >pList->a[i].pEx
1fc0: 70 72 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66  pr;.          if
1fd0: 28 20 21 69 73 43 6f 6e 73 74 61 6e 74 28 70 45  ( !isConstant(pE
1fe0: 32 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  2) ){.          
1ff0: 20 20 73 71 6c 69 74 65 53 65 74 53 74 72 69 6e    sqliteSetStrin
2000: 67 28 26 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d  g(&pParse->zErrM
2010: 73 67 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  sg,.            
2020: 20 20 22 72 69 67 68 74 2d 68 61 6e 64 20 73 69    "right-hand si
2030: 64 65 20 6f 66 20 49 4e 20 6f 70 65 72 61 74 6f  de of IN operato
2040: 72 20 6d 75 73 74 20 62 65 20 63 6f 6e 73 74 61  r must be consta
2050: 6e 74 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  nt", 0);.       
2060: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72       pParse->nEr
2070: 72 2b 2b 3b 0a 20 20 20 20 20 20 20 20 20 20 20  r++;.           
2080: 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20   return 1;.     
2090: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
20a0: 20 69 66 28 20 73 71 6c 69 74 65 45 78 70 72 43   if( sqliteExprC
20b0: 68 65 63 6b 28 70 50 61 72 73 65 2c 20 70 45 32  heck(pParse, pE2
20c0: 2c 20 30 2c 20 30 29 20 29 7b 0a 20 20 20 20 20  , 0, 0) ){.     
20d0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b         return 1;
20e0: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
20f0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69       }.        i
2100: 53 65 74 20 3d 20 70 45 78 70 72 2d 3e 69 54 61  Set = pExpr->iTa
2110: 62 6c 65 20 3d 20 70 50 61 72 73 65 2d 3e 6e 53  ble = pParse->nS
2120: 65 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20 66 6f  et++;.        fo
2130: 72 28 69 3d 30 3b 20 69 3c 70 45 78 70 72 2d 3e  r(i=0; i<pExpr->
2140: 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b  pList->nExpr; i+
2150: 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 45 78  +){.          Ex
2160: 70 72 20 2a 70 45 32 20 3d 20 70 45 78 70 72 2d  pr *pE2 = pExpr-
2170: 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78  >pList->a[i].pEx
2180: 70 72 3b 0a 20 20 20 20 20 20 20 20 20 20 73 77  pr;.          sw
2190: 69 74 63 68 28 20 70 45 32 2d 3e 6f 70 20 29 7b  itch( pE2->op ){
21a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 61 73  .            cas
21b0: 65 20 54 4b 5f 46 4c 4f 41 54 3a 0a 20 20 20 20  e TK_FLOAT:.    
21c0: 20 20 20 20 20 20 20 20 63 61 73 65 20 54 4b 5f          case TK_
21d0: 49 4e 54 45 47 45 52 3a 0a 20 20 20 20 20 20 20  INTEGER:.       
21e0: 20 20 20 20 20 63 61 73 65 20 54 4b 5f 53 54 52       case TK_STR
21f0: 49 4e 47 3a 20 7b 0a 20 20 20 20 20 20 20 20 20  ING: {.         
2200: 20 20 20 20 20 69 6e 74 20 61 64 64 72 20 3d 20       int addr = 
2210: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
2220: 76 2c 20 4f 50 5f 53 65 74 49 6e 73 65 72 74 2c  v, OP_SetInsert,
2230: 20 69 53 65 74 2c 20 30 29 3b 0a 20 20 20 20 20   iSet, 0);.     
2240: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56           sqliteV
2250: 64 62 65 43 68 61 6e 67 65 50 33 28 76 2c 20 61  dbeChangeP3(v, a
2260: 64 64 72 2c 20 70 45 32 2d 3e 74 6f 6b 65 6e 2e  ddr, pE2->token.
2270: 7a 2c 20 70 45 32 2d 3e 74 6f 6b 65 6e 2e 6e 29  z, pE2->token.n)
2280: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
2290: 73 71 6c 69 74 65 56 64 62 65 44 65 71 75 6f 74  sqliteVdbeDequot
22a0: 65 50 33 28 76 2c 20 61 64 64 72 29 3b 0a 20 20  eP3(v, addr);.  
22b0: 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61              brea
22c0: 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  k;.            }
22d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 64 65 66  .            def
22e0: 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20 20 20  ault: {.        
22f0: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
2300: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 32  Code(pParse, pE2
2310: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
2320: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
2330: 28 76 2c 20 4f 50 5f 53 65 74 49 6e 73 65 72 74  (v, OP_SetInsert
2340: 2c 20 69 53 65 74 2c 20 30 29 3b 0a 20 20 20 20  , iSet, 0);.    
2350: 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b            break;
2360: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
2370: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
2380: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
2390: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
23a0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 53 45 4c  .    case TK_SEL
23b0: 45 43 54 3a 20 7b 0a 20 20 20 20 20 20 2f 2a 20  ECT: {.      /* 
23c0: 54 68 69 73 20 68 61 73 20 74 6f 20 62 65 20 61  This has to be a
23d0: 20 73 63 61 6c 61 72 20 53 45 4c 45 43 54 2e 20   scalar SELECT. 
23e0: 20 47 65 6e 65 72 61 74 65 20 63 6f 64 65 20 74   Generate code t
23f0: 6f 20 70 75 74 20 74 68 65 0a 20 20 20 20 20 20  o put the.      
2400: 2a 2a 20 76 61 6c 75 65 20 6f 66 20 74 68 69 73  ** value of this
2410: 20 73 65 6c 65 63 74 20 69 6e 20 61 20 6d 65 6d   select in a mem
2420: 6f 72 79 20 63 65 6c 6c 20 61 6e 64 20 72 65 63  ory cell and rec
2430: 6f 72 64 20 74 68 65 20 6e 75 6d 62 65 72 0a 20  ord the number. 
2440: 20 20 20 20 20 2a 2a 20 6f 66 20 74 68 65 20 6d       ** of the m
2450: 65 6d 6f 72 79 20 63 65 6c 6c 20 69 6e 20 69 43  emory cell in iC
2460: 6f 6c 75 6d 6e 2e 0a 20 20 20 20 20 20 2a 2f 0a  olumn..      */.
2470: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f        pExpr->iCo
2480: 6c 75 6d 6e 20 3d 20 70 50 61 72 73 65 2d 3e 6e  lumn = pParse->n
2490: 4d 65 6d 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28  Mem++;.      if(
24a0: 20 73 71 6c 69 74 65 53 65 6c 65 63 74 28 70 50   sqliteSelect(pP
24b0: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 53 65  arse, pExpr->pSe
24c0: 6c 65 63 74 2c 20 53 52 54 5f 4d 65 6d 2c 20 70  lect, SRT_Mem, p
24d0: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 29 20 29  Expr->iColumn) )
24e0: 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  {.        return
24f0: 20 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20   1;.      }.    
2500: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a    break;.    }..
2510: 20 20 20 20 2f 2a 20 46 6f 72 20 61 6c 6c 20 65      /* For all e
2520: 6c 73 65 2c 20 6a 75 73 74 20 72 65 63 75 72 73  lse, just recurs
2530: 69 76 65 6c 79 20 77 61 6c 6b 20 74 68 65 20 74  ively walk the t
2540: 72 65 65 20 2a 2f 0a 20 20 20 20 64 65 66 61 75  ree */.    defau
2550: 6c 74 3a 20 7b 0a 20 20 20 20 20 20 69 66 28 20  lt: {.      if( 
2560: 70 45 78 70 72 2d 3e 70 4c 65 66 74 0a 20 20 20  pExpr->pLeft.   
2570: 20 20 20 26 26 20 73 71 6c 69 74 65 45 78 70 72     && sqliteExpr
2580: 52 65 73 6f 6c 76 65 49 64 73 28 70 50 61 72 73  ResolveIds(pPars
2590: 65 2c 20 70 54 61 62 4c 69 73 74 2c 20 70 45 78  e, pTabList, pEx
25a0: 70 72 2d 3e 70 4c 65 66 74 29 20 29 7b 0a 20 20  pr->pLeft) ){.  
25b0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a        return 1;.
25c0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
25d0: 28 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 20  ( pExpr->pRight 
25e0: 0a 20 20 20 20 20 20 26 26 20 73 71 6c 69 74 65  .      && sqlite
25f0: 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73 28 70  ExprResolveIds(p
2600: 50 61 72 73 65 2c 20 70 54 61 62 4c 69 73 74 2c  Parse, pTabList,
2610: 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 20   pExpr->pRight) 
2620: 29 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  ){.        retur
2630: 6e 20 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n 1;.      }.   
2640: 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 70 4c     if( pExpr->pL
2650: 69 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20 69  ist ){.        i
2660: 6e 74 20 69 3b 0a 20 20 20 20 20 20 20 20 45 78  nt i;.        Ex
2670: 70 72 4c 69 73 74 20 2a 70 4c 69 73 74 20 3d 20  prList *pList = 
2680: 70 45 78 70 72 2d 3e 70 4c 69 73 74 3b 0a 20 20  pExpr->pList;.  
2690: 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69        for(i=0; i
26a0: 3c 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69  <pList->nExpr; i
26b0: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69  ++){.          i
26c0: 66 28 20 73 71 6c 69 74 65 45 78 70 72 52 65 73  f( sqliteExprRes
26d0: 6f 6c 76 65 49 64 73 28 70 50 61 72 73 65 2c 20  olveIds(pParse, 
26e0: 70 54 61 62 4c 69 73 74 2c 20 70 4c 69 73 74 2d  pTabList, pList-
26f0: 3e 61 5b 69 5d 2e 70 45 78 70 72 29 20 29 7b 0a  >a[i].pExpr) ){.
2700: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
2710: 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20  rn 1;.          
2720: 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  }.        }.    
2730: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20    }.    }.  }.  
2740: 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 23 69 66  return 0;.}..#if
2750: 20 30 20 2f 2a 20 4e 4f 54 20 55 53 45 44 20 2a   0 /* NOT USED *
2760: 2f 0a 2f 2a 0a 2a 2a 20 43 6f 6d 70 61 72 65 20  /./*.** Compare 
2770: 61 20 74 6f 6b 65 6e 20 61 67 61 69 6e 73 74 20  a token against 
2780: 61 20 73 74 72 69 6e 67 2e 20 20 52 65 74 75 72  a string.  Retur
2790: 6e 20 54 52 55 45 20 69 66 20 74 68 65 79 20 6d  n TRUE if they m
27a0: 61 74 63 68 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  atch..*/.static 
27b0: 69 6e 74 20 73 71 6c 69 74 65 54 6f 6b 65 6e 43  int sqliteTokenC
27c0: 6d 70 28 54 6f 6b 65 6e 20 2a 70 54 6f 6b 65 6e  mp(Token *pToken
27d0: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53  , const char *zS
27e0: 74 72 29 7b 0a 20 20 69 6e 74 20 6e 20 3d 20 73  tr){.  int n = s
27f0: 74 72 6c 65 6e 28 7a 53 74 72 29 3b 0a 20 20 69  trlen(zStr);.  i
2800: 66 28 20 6e 21 3d 70 54 6f 6b 65 6e 2d 3e 6e 20  f( n!=pToken->n 
2810: 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 72 65  ) return 0;.  re
2820: 74 75 72 6e 20 73 71 6c 69 74 65 53 74 72 4e 49  turn sqliteStrNI
2830: 43 6d 70 28 70 54 6f 6b 65 6e 2d 3e 7a 2c 20 7a  Cmp(pToken->z, z
2840: 53 74 72 2c 20 6e 29 3d 3d 30 3b 0a 7d 0a 23 65  Str, n)==0;.}.#e
2850: 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 76  ndif../*.** Conv
2860: 65 72 74 20 61 20 66 75 6e 63 74 69 6f 6e 20 6e  ert a function n
2870: 61 6d 65 20 69 6e 74 6f 20 69 74 73 20 69 6e 74  ame into its int
2880: 65 67 65 72 20 69 64 65 6e 74 69 66 69 65 72 2e  eger identifier.
2890: 20 20 52 65 74 75 72 6e 20 74 68 65 0a 2a 2a 20    Return the.** 
28a0: 69 64 65 6e 74 69 66 69 65 72 2e 20 20 52 65 74  identifier.  Ret
28b0: 75 72 6e 20 46 4e 5f 55 6e 6b 6e 6f 77 6e 20 69  urn FN_Unknown i
28c0: 66 20 74 68 65 20 66 75 6e 63 74 69 6f 6e 20 6e  f the function n
28d0: 61 6d 65 20 69 73 20 75 6e 6b 6e 6f 77 6e 2e 0a  ame is unknown..
28e0: 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 46 75 6e  */.int sqliteFun
28f0: 63 49 64 28 54 6f 6b 65 6e 20 2a 70 54 6f 6b 65  cId(Token *pToke
2900: 6e 29 7b 0a 20 20 73 74 61 74 69 63 20 63 6f 6e  n){.  static con
2910: 73 74 20 73 74 72 75 63 74 20 7b 0a 20 20 20 20  st struct {.    
2920: 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 0a 20 20   char *zName;.  
2930: 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20     int len;.    
2940: 20 69 6e 74 20 69 64 3b 0a 20 20 7d 20 61 46 75   int id;.  } aFu
2950: 6e 63 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 7b 20  nc[] = {.     { 
2960: 22 63 6f 75 6e 74 22 2c 20 20 35 2c 20 46 4e 5f  "count",  5, FN_
2970: 43 6f 75 6e 74 20 7d 2c 0a 20 20 20 20 20 7b 20  Count },.     { 
2980: 22 6d 69 6e 22 2c 20 20 20 20 33 2c 20 46 4e 5f  "min",    3, FN_
2990: 4d 69 6e 20 20 20 7d 2c 0a 20 20 20 20 20 7b 20  Min   },.     { 
29a0: 22 6d 61 78 22 2c 20 20 20 20 33 2c 20 46 4e 5f  "max",    3, FN_
29b0: 4d 61 78 20 20 20 7d 2c 0a 20 20 20 20 20 7b 20  Max   },.     { 
29c0: 22 73 75 6d 22 2c 20 20 20 20 33 2c 20 46 4e 5f  "sum",    3, FN_
29d0: 53 75 6d 20 20 20 7d 2c 0a 20 20 20 20 20 7b 20  Sum   },.     { 
29e0: 22 61 76 67 22 2c 20 20 20 20 33 2c 20 46 4e 5f  "avg",    3, FN_
29f0: 41 76 67 20 20 20 7d 2c 0a 20 20 20 20 20 7b 20  Avg   },.     { 
2a00: 22 66 63 6e 74 22 2c 20 20 20 34 2c 20 46 4e 5f  "fcnt",   4, FN_
2a10: 46 63 6e 74 20 20 7d 2c 20 20 2f 2a 20 55 73 65  Fcnt  },  /* Use
2a20: 64 20 66 6f 72 20 74 65 73 74 69 6e 67 20 6f 6e  d for testing on
2a30: 6c 79 20 2a 2f 0a 20 20 20 20 20 7b 20 22 6c 65  ly */.     { "le
2a40: 6e 67 74 68 22 2c 20 36 2c 20 46 4e 5f 4c 65 6e  ngth", 6, FN_Len
2a50: 67 74 68 7d 2c 0a 20 20 20 20 20 7b 20 22 73 75  gth},.     { "su
2a60: 62 73 74 72 22 2c 20 36 2c 20 46 4e 5f 53 75 62  bstr", 6, FN_Sub
2a70: 73 74 72 7d 2c 0a 20 20 7d 3b 0a 20 20 69 6e 74  str},.  };.  int
2a80: 20 69 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69   i;.  for(i=0; i
2a90: 3c 41 72 72 61 79 53 69 7a 65 28 61 46 75 6e 63  <ArraySize(aFunc
2aa0: 29 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28  ); i++){.    if(
2ab0: 20 61 46 75 6e 63 5b 69 5d 2e 6c 65 6e 3d 3d 70   aFunc[i].len==p
2ac0: 54 6f 6b 65 6e 2d 3e 6e 20 0a 20 20 20 20 20 26  Token->n .     &
2ad0: 26 20 73 71 6c 69 74 65 53 74 72 4e 49 43 6d 70  & sqliteStrNICmp
2ae0: 28 70 54 6f 6b 65 6e 2d 3e 7a 2c 20 61 46 75 6e  (pToken->z, aFun
2af0: 63 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 61 46 75 6e  c[i].zName, aFun
2b00: 63 5b 69 5d 2e 6c 65 6e 29 3d 3d 30 20 29 7b 0a  c[i].len)==0 ){.
2b10: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 61 46         return aF
2b20: 75 6e 63 5b 69 5d 2e 69 64 3b 0a 20 20 20 20 7d  unc[i].id;.    }
2b30: 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 46 4e  .  }.  return FN
2b40: 5f 55 6e 6b 6e 6f 77 6e 3b 0a 7d 0a 0a 2f 2a 0a  _Unknown;.}../*.
2b50: 2a 2a 20 45 72 72 6f 72 20 63 68 65 63 6b 20 74  ** Error check t
2b60: 68 65 20 66 75 6e 63 74 69 6f 6e 73 20 69 6e 20  he functions in 
2b70: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 2e 20 20  an expression.  
2b80: 4d 61 6b 65 20 73 75 72 65 20 61 6c 6c 0a 2a 2a  Make sure all.**
2b90: 20 66 75 6e 63 74 69 6f 6e 20 6e 61 6d 65 73 20   function names 
2ba0: 61 72 65 20 72 65 63 6f 67 6e 69 7a 65 64 20 61  are recognized a
2bb0: 6e 64 20 61 6c 6c 20 66 75 6e 63 74 69 6f 6e 73  nd all functions
2bc0: 20 68 61 76 65 20 74 68 65 20 63 6f 72 72 65 63   have the correc
2bd0: 74 0a 2a 2a 20 6e 75 6d 62 65 72 20 6f 66 20 61  t.** number of a
2be0: 72 67 75 6d 65 6e 74 73 2e 20 20 4c 65 61 76 65  rguments.  Leave
2bf0: 20 61 6e 20 65 72 72 6f 72 20 6d 65 73 73 61 67   an error messag
2c00: 65 20 69 6e 20 70 50 61 72 73 65 2d 3e 7a 45 72  e in pParse->zEr
2c10: 72 4d 73 67 0a 2a 2a 20 69 66 20 61 6e 79 74 68  rMsg.** if anyth
2c20: 69 6e 67 20 69 73 20 61 6d 69 73 73 2e 20 20 52  ing is amiss.  R
2c30: 65 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72  eturn the number
2c40: 20 6f 66 20 65 72 72 6f 72 73 2e 0a 2a 2a 0a 2a   of errors..**.*
2c50: 2a 20 69 66 20 70 49 73 41 67 67 20 69 73 20 6e  * if pIsAgg is n
2c60: 6f 74 20 6e 75 6c 6c 20 61 6e 64 20 74 68 69 73  ot null and this
2c70: 20 65 78 70 72 65 73 73 69 6f 6e 20 69 73 20 61   expression is a
2c80: 6e 20 61 67 67 72 65 67 61 74 65 20 66 75 6e 63  n aggregate func
2c90: 74 69 6f 6e 0a 2a 2a 20 28 6c 69 6b 65 20 63 6f  tion.** (like co
2ca0: 75 6e 74 28 2a 29 20 6f 72 20 6d 61 78 28 76 61  unt(*) or max(va
2cb0: 6c 75 65 29 29 20 74 68 65 6e 20 77 72 69 74 65  lue)) then write
2cc0: 20 61 20 31 20 69 6e 74 6f 20 2a 70 49 73 41 67   a 1 into *pIsAg
2cd0: 67 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  g..*/.int sqlite
2ce0: 45 78 70 72 43 68 65 63 6b 28 50 61 72 73 65 20  ExprCheck(Parse 
2cf0: 2a 70 50 61 72 73 65 2c 20 45 78 70 72 20 2a 70  *pParse, Expr *p
2d00: 45 78 70 72 2c 20 69 6e 74 20 61 6c 6c 6f 77 41  Expr, int allowA
2d10: 67 67 2c 20 69 6e 74 20 2a 70 49 73 41 67 67 29  gg, int *pIsAgg)
2d20: 7b 0a 20 20 69 6e 74 20 6e 45 72 72 20 3d 20 30  {.  int nErr = 0
2d30: 3b 0a 20 20 69 66 28 20 70 45 78 70 72 3d 3d 30  ;.  if( pExpr==0
2d40: 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 73   ) return 0;.  s
2d50: 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70  witch( pExpr->op
2d60: 20 29 7b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f   ){.    case TK_
2d70: 46 55 4e 43 54 49 4f 4e 3a 20 7b 0a 20 20 20 20  FUNCTION: {.    
2d80: 20 20 69 6e 74 20 69 64 20 3d 20 73 71 6c 69 74    int id = sqlit
2d90: 65 46 75 6e 63 49 64 28 26 70 45 78 70 72 2d 3e  eFuncId(&pExpr->
2da0: 74 6f 6b 65 6e 29 3b 0a 20 20 20 20 20 20 69 6e  token);.      in
2db0: 74 20 6e 20 3d 20 70 45 78 70 72 2d 3e 70 4c 69  t n = pExpr->pLi
2dc0: 73 74 20 3f 20 70 45 78 70 72 2d 3e 70 4c 69 73  st ? pExpr->pLis
2dd0: 74 2d 3e 6e 45 78 70 72 20 3a 20 30 3b 0a 20 20  t->nExpr : 0;.  
2de0: 20 20 20 20 69 6e 74 20 6e 6f 5f 73 75 63 68 5f      int no_such_
2df0: 66 75 6e 63 20 3d 20 30 3b 0a 20 20 20 20 20 20  func = 0;.      
2e00: 69 6e 74 20 74 6f 6f 5f 6d 61 6e 79 5f 61 72 67  int too_many_arg
2e10: 73 20 3d 20 30 3b 0a 20 20 20 20 20 20 69 6e 74  s = 0;.      int
2e20: 20 74 6f 6f 5f 66 65 77 5f 61 72 67 73 20 3d 20   too_few_args = 
2e30: 30 3b 0a 20 20 20 20 20 20 69 6e 74 20 69 73 5f  0;.      int is_
2e40: 61 67 67 20 3d 20 30 3b 0a 20 20 20 20 20 20 69  agg = 0;.      i
2e50: 6e 74 20 69 3b 0a 20 20 20 20 20 20 70 45 78 70  nt i;.      pExp
2e60: 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20 69 64 3b  r->iColumn = id;
2e70: 0a 20 20 20 20 20 20 73 77 69 74 63 68 28 20 69  .      switch( i
2e80: 64 20 29 7b 0a 20 20 20 20 20 20 20 20 63 61 73  d ){.        cas
2e90: 65 20 46 4e 5f 55 6e 6b 6e 6f 77 6e 3a 20 7b 20  e FN_Unknown: { 
2ea0: 0a 20 20 20 20 20 20 20 20 20 20 6e 6f 5f 73 75  .          no_su
2eb0: 63 68 5f 66 75 6e 63 20 3d 20 31 3b 0a 20 20 20  ch_func = 1;.   
2ec0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
2ed0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
2ee0: 63 61 73 65 20 46 4e 5f 43 6f 75 6e 74 3a 20 7b  case FN_Count: {
2ef0: 20 0a 20 20 20 20 20 20 20 20 20 20 6e 6f 5f 73   .          no_s
2f00: 75 63 68 5f 66 75 6e 63 20 3d 20 21 61 6c 6c 6f  uch_func = !allo
2f10: 77 41 67 67 3b 0a 20 20 20 20 20 20 20 20 20 20  wAgg;.          
2f20: 74 6f 6f 5f 6d 61 6e 79 5f 61 72 67 73 20 3d 20  too_many_args = 
2f30: 6e 3e 31 3b 0a 20 20 20 20 20 20 20 20 20 20 69  n>1;.          i
2f40: 73 5f 61 67 67 20 3d 20 31 3b 0a 20 20 20 20 20  s_agg = 1;.     
2f50: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
2f60: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 63 61      }.        ca
2f70: 73 65 20 46 4e 5f 4d 61 78 3a 0a 20 20 20 20 20  se FN_Max:.     
2f80: 20 20 20 63 61 73 65 20 46 4e 5f 4d 69 6e 3a 20     case FN_Min: 
2f90: 7b 0a 20 20 20 20 20 20 20 20 20 20 74 6f 6f 5f  {.          too_
2fa0: 66 65 77 5f 61 72 67 73 20 3d 20 61 6c 6c 6f 77  few_args = allow
2fb0: 41 67 67 20 3f 20 6e 3c 31 20 3a 20 6e 3c 32 3b  Agg ? n<1 : n<2;
2fc0: 0a 20 20 20 20 20 20 20 20 20 20 69 73 5f 61 67  .          is_ag
2fd0: 67 20 3d 20 6e 3d 3d 31 3b 0a 20 20 20 20 20 20  g = n==1;.      
2fe0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20      break;.     
2ff0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 63 61 73     }.        cas
3000: 65 20 46 4e 5f 41 76 67 3a 0a 20 20 20 20 20 20  e FN_Avg:.      
3010: 20 20 63 61 73 65 20 46 4e 5f 53 75 6d 3a 20 7b    case FN_Sum: {
3020: 0a 20 20 20 20 20 20 20 20 20 20 6e 6f 5f 73 75  .          no_su
3030: 63 68 5f 66 75 6e 63 20 3d 20 21 61 6c 6c 6f 77  ch_func = !allow
3040: 41 67 67 3b 0a 20 20 20 20 20 20 20 20 20 20 74  Agg;.          t
3050: 6f 6f 5f 6d 61 6e 79 5f 61 72 67 73 20 3d 20 6e  oo_many_args = n
3060: 3e 31 3b 0a 20 20 20 20 20 20 20 20 20 20 74 6f  >1;.          to
3070: 6f 5f 66 65 77 5f 61 72 67 73 20 3d 20 6e 3c 31  o_few_args = n<1
3080: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 73 5f 61  ;.          is_a
3090: 67 67 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20  gg = 1;.        
30a0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20    break;.       
30b0: 20 7d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20   }.        case 
30c0: 46 4e 5f 4c 65 6e 67 74 68 3a 20 7b 0a 20 20 20  FN_Length: {.   
30d0: 20 20 20 20 20 20 20 74 6f 6f 5f 66 65 77 5f 61         too_few_a
30e0: 72 67 73 20 3d 20 6e 3c 31 3b 0a 20 20 20 20 20  rgs = n<1;.     
30f0: 20 20 20 20 20 74 6f 6f 5f 6d 61 6e 79 5f 61 72       too_many_ar
3100: 67 73 20 3d 20 6e 3e 31 3b 0a 20 20 20 20 20 20  gs = n>1;.      
3110: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20      break;.     
3120: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 63 61 73     }.        cas
3130: 65 20 46 4e 5f 53 75 62 73 74 72 3a 20 7b 0a 20  e FN_Substr: {. 
3140: 20 20 20 20 20 20 20 20 20 74 6f 6f 5f 66 65 77           too_few
3150: 5f 61 72 67 73 20 3d 20 6e 3c 33 3b 0a 20 20 20  _args = n<3;.   
3160: 20 20 20 20 20 20 20 74 6f 6f 5f 6d 61 6e 79 5f         too_many_
3170: 61 72 67 73 20 3d 20 6e 3e 33 3b 0a 20 20 20 20  args = n>3;.    
3180: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
3190: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 2f       }.        /
31a0: 2a 20 54 68 65 20 22 66 63 6e 74 28 2a 29 22 20  * The "fcnt(*)" 
31b0: 66 75 6e 63 74 69 6f 6e 20 61 6c 77 61 79 73 20  function always 
31c0: 72 65 74 75 72 6e 73 20 74 68 65 20 6e 75 6d 62  returns the numb
31d0: 65 72 20 6f 66 20 66 65 74 63 68 0a 20 20 20 20  er of fetch.    
31e0: 20 20 20 20 2a 2a 20 6f 70 65 72 61 74 69 6f 6e      ** operation
31f0: 73 20 74 68 61 74 20 68 61 76 65 20 6f 63 63 75  s that have occu
3200: 72 72 65 64 20 73 6f 20 66 61 72 20 77 68 69 6c  rred so far whil
3210: 65 20 70 72 6f 63 65 73 73 69 6e 67 20 74 68 65  e processing the
3220: 0a 20 20 20 20 20 20 20 20 2a 2a 20 53 51 4c 20  .        ** SQL 
3230: 73 74 61 74 65 6d 65 6e 74 2e 20 20 54 68 69 73  statement.  This
3240: 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 63 61 6e   information can
3250: 20 62 65 20 75 73 65 64 20 62 79 20 74 65 73 74   be used by test
3260: 20 70 72 6f 63 65 64 75 72 65 73 0a 20 20 20 20   procedures.    
3270: 20 20 20 20 2a 2a 20 74 6f 20 76 65 72 69 66 79      ** to verify
3280: 20 74 68 61 74 20 69 6e 64 69 63 65 73 20 61 72   that indices ar
3290: 65 20 62 65 69 6e 67 20 75 73 65 64 20 70 72 6f  e being used pro
32a0: 70 65 72 6c 79 20 74 6f 20 6d 69 6e 69 6d 69 7a  perly to minimiz
32b0: 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 73 65 61  e.        ** sea
32c0: 72 63 68 69 6e 67 2e 20 20 41 6c 6c 20 61 72 67  rching.  All arg
32d0: 75 6d 65 6e 74 73 20 74 6f 20 66 63 6e 74 28 29  uments to fcnt()
32e0: 20 61 72 65 20 69 67 6e 6f 72 65 64 2e 20 20 66   are ignored.  f
32f0: 63 6e 74 28 29 20 68 61 73 0a 20 20 20 20 20 20  cnt() has.      
3300: 20 20 2a 2a 20 6e 6f 20 75 73 65 20 28 6f 74 68    ** no use (oth
3310: 65 72 20 74 68 61 6e 20 74 65 73 74 69 6e 67 29  er than testing)
3320: 20 74 68 61 74 20 77 65 20 61 72 65 20 61 77 61   that we are awa
3330: 72 65 20 6f 66 2e 0a 20 20 20 20 20 20 20 20 2a  re of..        *
3340: 2f 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 46  /.        case F
3350: 4e 5f 46 63 6e 74 3a 20 7b 0a 20 20 20 20 20 20  N_Fcnt: {.      
3360: 20 20 20 20 6e 20 3d 20 30 3b 0a 20 20 20 20 20      n = 0;.     
3370: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
3380: 20 20 20 20 7d 0a 20 20 20 20 20 20 0a 20 20 20      }.      .   
3390: 20 20 20 20 20 64 65 66 61 75 6c 74 3a 20 62 72       default: br
33a0: 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  eak;.      }.   
33b0: 20 20 20 69 66 28 20 6e 6f 5f 73 75 63 68 5f 66     if( no_such_f
33c0: 75 6e 63 20 29 7b 0a 20 20 20 20 20 20 20 20 73  unc ){.        s
33d0: 71 6c 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28  qliteSetNString(
33e0: 26 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67  &pParse->zErrMsg
33f0: 2c 20 22 6e 6f 20 73 75 63 68 20 66 75 6e 63 74  , "no such funct
3400: 69 6f 6e 3a 20 22 2c 20 2d 31 2c 0a 20 20 20 20  ion: ", -1,.    
3410: 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f         pExpr->to
3420: 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f  ken.z, pExpr->to
3430: 6b 65 6e 2e 6e 2c 20 30 29 3b 0a 20 20 20 20 20  ken.n, 0);.     
3440: 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b     pParse->nErr+
3450: 2b 3b 0a 20 20 20 20 20 20 20 20 6e 45 72 72 2b  +;.        nErr+
3460: 2b 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  +;.      }else i
3470: 66 28 20 74 6f 6f 5f 6d 61 6e 79 5f 61 72 67 73  f( too_many_args
3480: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
3490: 74 65 53 65 74 4e 53 74 72 69 6e 67 28 26 70 50  teSetNString(&pP
34a0: 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 2c 20 22  arse->zErrMsg, "
34b0: 74 6f 6f 20 6d 61 6e 79 20 61 72 67 75 6d 65 6e  too many argumen
34c0: 74 73 20 74 6f 20 66 75 6e 63 74 69 6f 6e 20 22  ts to function "
34d0: 2c 2d 31 2c 0a 20 20 20 20 20 20 20 20 20 20 20  ,-1,.           
34e0: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20  pExpr->token.z, 
34f0: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20  pExpr->token.n, 
3500: 22 28 29 22 2c 20 32 2c 20 30 29 3b 0a 20 20 20  "()", 2, 0);.   
3510: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72       pParse->nEr
3520: 72 2b 2b 3b 0a 20 20 20 20 20 20 20 20 6e 45 72  r++;.        nEr
3530: 72 2b 2b 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  r++;.      }else
3540: 20 69 66 28 20 74 6f 6f 5f 66 65 77 5f 61 72 67   if( too_few_arg
3550: 73 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  s ){.        sql
3560: 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28 26 70  iteSetNString(&p
3570: 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 2c 20  Parse->zErrMsg, 
3580: 22 74 6f 6f 20 66 65 77 20 61 72 67 75 6d 65 6e  "too few argumen
3590: 74 73 20 74 6f 20 66 75 6e 63 74 69 6f 6e 20 22  ts to function "
35a0: 2c 2d 31 2c 0a 20 20 20 20 20 20 20 20 20 20 20  ,-1,.           
35b0: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20  pExpr->token.z, 
35c0: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20  pExpr->token.n, 
35d0: 22 28 29 22 2c 20 32 2c 20 30 29 3b 0a 20 20 20  "()", 2, 0);.   
35e0: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72       pParse->nEr
35f0: 72 2b 2b 3b 0a 20 20 20 20 20 20 20 20 6e 45 72  r++;.        nEr
3600: 72 2b 2b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  r++;.      }.   
3610: 20 20 20 69 66 28 20 69 73 5f 61 67 67 20 29 20     if( is_agg ) 
3620: 70 45 78 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 41  pExpr->op = TK_A
3630: 47 47 5f 46 55 4e 43 54 49 4f 4e 3b 0a 20 20 20  GG_FUNCTION;.   
3640: 20 20 20 69 66 28 20 69 73 5f 61 67 67 20 26 26     if( is_agg &&
3650: 20 70 49 73 41 67 67 20 29 20 2a 70 49 73 41 67   pIsAgg ) *pIsAg
3660: 67 20 3d 20 31 3b 0a 20 20 20 20 20 20 66 6f 72  g = 1;.      for
3670: 28 69 3d 30 3b 20 6e 45 72 72 3d 3d 30 20 26 26  (i=0; nErr==0 &&
3680: 20 69 3c 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20   i<n; i++){.    
3690: 20 20 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74      nErr = sqlit
36a0: 65 45 78 70 72 43 68 65 63 6b 28 70 50 61 72 73  eExprCheck(pPars
36b0: 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d  e, pExpr->pList-
36c0: 3e 61 5b 69 5d 2e 70 45 78 70 72 2c 0a 20 20 20  >a[i].pExpr,.   
36d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
36e0: 20 20 20 20 20 20 20 20 20 20 20 20 61 6c 6c 6f              allo
36f0: 77 41 67 67 20 26 26 20 21 69 73 5f 61 67 67 2c  wAgg && !is_agg,
3700: 20 70 49 73 41 67 67 29 3b 0a 20 20 20 20 20 20   pIsAgg);.      
3710: 7d 0a 20 20 20 20 7d 0a 20 20 20 20 64 65 66 61  }.    }.    defa
3720: 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20 69 66 28  ult: {.      if(
3730: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 29 7b   pExpr->pLeft ){
3740: 0a 20 20 20 20 20 20 20 20 6e 45 72 72 20 3d 20  .        nErr = 
3750: 73 71 6c 69 74 65 45 78 70 72 43 68 65 63 6b 28  sqliteExprCheck(
3760: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
3770: 4c 65 66 74 2c 20 61 6c 6c 6f 77 41 67 67 2c 20  Left, allowAgg, 
3780: 70 49 73 41 67 67 29 3b 0a 20 20 20 20 20 20 7d  pIsAgg);.      }
3790: 0a 20 20 20 20 20 20 69 66 28 20 6e 45 72 72 3d  .      if( nErr=
37a0: 3d 30 20 26 26 20 70 45 78 70 72 2d 3e 70 52 69  =0 && pExpr->pRi
37b0: 67 68 74 20 29 7b 0a 20 20 20 20 20 20 20 20 6e  ght ){.        n
37c0: 45 72 72 20 3d 20 73 71 6c 69 74 65 45 78 70 72  Err = sqliteExpr
37d0: 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20 70 45  Check(pParse, pE
37e0: 78 70 72 2d 3e 70 52 69 67 68 74 2c 20 61 6c 6c  xpr->pRight, all
37f0: 6f 77 41 67 67 2c 20 70 49 73 41 67 67 29 3b 0a  owAgg, pIsAgg);.
3800: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
3810: 28 20 6e 45 72 72 3d 3d 30 20 26 26 20 70 45 78  ( nErr==0 && pEx
3820: 70 72 2d 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20  pr->pList ){.   
3830: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 70 45 78       int n = pEx
3840: 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72  pr->pList->nExpr
3850: 3b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b  ;.        int i;
3860: 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30  .        for(i=0
3870: 3b 20 6e 45 72 72 3d 3d 30 20 26 26 20 69 3c 6e  ; nErr==0 && i<n
3880: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; i++){.        
3890: 20 20 45 78 70 72 20 2a 70 45 32 20 3d 20 70 45    Expr *pE2 = pE
38a0: 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d  xpr->pList->a[i]
38b0: 2e 70 45 78 70 72 3b 0a 20 20 20 20 20 20 20 20  .pExpr;.        
38c0: 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74 65 45    nErr = sqliteE
38d0: 78 70 72 43 68 65 63 6b 28 70 50 61 72 73 65 2c  xprCheck(pParse,
38e0: 20 70 45 32 2c 20 61 6c 6c 6f 77 41 67 67 2c 20   pE2, allowAgg, 
38f0: 70 49 73 41 67 67 29 3b 0a 20 20 20 20 20 20 20  pIsAgg);.       
3900: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
3910: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
3920: 7d 0a 20 20 72 65 74 75 72 6e 20 6e 45 72 72 3b  }.  return nErr;
3930: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61  .}../*.** Genera
3940: 74 65 20 63 6f 64 65 20 69 6e 74 6f 20 74 68 65  te code into the
3950: 20 63 75 72 72 65 6e 74 20 56 64 62 65 20 74 6f   current Vdbe to
3960: 20 65 76 61 6c 75 61 74 65 20 74 68 65 20 67 69   evaluate the gi
3970: 76 65 6e 0a 2a 2a 20 65 78 70 72 65 73 73 69 6f  ven.** expressio
3980: 6e 20 61 6e 64 20 6c 65 61 76 65 20 74 68 65 20  n and leave the 
3990: 72 65 73 75 6c 74 20 6f 6e 20 74 68 65 20 74 6f  result on the to
39a0: 70 20 6f 66 20 73 74 61 63 6b 2e 0a 2a 2f 0a 76  p of stack..*/.v
39b0: 6f 69 64 20 73 71 6c 69 74 65 45 78 70 72 43 6f  oid sqliteExprCo
39c0: 64 65 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  de(Parse *pParse
39d0: 2c 20 45 78 70 72 20 2a 70 45 78 70 72 29 7b 0a  , Expr *pExpr){.
39e0: 20 20 56 64 62 65 20 2a 76 20 3d 20 70 50 61 72    Vdbe *v = pPar
39f0: 73 65 2d 3e 70 56 64 62 65 3b 0a 20 20 69 6e 74  se->pVdbe;.  int
3a00: 20 6f 70 3b 0a 20 20 69 66 28 20 76 3d 3d 30 20   op;.  if( v==0 
3a10: 7c 7c 20 70 45 78 70 72 3d 3d 30 20 29 20 72 65  || pExpr==0 ) re
3a20: 74 75 72 6e 3b 0a 20 20 73 77 69 74 63 68 28 20  turn;.  switch( 
3a30: 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20  pExpr->op ){.   
3a40: 20 63 61 73 65 20 54 4b 5f 50 4c 55 53 3a 20 20   case TK_PLUS:  
3a50: 20 20 20 6f 70 20 3d 20 4f 50 5f 41 64 64 3b 20     op = OP_Add; 
3a60: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
3a70: 63 61 73 65 20 54 4b 5f 4d 49 4e 55 53 3a 20 20  case TK_MINUS:  
3a80: 20 20 6f 70 20 3d 20 4f 50 5f 53 75 62 74 72 61    op = OP_Subtra
3a90: 63 74 3b 20 62 72 65 61 6b 3b 0a 20 20 20 20 63  ct; break;.    c
3aa0: 61 73 65 20 54 4b 5f 53 54 41 52 3a 20 20 20 20  ase TK_STAR:    
3ab0: 20 6f 70 20 3d 20 4f 50 5f 4d 75 6c 74 69 70 6c   op = OP_Multipl
3ac0: 79 3b 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61  y; break;.    ca
3ad0: 73 65 20 54 4b 5f 53 4c 41 53 48 3a 20 20 20 20  se TK_SLASH:    
3ae0: 6f 70 20 3d 20 4f 50 5f 44 69 76 69 64 65 3b 20  op = OP_Divide; 
3af0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
3b00: 65 20 54 4b 5f 41 4e 44 3a 20 20 20 20 20 20 6f  e TK_AND:      o
3b10: 70 20 3d 20 4f 50 5f 41 6e 64 3b 20 20 20 20 20  p = OP_And;     
3b20: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
3b30: 20 54 4b 5f 4f 52 3a 20 20 20 20 20 20 20 6f 70   TK_OR:       op
3b40: 20 3d 20 4f 50 5f 4f 72 3b 20 20 20 20 20 20 20   = OP_Or;       
3b50: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
3b60: 54 4b 5f 4c 54 3a 20 20 20 20 20 20 20 6f 70 20  TK_LT:       op 
3b70: 3d 20 4f 50 5f 4c 74 3b 20 20 20 20 20 20 20 62  = OP_Lt;       b
3b80: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
3b90: 4b 5f 4c 45 3a 20 20 20 20 20 20 20 6f 70 20 3d  K_LE:       op =
3ba0: 20 4f 50 5f 4c 65 3b 20 20 20 20 20 20 20 62 72   OP_Le;       br
3bb0: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
3bc0: 5f 47 54 3a 20 20 20 20 20 20 20 6f 70 20 3d 20  _GT:       op = 
3bd0: 4f 50 5f 47 74 3b 20 20 20 20 20 20 20 62 72 65  OP_Gt;       bre
3be0: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  ak;.    case TK_
3bf0: 47 45 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f  GE:       op = O
3c00: 50 5f 47 65 3b 20 20 20 20 20 20 20 62 72 65 61  P_Ge;       brea
3c10: 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e  k;.    case TK_N
3c20: 45 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50  E:       op = OP
3c30: 5f 4e 65 3b 20 20 20 20 20 20 20 62 72 65 61 6b  _Ne;       break
3c40: 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 45 51  ;.    case TK_EQ
3c50: 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f  :       op = OP_
3c60: 45 71 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b  Eq;       break;
3c70: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 49 4b  .    case TK_LIK
3c80: 45 3a 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4c  E:     op = OP_L
3c90: 69 6b 65 3b 20 20 20 20 20 62 72 65 61 6b 3b 0a  ike;     break;.
3ca0: 20 20 20 20 63 61 73 65 20 54 4b 5f 47 4c 4f 42      case TK_GLOB
3cb0: 3a 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 6c  :     op = OP_Gl
3cc0: 6f 62 3b 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ob;     break;. 
3cd0: 20 20 20 63 61 73 65 20 54 4b 5f 49 53 4e 55 4c     case TK_ISNUL
3ce0: 4c 3a 20 20 20 6f 70 20 3d 20 4f 50 5f 49 73 4e  L:   op = OP_IsN
3cf0: 75 6c 6c 3b 20 20 20 62 72 65 61 6b 3b 0a 20 20  ull;   break;.  
3d00: 20 20 63 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c    case TK_NOTNUL
3d10: 4c 3a 20 20 6f 70 20 3d 20 4f 50 5f 4e 6f 74 4e  L:  op = OP_NotN
3d20: 75 6c 6c 3b 20 20 62 72 65 61 6b 3b 0a 20 20 20  ull;  break;.   
3d30: 20 63 61 73 65 20 54 4b 5f 4e 4f 54 3a 20 20 20   case TK_NOT:   
3d40: 20 20 20 6f 70 20 3d 20 4f 50 5f 4e 6f 74 3b 20     op = OP_Not; 
3d50: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
3d60: 63 61 73 65 20 54 4b 5f 55 4d 49 4e 55 53 3a 20  case TK_UMINUS: 
3d70: 20 20 6f 70 20 3d 20 4f 50 5f 4e 65 67 61 74 69    op = OP_Negati
3d80: 76 65 3b 20 62 72 65 61 6b 3b 0a 20 20 20 20 64  ve; break;.    d
3d90: 65 66 61 75 6c 74 3a 20 62 72 65 61 6b 3b 0a 20  efault: break;. 
3da0: 20 7d 0a 20 20 73 77 69 74 63 68 28 20 70 45 78   }.  switch( pEx
3db0: 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61  pr->op ){.    ca
3dc0: 73 65 20 54 4b 5f 43 4f 4c 55 4d 4e 3a 20 7b 0a  se TK_COLUMN: {.
3dd0: 20 20 20 20 20 20 69 66 28 20 70 50 61 72 73 65        if( pParse
3de0: 2d 3e 75 73 65 41 67 67 20 29 7b 0a 20 20 20 20  ->useAgg ){.    
3df0: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
3e00: 64 4f 70 28 76 2c 20 4f 50 5f 41 67 67 47 65 74  dOp(v, OP_AggGet
3e10: 2c 20 30 2c 20 70 45 78 70 72 2d 3e 69 41 67 67  , 0, pExpr->iAgg
3e20: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  );.      }else i
3e30: 66 28 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d  f( pExpr->iColum
3e40: 6e 3e 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  n>=0 ){.        
3e50: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
3e60: 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e 2c 20 70 45  v, OP_Column, pE
3e70: 78 70 72 2d 3e 69 54 61 62 6c 65 2c 20 70 45 78  xpr->iTable, pEx
3e80: 70 72 2d 3e 69 43 6f 6c 75 6d 6e 29 3b 0a 20 20  pr->iColumn);.  
3e90: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
3ea0: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
3eb0: 4f 70 28 76 2c 20 4f 50 5f 52 65 63 6e 6f 2c 20  Op(v, OP_Recno, 
3ec0: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 2c 20 30  pExpr->iTable, 0
3ed0: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  );.      }.     
3ee0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
3ef0: 20 20 63 61 73 65 20 54 4b 5f 49 4e 54 45 47 45    case TK_INTEGE
3f00: 52 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 69  R: {.      int i
3f10: 20 3d 20 61 74 6f 69 28 70 45 78 70 72 2d 3e 74   = atoi(pExpr->t
3f20: 6f 6b 65 6e 2e 7a 29 3b 0a 20 20 20 20 20 20 73  oken.z);.      s
3f30: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
3f40: 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c  , OP_Integer, i,
3f50: 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b   0);.      break
3f60: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
3f70: 20 54 4b 5f 46 4c 4f 41 54 3a 20 7b 0a 20 20 20   TK_FLOAT: {.   
3f80: 20 20 20 69 6e 74 20 61 64 64 72 20 3d 20 73 71     int addr = sq
3f90: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
3fa0: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
3fb0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  );.      sqliteV
3fc0: 64 62 65 43 68 61 6e 67 65 50 33 28 76 2c 20 61  dbeChangeP3(v, a
3fd0: 64 64 72 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65  ddr, pExpr->toke
3fe0: 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65  n.z, pExpr->toke
3ff0: 6e 2e 6e 29 3b 0a 20 20 20 20 20 20 62 72 65 61  n.n);.      brea
4000: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
4010: 65 20 54 4b 5f 53 54 52 49 4e 47 3a 20 7b 0a 20  e TK_STRING: {. 
4020: 20 20 20 20 20 69 6e 74 20 61 64 64 72 20 3d 20       int addr = 
4030: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
4040: 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c  v, OP_String, 0,
4050: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
4060: 65 56 64 62 65 43 68 61 6e 67 65 50 33 28 76 2c  eVdbeChangeP3(v,
4070: 20 61 64 64 72 2c 20 70 45 78 70 72 2d 3e 74 6f   addr, pExpr->to
4080: 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f  ken.z, pExpr->to
4090: 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20 20 20 73 71  ken.n);.      sq
40a0: 6c 69 74 65 56 64 62 65 44 65 71 75 6f 74 65 50  liteVdbeDequoteP
40b0: 33 28 76 2c 20 61 64 64 72 29 3b 0a 20 20 20 20  3(v, addr);.    
40c0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20    break;.    }. 
40d0: 20 20 20 63 61 73 65 20 54 4b 5f 4e 55 4c 4c 3a     case TK_NULL:
40e0: 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56   {.      sqliteV
40f0: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53  dbeAddOp(v, OP_S
4100: 74 72 69 6e 67 2c 20 30 2c 20 30 29 3b 0a 20 20  tring, 0, 0);.  
4110: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
4120: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 41 4e 44  .    case TK_AND
4130: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4f 52  :.    case TK_OR
4140: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 50 4c  :.    case TK_PL
4150: 55 53 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  US:.    case TK_
4160: 53 54 41 52 3a 0a 20 20 20 20 63 61 73 65 20 54  STAR:.    case T
4170: 4b 5f 4d 49 4e 55 53 3a 0a 20 20 20 20 63 61 73  K_MINUS:.    cas
4180: 65 20 54 4b 5f 53 4c 41 53 48 3a 20 7b 0a 20 20  e TK_SLASH: {.  
4190: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f      sqliteExprCo
41a0: 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  de(pParse, pExpr
41b0: 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20  ->pLeft);.      
41c0: 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70  sqliteExprCode(p
41d0: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 52  Parse, pExpr->pR
41e0: 69 67 68 74 29 3b 0a 20 20 20 20 20 20 73 71 6c  ight);.      sql
41f0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
4200: 6f 70 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20  op, 0, 0);.     
4210: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
4220: 20 20 63 61 73 65 20 54 4b 5f 43 4f 4e 43 41 54    case TK_CONCAT
4230: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
4240: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
4250: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
4260: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
4270: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78  Code(pParse, pEx
4280: 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20  pr->pRight);.   
4290: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
42a0: 4f 70 28 76 2c 20 4f 50 5f 43 6f 6e 63 61 74 2c  Op(v, OP_Concat,
42b0: 20 32 2c 20 30 29 3b 0a 20 20 20 20 20 20 62 72   2, 0);.      br
42c0: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63  eak;.    }.    c
42d0: 61 73 65 20 54 4b 5f 4c 54 3a 0a 20 20 20 20 63  ase TK_LT:.    c
42e0: 61 73 65 20 54 4b 5f 4c 45 3a 0a 20 20 20 20 63  ase TK_LE:.    c
42f0: 61 73 65 20 54 4b 5f 47 54 3a 0a 20 20 20 20 63  ase TK_GT:.    c
4300: 61 73 65 20 54 4b 5f 47 45 3a 0a 20 20 20 20 63  ase TK_GE:.    c
4310: 61 73 65 20 54 4b 5f 4e 45 3a 0a 20 20 20 20 63  ase TK_NE:.    c
4320: 61 73 65 20 54 4b 5f 45 51 3a 20 0a 20 20 20 20  ase TK_EQ: .    
4330: 63 61 73 65 20 54 4b 5f 4c 49 4b 45 3a 20 0a 20  case TK_LIKE: . 
4340: 20 20 20 63 61 73 65 20 54 4b 5f 47 4c 4f 42 3a     case TK_GLOB:
4350: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 64 65 73   {.      int des
4360: 74 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  t;.      sqliteV
4370: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49  dbeAddOp(v, OP_I
4380: 6e 74 65 67 65 72 2c 20 31 2c 20 30 29 3b 0a 20  nteger, 1, 0);. 
4390: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
43a0: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
43b0: 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20  r->pLeft);.     
43c0: 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28   sqliteExprCode(
43d0: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
43e0: 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20 64 65  Right);.      de
43f0: 73 74 20 3d 20 73 71 6c 69 74 65 56 64 62 65 43  st = sqliteVdbeC
4400: 75 72 72 65 6e 74 41 64 64 72 28 76 29 20 2b 20  urrentAddr(v) + 
4410: 32 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  2;.      sqliteV
4420: 64 62 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20  dbeAddOp(v, op, 
4430: 30 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20 20  0, dest);.      
4440: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
4450: 76 2c 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 2d 31  v, OP_AddImm, -1
4460: 2c 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61  , 0);.      brea
4470: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
4480: 65 20 54 4b 5f 55 4d 49 4e 55 53 3a 20 7b 0a 20  e TK_UMINUS: {. 
4490: 20 20 20 20 20 61 73 73 65 72 74 28 20 70 45 78       assert( pEx
44a0: 70 72 2d 3e 70 4c 65 66 74 20 29 3b 0a 20 20 20  pr->pLeft );.   
44b0: 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 70 4c     if( pExpr->pL
44c0: 65 66 74 2d 3e 6f 70 3d 3d 54 4b 5f 49 4e 54 45  eft->op==TK_INTE
44d0: 47 45 52 20 29 7b 0a 20 20 20 20 20 20 20 20 69  GER ){.        i
44e0: 6e 74 20 69 20 3d 20 61 74 6f 69 28 70 45 78 70  nt i = atoi(pExp
44f0: 72 2d 3e 70 4c 65 66 74 2d 3e 74 6f 6b 65 6e 2e  r->pLeft->token.
4500: 7a 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  z);.        sqli
4510: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
4520: 50 5f 49 6e 74 65 67 65 72 2c 20 2d 69 2c 20 30  P_Integer, -i, 0
4530: 29 3b 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b  );.        break
4540: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66  ;.      }else if
4550: 28 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 2d 3e  ( pExpr->pLeft->
4560: 6f 70 3d 3d 54 4b 5f 46 4c 4f 41 54 20 29 7b 0a  op==TK_FLOAT ){.
4570: 20 20 20 20 20 20 20 20 54 6f 6b 65 6e 20 2a 70          Token *p
4580: 20 3d 20 26 70 45 78 70 72 2d 3e 70 4c 65 66 74   = &pExpr->pLeft
4590: 2d 3e 74 6f 6b 65 6e 3b 0a 20 20 20 20 20 20 20  ->token;.       
45a0: 20 63 68 61 72 20 2a 7a 20 3d 20 73 71 6c 69 74   char *z = sqlit
45b0: 65 4d 61 6c 6c 6f 63 28 20 70 2d 3e 6e 20 2b 20  eMalloc( p->n + 
45c0: 32 20 29 3b 0a 20 20 20 20 20 20 20 20 73 70 72  2 );.        spr
45d0: 69 6e 74 66 28 7a 2c 20 22 2d 25 2e 2a 73 22 2c  intf(z, "-%.*s",
45e0: 20 70 2d 3e 6e 2c 20 70 2d 3e 7a 29 3b 0a 20 20   p->n, p->z);.  
45f0: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
4600: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 74 72 69  AddOp(v, OP_Stri
4610: 6e 67 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20  ng, 0, 0);.     
4620: 20 20 20 73 71 6c 69 74 65 56 64 62 65 43 68 61     sqliteVdbeCha
4630: 6e 67 65 50 33 28 76 2c 20 2d 31 2c 20 7a 2c 20  ngeP3(v, -1, z, 
4640: 70 2d 3e 6e 2b 31 29 3b 0a 20 20 20 20 20 20 20  p->n+1);.       
4650: 20 73 71 6c 69 74 65 46 72 65 65 28 7a 29 3b 0a   sqliteFree(z);.
4660: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
4670: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 2f 2a 20       }.      /* 
4680: 46 61 6c 6c 20 74 68 72 6f 75 67 68 20 69 6e 74  Fall through int
4690: 6f 20 54 4b 5f 4e 4f 54 20 2a 2f 0a 20 20 20 20  o TK_NOT */.    
46a0: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 4f  }.    case TK_NO
46b0: 54 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  T: {.      sqlit
46c0: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
46d0: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
46e0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
46f0: 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20 30 2c  eAddOp(v, op, 0,
4700: 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b   0);.      break
4710: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
4720: 20 54 4b 5f 49 53 4e 55 4c 4c 3a 0a 20 20 20 20   TK_ISNULL:.    
4730: 63 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a  case TK_NOTNULL:
4740: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 64 65 73   {.      int des
4750: 74 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  t;.      sqliteV
4760: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49  dbeAddOp(v, OP_I
4770: 6e 74 65 67 65 72 2c 20 31 2c 20 30 29 3b 0a 20  nteger, 1, 0);. 
4780: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
4790: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
47a0: 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20  r->pLeft);.     
47b0: 20 64 65 73 74 20 3d 20 73 71 6c 69 74 65 56 64   dest = sqliteVd
47c0: 62 65 43 75 72 72 65 6e 74 41 64 64 72 28 76 29  beCurrentAddr(v)
47d0: 20 2b 20 32 3b 0a 20 20 20 20 20 20 73 71 6c 69   + 2;.      sqli
47e0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f  teVdbeAddOp(v, o
47f0: 70 2c 20 30 2c 20 64 65 73 74 29 3b 0a 20 20 20  p, 0, dest);.   
4800: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
4810: 4f 70 28 76 2c 20 4f 50 5f 41 64 64 49 6d 6d 2c  Op(v, OP_AddImm,
4820: 20 2d 31 2c 20 30 29 3b 0a 20 20 20 20 20 20 62   -1, 0);.      b
4830: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  reak;.    }.    
4840: 63 61 73 65 20 54 4b 5f 41 47 47 5f 46 55 4e 43  case TK_AGG_FUNC
4850: 54 49 4f 4e 3a 20 7b 0a 20 20 20 20 20 20 73 71  TION: {.      sq
4860: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
4870: 20 4f 50 5f 41 67 67 47 65 74 2c 20 30 2c 20 70   OP_AggGet, 0, p
4880: 45 78 70 72 2d 3e 69 41 67 67 29 3b 0a 20 20 20  Expr->iAgg);.   
4890: 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 69 43     if( pExpr->iC
48a0: 6f 6c 75 6d 6e 3d 3d 46 4e 5f 41 76 67 20 29 7b  olumn==FN_Avg ){
48b0: 0a 20 20 20 20 20 20 20 20 61 73 73 65 72 74 28  .        assert(
48c0: 20 70 50 61 72 73 65 2d 3e 69 41 67 67 43 6f 75   pParse->iAggCou
48d0: 6e 74 3e 3d 30 20 26 26 20 70 50 61 72 73 65 2d  nt>=0 && pParse-
48e0: 3e 69 41 67 67 43 6f 75 6e 74 3c 70 50 61 72 73  >iAggCount<pPars
48f0: 65 2d 3e 6e 41 67 67 20 29 3b 0a 20 20 20 20 20  e->nAgg );.     
4900: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
4910: 4f 70 28 76 2c 20 4f 50 5f 41 67 67 47 65 74 2c  Op(v, OP_AggGet,
4920: 20 30 2c 20 70 50 61 72 73 65 2d 3e 69 41 67 67   0, pParse->iAgg
4930: 43 6f 75 6e 74 29 3b 0a 20 20 20 20 20 20 20 20  Count);.        
4940: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
4950: 76 2c 20 4f 50 5f 44 69 76 69 64 65 2c 20 30 2c  v, OP_Divide, 0,
4960: 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20   0);.      }.   
4970: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
4980: 20 20 20 20 63 61 73 65 20 54 4b 5f 46 55 4e 43      case TK_FUNC
4990: 54 49 4f 4e 3a 20 7b 0a 20 20 20 20 20 20 69 6e  TION: {.      in
49a0: 74 20 69 64 20 3d 20 70 45 78 70 72 2d 3e 69 43  t id = pExpr->iC
49b0: 6f 6c 75 6d 6e 3b 0a 20 20 20 20 20 20 69 6e 74  olumn;.      int
49c0: 20 6f 70 3b 0a 20 20 20 20 20 20 69 6e 74 20 69   op;.      int i
49d0: 3b 0a 20 20 20 20 20 20 45 78 70 72 4c 69 73 74  ;.      ExprList
49e0: 20 2a 70 4c 69 73 74 20 3d 20 70 45 78 70 72 2d   *pList = pExpr-
49f0: 3e 70 4c 69 73 74 3b 0a 20 20 20 20 20 20 73 77  >pList;.      sw
4a00: 69 74 63 68 28 20 69 64 20 29 7b 0a 20 20 20 20  itch( id ){.    
4a10: 20 20 20 20 63 61 73 65 20 46 4e 5f 46 63 6e 74      case FN_Fcnt
4a20: 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71  : {.          sq
4a30: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
4a40: 20 4f 50 5f 46 63 6e 74 2c 20 30 2c 20 30 29 3b   OP_Fcnt, 0, 0);
4a50: 0a 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b  .          break
4a60: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
4a70: 20 20 20 20 63 61 73 65 20 46 4e 5f 4d 69 6e 3a      case FN_Min:
4a80: 20 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 46   .        case F
4a90: 4e 5f 4d 61 78 3a 20 7b 0a 20 20 20 20 20 20 20  N_Max: {.       
4aa0: 20 20 20 6f 70 20 3d 20 69 64 3d 3d 46 4e 5f 4d     op = id==FN_M
4ab0: 69 6e 20 3f 20 4f 50 5f 4d 69 6e 20 3a 20 4f 50  in ? OP_Min : OP
4ac0: 5f 4d 61 78 3b 0a 20 20 20 20 20 20 20 20 20 20  _Max;.          
4ad0: 66 6f 72 28 69 3d 30 3b 20 69 3c 70 4c 69 73 74  for(i=0; i<pList
4ae0: 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a 20  ->nExpr; i++){. 
4af0: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
4b00: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
4b10: 2c 20 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45  , pList->a[i].pE
4b20: 78 70 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20  xpr);.          
4b30: 20 20 69 66 28 20 69 3e 30 20 29 7b 0a 20 20 20    if( i>0 ){.   
4b40: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
4b50: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f 70  eVdbeAddOp(v, op
4b60: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  , 0, 0);.       
4b70: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
4b80: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 62 72 65   }.          bre
4b90: 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ak;.        }.  
4ba0: 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f 4c 65        case FN_Le
4bb0: 6e 67 74 68 3a 20 7b 0a 20 20 20 20 20 20 20 20  ngth: {.        
4bc0: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
4bd0: 28 70 50 61 72 73 65 2c 20 70 4c 69 73 74 2d 3e  (pParse, pList->
4be0: 61 5b 30 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20  a[0].pExpr);.   
4bf0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
4c00: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 74 72  eAddOp(v, OP_Str
4c10: 6c 65 6e 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  len, 0, 0);.    
4c20: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
4c30: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 63       }.        c
4c40: 61 73 65 20 46 4e 5f 53 75 62 73 74 72 3a 20 7b  ase FN_Substr: {
4c50: 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 28 69  .          for(i
4c60: 3d 30 3b 20 69 3c 70 4c 69 73 74 2d 3e 6e 45 78  =0; i<pList->nEx
4c70: 70 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  pr; i++){.      
4c80: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
4c90: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 4c 69  Code(pParse, pLi
4ca0: 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 29 3b  st->a[i].pExpr);
4cb0: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
4cc0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
4cd0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 75 62  eAddOp(v, OP_Sub
4ce0: 73 74 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  str, 0, 0);.    
4cf0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
4d00: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 64       }.        d
4d10: 65 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20  efault: {.      
4d20: 20 20 20 20 2f 2a 20 43 61 6e 27 74 20 68 61 70      /* Can't hap
4d30: 70 65 6e 21 20 2a 2f 0a 20 20 20 20 20 20 20 20  pen! */.        
4d40: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20    break;.       
4d50: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
4d60: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
4d70: 20 20 63 61 73 65 20 54 4b 5f 53 45 4c 45 43 54    case TK_SELECT
4d80: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
4d90: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
4da0: 4d 65 6d 4c 6f 61 64 2c 20 70 45 78 70 72 2d 3e  MemLoad, pExpr->
4db0: 69 43 6f 6c 75 6d 6e 2c 20 30 29 3b 0a 20 20 20  iColumn, 0);.   
4dc0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
4dd0: 20 20 20 20 63 61 73 65 20 54 4b 5f 49 4e 3a 20      case TK_IN: 
4de0: 7b 0a 20 20 20 20 20 20 69 6e 74 20 61 64 64 72  {.      int addr
4df0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64  ;.      sqliteVd
4e00: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e  beAddOp(v, OP_In
4e10: 74 65 67 65 72 2c 20 31 2c 20 30 29 3b 0a 20 20  teger, 1, 0);.  
4e20: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f      sqliteExprCo
4e30: 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  de(pParse, pExpr
4e40: 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20  ->pLeft);.      
4e50: 61 64 64 72 20 3d 20 73 71 6c 69 74 65 56 64 62  addr = sqliteVdb
4e60: 65 43 75 72 72 65 6e 74 41 64 64 72 28 76 29 3b  eCurrentAddr(v);
4e70: 0a 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72  .      if( pExpr
4e80: 2d 3e 70 53 65 6c 65 63 74 20 29 7b 0a 20 20 20  ->pSelect ){.   
4e90: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
4ea0: 64 64 4f 70 28 76 2c 20 4f 50 5f 46 6f 75 6e 64  ddOp(v, OP_Found
4eb0: 2c 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 2c  , pExpr->iTable,
4ec0: 20 61 64 64 72 2b 32 29 3b 0a 20 20 20 20 20 20   addr+2);.      
4ed0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 73  }else{.        s
4ee0: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
4ef0: 2c 20 4f 50 5f 53 65 74 46 6f 75 6e 64 2c 20 70  , OP_SetFound, p
4f00: 45 78 70 72 2d 3e 69 54 61 62 6c 65 2c 20 61 64  Expr->iTable, ad
4f10: 64 72 2b 32 29 3b 0a 20 20 20 20 20 20 7d 0a 20  dr+2);.      }. 
4f20: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
4f30: 64 64 4f 70 28 76 2c 20 4f 50 5f 41 64 64 49 6d  ddOp(v, OP_AddIm
4f40: 6d 2c 20 2d 31 2c 20 30 29 3b 0a 20 20 20 20 20  m, -1, 0);.     
4f50: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
4f60: 20 20 63 61 73 65 20 54 4b 5f 42 45 54 57 45 45    case TK_BETWEE
4f70: 4e 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c  N: {.      int l
4f80: 62 6c 20 3d 20 73 71 6c 69 74 65 56 64 62 65 4d  bl = sqliteVdbeM
4f90: 61 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20 20 20  akeLabel(v);.   
4fa0: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
4fb0: 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72  Op(v, OP_Integer
4fc0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73  , 0, 0);.      s
4fd0: 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73 65  qliteExprIfFalse
4fe0: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2c 20  (pParse, pExpr, 
4ff0: 6c 62 6c 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  lbl);.      sqli
5000: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
5010: 50 5f 41 64 64 49 6d 6d 2c 20 31 2c 20 30 29 3b  P_AddImm, 1, 0);
5020: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
5030: 65 52 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76 2c  eResolveLabel(v,
5040: 20 6c 62 6c 29 3b 0a 20 20 20 20 20 20 62 72 65   lbl);.      bre
5050: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  ak;.    }.  }.  
5060: 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  return;.}../*.**
5070: 20 47 65 6e 65 72 61 74 65 20 63 6f 64 65 20 66   Generate code f
5080: 6f 72 20 61 20 62 6f 6f 6c 65 61 6e 20 65 78 70  or a boolean exp
5090: 72 65 73 73 69 6f 6e 20 73 75 63 68 20 74 68 61  ression such tha
50a0: 74 20 61 20 6a 75 6d 70 20 69 73 20 6d 61 64 65  t a jump is made
50b0: 0a 2a 2a 20 74 6f 20 74 68 65 20 6c 61 62 65 6c  .** to the label
50c0: 20 22 64 65 73 74 22 20 69 66 20 74 68 65 20 65   "dest" if the e
50d0: 78 70 72 65 73 73 69 6f 6e 20 69 73 20 74 72 75  xpression is tru
50e0: 65 20 62 75 74 20 65 78 65 63 75 74 69 6f 6e 0a  e but execution.
50f0: 2a 2a 20 63 6f 6e 74 69 6e 75 65 73 20 73 74 72  ** continues str
5100: 61 69 67 68 74 20 74 68 72 75 20 69 66 20 74 68  aight thru if th
5110: 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69 73 20  e expression is 
5120: 66 61 6c 73 65 2e 0a 2a 2f 0a 76 6f 69 64 20 73  false..*/.void s
5130: 71 6c 69 74 65 45 78 70 72 49 66 54 72 75 65 28  qliteExprIfTrue(
5140: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 45  Parse *pParse, E
5150: 78 70 72 20 2a 70 45 78 70 72 2c 20 69 6e 74 20  xpr *pExpr, int 
5160: 64 65 73 74 29 7b 0a 20 20 56 64 62 65 20 2a 76  dest){.  Vdbe *v
5170: 20 3d 20 70 50 61 72 73 65 2d 3e 70 56 64 62 65   = pParse->pVdbe
5180: 3b 0a 20 20 69 6e 74 20 6f 70 20 3d 20 30 3b 0a  ;.  int op = 0;.
5190: 20 20 69 66 28 20 76 3d 3d 30 20 7c 7c 20 70 45    if( v==0 || pE
51a0: 78 70 72 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b  xpr==0 ) return;
51b0: 0a 20 20 73 77 69 74 63 68 28 20 70 45 78 70 72  .  switch( pExpr
51c0: 2d 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65  ->op ){.    case
51d0: 20 54 4b 5f 4c 54 3a 20 20 20 20 20 20 20 6f 70   TK_LT:       op
51e0: 20 3d 20 4f 50 5f 4c 74 3b 20 20 20 20 20 20 20   = OP_Lt;       
51f0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
5200: 54 4b 5f 4c 45 3a 20 20 20 20 20 20 20 6f 70 20  TK_LE:       op 
5210: 3d 20 4f 50 5f 4c 65 3b 20 20 20 20 20 20 20 62  = OP_Le;       b
5220: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
5230: 4b 5f 47 54 3a 20 20 20 20 20 20 20 6f 70 20 3d  K_GT:       op =
5240: 20 4f 50 5f 47 74 3b 20 20 20 20 20 20 20 62 72   OP_Gt;       br
5250: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
5260: 5f 47 45 3a 20 20 20 20 20 20 20 6f 70 20 3d 20  _GE:       op = 
5270: 4f 50 5f 47 65 3b 20 20 20 20 20 20 20 62 72 65  OP_Ge;       bre
5280: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  ak;.    case TK_
5290: 4e 45 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f  NE:       op = O
52a0: 50 5f 4e 65 3b 20 20 20 20 20 20 20 62 72 65 61  P_Ne;       brea
52b0: 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 45  k;.    case TK_E
52c0: 51 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50  Q:       op = OP
52d0: 5f 45 71 3b 20 20 20 20 20 20 20 62 72 65 61 6b  _Eq;       break
52e0: 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 49  ;.    case TK_LI
52f0: 4b 45 3a 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f  KE:     op = OP_
5300: 4c 69 6b 65 3b 20 20 20 20 20 62 72 65 61 6b 3b  Like;     break;
5310: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 4c 4f  .    case TK_GLO
5320: 42 3a 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47  B:     op = OP_G
5330: 6c 6f 62 3b 20 20 20 20 20 62 72 65 61 6b 3b 0a  lob;     break;.
5340: 20 20 20 20 63 61 73 65 20 54 4b 5f 49 53 4e 55      case TK_ISNU
5350: 4c 4c 3a 20 20 20 6f 70 20 3d 20 4f 50 5f 49 73  LL:   op = OP_Is
5360: 4e 75 6c 6c 3b 20 20 20 62 72 65 61 6b 3b 0a 20  Null;   break;. 
5370: 20 20 20 63 61 73 65 20 54 4b 5f 4e 4f 54 4e 55     case TK_NOTNU
5380: 4c 4c 3a 20 20 6f 70 20 3d 20 4f 50 5f 4e 6f 74  LL:  op = OP_Not
5390: 4e 75 6c 6c 3b 20 20 62 72 65 61 6b 3b 0a 20 20  Null;  break;.  
53a0: 20 20 64 65 66 61 75 6c 74 3a 20 20 62 72 65 61    default:  brea
53b0: 6b 3b 0a 20 20 7d 0a 20 20 73 77 69 74 63 68 28  k;.  }.  switch(
53c0: 20 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20 20   pExpr->op ){.  
53d0: 20 20 63 61 73 65 20 54 4b 5f 41 4e 44 3a 20 7b    case TK_AND: {
53e0: 0a 20 20 20 20 20 20 69 6e 74 20 64 32 20 3d 20  .      int d2 = 
53f0: 73 71 6c 69 74 65 56 64 62 65 4d 61 6b 65 4c 61  sqliteVdbeMakeLa
5400: 62 65 6c 28 76 29 3b 0a 20 20 20 20 20 20 73 71  bel(v);.      sq
5410: 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73 65 28  liteExprIfFalse(
5420: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
5430: 4c 65 66 74 2c 20 64 32 29 3b 0a 20 20 20 20 20  Left, d2);.     
5440: 20 73 71 6c 69 74 65 45 78 70 72 49 66 54 72 75   sqliteExprIfTru
5450: 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  e(pParse, pExpr-
5460: 3e 70 52 69 67 68 74 2c 20 64 65 73 74 29 3b 0a  >pRight, dest);.
5470: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
5480: 52 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76 2c 20  ResolveLabel(v, 
5490: 64 32 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  d2);.      break
54a0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
54b0: 20 54 4b 5f 4f 52 3a 20 7b 0a 20 20 20 20 20 20   TK_OR: {.      
54c0: 73 71 6c 69 74 65 45 78 70 72 49 66 54 72 75 65  sqliteExprIfTrue
54d0: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
54e0: 70 4c 65 66 74 2c 20 64 65 73 74 29 3b 0a 20 20  pLeft, dest);.  
54f0: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 49 66      sqliteExprIf
5500: 54 72 75 65 28 70 50 61 72 73 65 2c 20 70 45 78  True(pParse, pEx
5510: 70 72 2d 3e 70 52 69 67 68 74 2c 20 64 65 73 74  pr->pRight, dest
5520: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
5530: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
5540: 4b 5f 4e 4f 54 3a 20 7b 0a 20 20 20 20 20 20 73  K_NOT: {.      s
5550: 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73 65  qliteExprIfFalse
5560: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
5570: 70 4c 65 66 74 2c 20 64 65 73 74 29 3b 0a 20 20  pLeft, dest);.  
5580: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
5590: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 54 3a  .    case TK_LT:
55a0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 45 3a  .    case TK_LE:
55b0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 54 3a  .    case TK_GT:
55c0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 45 3a  .    case TK_GE:
55d0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 45 3a  .    case TK_NE:
55e0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 45 51 3a  .    case TK_EQ:
55f0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 49 4b  .    case TK_LIK
5600: 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47  E:.    case TK_G
5610: 4c 4f 42 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c  LOB: {.      sql
5620: 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72  iteExprCode(pPar
5630: 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74  se, pExpr->pLeft
5640: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45  );.      sqliteE
5650: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
5660: 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a  pExpr->pRight);.
5670: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
5680: 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20 30 2c 20  AddOp(v, op, 0, 
5690: 64 65 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65  dest);.      bre
56a0: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61  ak;.    }.    ca
56b0: 73 65 20 54 4b 5f 49 53 4e 55 4c 4c 3a 0a 20 20  se TK_ISNULL:.  
56c0: 20 20 63 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c    case TK_NOTNUL
56d0: 4c 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  L: {.      sqlit
56e0: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
56f0: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
5700: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
5710: 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20 30 2c  eAddOp(v, op, 0,
5720: 20 64 65 73 74 29 3b 0a 20 20 20 20 20 20 62 72   dest);.      br
5730: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63  eak;.    }.    c
5740: 61 73 65 20 54 4b 5f 49 4e 3a 20 7b 0a 20 20 20  ase TK_IN: {.   
5750: 20 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64     sqliteExprCod
5760: 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  e(pParse, pExpr-
5770: 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 69  >pLeft);.      i
5780: 66 28 20 70 45 78 70 72 2d 3e 70 53 65 6c 65 63  f( pExpr->pSelec
5790: 74 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  t ){.        sql
57a0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
57b0: 4f 50 5f 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d  OP_Found, pExpr-
57c0: 3e 69 54 61 62 6c 65 2c 20 64 65 73 74 29 3b 0a  >iTable, dest);.
57d0: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
57e0: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
57f0: 64 64 4f 70 28 76 2c 20 4f 50 5f 53 65 74 46 6f  ddOp(v, OP_SetFo
5800: 75 6e 64 2c 20 70 45 78 70 72 2d 3e 69 54 61 62  und, pExpr->iTab
5810: 6c 65 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20  le, dest);.     
5820: 20 7d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a   }.      break;.
5830: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
5840: 4b 5f 42 45 54 57 45 45 4e 3a 20 7b 0a 20 20 20  K_BETWEEN: {.   
5850: 20 20 20 69 6e 74 20 6c 62 6c 20 3d 20 73 71 6c     int lbl = sql
5860: 69 74 65 56 64 62 65 4d 61 6b 65 4c 61 62 65 6c  iteVdbeMakeLabel
5870: 28 76 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  (v);.      sqlit
5880: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
5890: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
58a0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
58b0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 44 75 70  eAddOp(v, OP_Dup
58c0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73  , 0, 0);.      s
58d0: 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50  qliteExprCode(pP
58e0: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69  arse, pExpr->pLi
58f0: 73 74 2d 3e 61 5b 30 5d 2e 70 45 78 70 72 29 3b  st->a[0].pExpr);
5900: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
5910: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4c 74 2c  eAddOp(v, OP_Lt,
5920: 20 30 2c 20 6c 62 6c 29 3b 0a 20 20 20 20 20 20   0, lbl);.      
5930: 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70  sqliteExprCode(p
5940: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c  Parse, pExpr->pL
5950: 69 73 74 2d 3e 61 5b 31 5d 2e 70 45 78 70 72 29  ist->a[1].pExpr)
5960: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64  ;.      sqliteVd
5970: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4c 65  beAddOp(v, OP_Le
5980: 2c 20 30 2c 20 64 65 73 74 29 3b 0a 20 20 20 20  , 0, dest);.    
5990: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
59a0: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
59b0: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71   0, 0);.      sq
59c0: 6c 69 74 65 56 64 62 65 52 65 73 6f 6c 76 65 4c  liteVdbeResolveL
59d0: 61 62 65 6c 28 76 2c 20 6c 62 6c 29 3b 0a 20 20  abel(v, lbl);.  
59e0: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
59f0: 64 4f 70 28 76 2c 20 4f 50 5f 50 6f 70 2c 20 31  dOp(v, OP_Pop, 1
5a00: 2c 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61  , 0);.      brea
5a10: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 64 65 66  k;.    }.    def
5a20: 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20 73 71  ault: {.      sq
5a30: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
5a40: 72 73 65 2c 20 70 45 78 70 72 29 3b 0a 20 20 20  rse, pExpr);.   
5a50: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
5a60: 4f 70 28 76 2c 20 4f 50 5f 49 66 2c 20 30 2c 20  Op(v, OP_If, 0, 
5a70: 64 65 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65  dest);.      bre
5a80: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a  ak;.    }.  }.}.
5a90: 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20  ./*.** Generate 
5aa0: 63 6f 64 65 20 66 6f 72 20 61 20 62 6f 6f 6c 65  code for a boole
5ab0: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 73 75  an expression su
5ac0: 63 68 20 74 68 61 74 20 61 20 6a 75 6d 70 20 69  ch that a jump i
5ad0: 73 20 6d 61 64 65 0a 2a 2a 20 74 6f 20 74 68 65  s made.** to the
5ae0: 20 6c 61 62 65 6c 20 22 64 65 73 74 22 20 69 66   label "dest" if
5af0: 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20   the expression 
5b00: 69 73 20 66 61 6c 73 65 20 62 75 74 20 65 78 65  is false but exe
5b10: 63 75 74 69 6f 6e 0a 2a 2a 20 63 6f 6e 74 69 6e  cution.** contin
5b20: 75 65 73 20 73 74 72 61 69 67 68 74 20 74 68 72  ues straight thr
5b30: 75 20 69 66 20 74 68 65 20 65 78 70 72 65 73 73  u if the express
5b40: 69 6f 6e 20 69 73 20 74 72 75 65 2e 0a 2a 2f 0a  ion is true..*/.
5b50: 76 6f 69 64 20 73 71 6c 69 74 65 45 78 70 72 49  void sqliteExprI
5b60: 66 46 61 6c 73 65 28 50 61 72 73 65 20 2a 70 50  fFalse(Parse *pP
5b70: 61 72 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70  arse, Expr *pExp
5b80: 72 2c 20 69 6e 74 20 64 65 73 74 29 7b 0a 20 20  r, int dest){.  
5b90: 56 64 62 65 20 2a 76 20 3d 20 70 50 61 72 73 65  Vdbe *v = pParse
5ba0: 2d 3e 70 56 64 62 65 3b 0a 20 20 69 6e 74 20 6f  ->pVdbe;.  int o
5bb0: 70 20 3d 20 30 3b 0a 20 20 69 66 28 20 76 3d 3d  p = 0;.  if( v==
5bc0: 30 20 7c 7c 20 70 45 78 70 72 3d 3d 30 20 29 20  0 || pExpr==0 ) 
5bd0: 72 65 74 75 72 6e 3b 0a 20 20 73 77 69 74 63 68  return;.  switch
5be0: 28 20 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20  ( pExpr->op ){. 
5bf0: 20 20 20 63 61 73 65 20 54 4b 5f 4c 54 3a 20 20     case TK_LT:  
5c00: 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 65 3b       op = OP_Ge;
5c10: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
5c20: 20 20 63 61 73 65 20 54 4b 5f 4c 45 3a 20 20 20    case TK_LE:   
5c30: 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 74 3b 20      op = OP_Gt; 
5c40: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
5c50: 20 63 61 73 65 20 54 4b 5f 47 54 3a 20 20 20 20   case TK_GT:    
5c60: 20 20 20 6f 70 20 3d 20 4f 50 5f 4c 65 3b 20 20     op = OP_Le;  
5c70: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
5c80: 63 61 73 65 20 54 4b 5f 47 45 3a 20 20 20 20 20  case TK_GE:     
5c90: 20 20 6f 70 20 3d 20 4f 50 5f 4c 74 3b 20 20 20    op = OP_Lt;   
5ca0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
5cb0: 61 73 65 20 54 4b 5f 4e 45 3a 20 20 20 20 20 20  ase TK_NE:      
5cc0: 20 6f 70 20 3d 20 4f 50 5f 45 71 3b 20 20 20 20   op = OP_Eq;    
5cd0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
5ce0: 73 65 20 54 4b 5f 45 51 3a 20 20 20 20 20 20 20  se TK_EQ:       
5cf0: 6f 70 20 3d 20 4f 50 5f 4e 65 3b 20 20 20 20 20  op = OP_Ne;     
5d00: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
5d10: 65 20 54 4b 5f 4c 49 4b 45 3a 20 20 20 20 20 6f  e TK_LIKE:     o
5d20: 70 20 3d 20 4f 50 5f 4c 69 6b 65 3b 20 20 20 20  p = OP_Like;    
5d30: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
5d40: 20 54 4b 5f 47 4c 4f 42 3a 20 20 20 20 20 6f 70   TK_GLOB:     op
5d50: 20 3d 20 4f 50 5f 47 6c 6f 62 3b 20 20 20 20 20   = OP_Glob;     
5d60: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
5d70: 54 4b 5f 49 53 4e 55 4c 4c 3a 20 20 20 6f 70 20  TK_ISNULL:   op 
5d80: 3d 20 4f 50 5f 4e 6f 74 4e 75 6c 6c 3b 20 20 62  = OP_NotNull;  b
5d90: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
5da0: 4b 5f 4e 4f 54 4e 55 4c 4c 3a 20 20 6f 70 20 3d  K_NOTNULL:  op =
5db0: 20 4f 50 5f 49 73 4e 75 6c 6c 3b 20 20 20 62 72   OP_IsNull;   br
5dc0: 65 61 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c 74  eak;.    default
5dd0: 3a 20 20 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20  :  break;.  }.  
5de0: 73 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f  switch( pExpr->o
5df0: 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20 54 4b  p ){.    case TK
5e00: 5f 41 4e 44 3a 20 7b 0a 20 20 20 20 20 20 73 71  _AND: {.      sq
5e10: 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73 65 28  liteExprIfFalse(
5e20: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
5e30: 4c 65 66 74 2c 20 64 65 73 74 29 3b 0a 20 20 20  Left, dest);.   
5e40: 20 20 20 73 71 6c 69 74 65 45 78 70 72 49 66 46     sqliteExprIfF
5e50: 61 6c 73 65 28 70 50 61 72 73 65 2c 20 70 45 78  alse(pParse, pEx
5e60: 70 72 2d 3e 70 52 69 67 68 74 2c 20 64 65 73 74  pr->pRight, dest
5e70: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
5e80: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
5e90: 4b 5f 4f 52 3a 20 7b 0a 20 20 20 20 20 20 69 6e  K_OR: {.      in
5ea0: 74 20 64 32 20 3d 20 73 71 6c 69 74 65 56 64 62  t d2 = sqliteVdb
5eb0: 65 4d 61 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20  eMakeLabel(v);. 
5ec0: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 49       sqliteExprI
5ed0: 66 54 72 75 65 28 70 50 61 72 73 65 2c 20 70 45  fTrue(pParse, pE
5ee0: 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64 32 29 3b  xpr->pLeft, d2);
5ef0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
5f00: 72 49 66 46 61 6c 73 65 28 70 50 61 72 73 65 2c  rIfFalse(pParse,
5f10: 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 2c 20   pExpr->pRight, 
5f20: 64 65 73 74 29 3b 0a 20 20 20 20 20 20 73 71 6c  dest);.      sql
5f30: 69 74 65 56 64 62 65 52 65 73 6f 6c 76 65 4c 61  iteVdbeResolveLa
5f40: 62 65 6c 28 76 2c 20 64 32 29 3b 0a 20 20 20 20  bel(v, d2);.    
5f50: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20    break;.    }. 
5f60: 20 20 20 63 61 73 65 20 54 4b 5f 4e 4f 54 3a 20     case TK_NOT: 
5f70: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78  {.      sqliteEx
5f80: 70 72 49 66 54 72 75 65 28 70 50 61 72 73 65 2c  prIfTrue(pParse,
5f90: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64   pExpr->pLeft, d
5fa0: 65 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61  est);.      brea
5fb0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
5fc0: 65 20 54 4b 5f 4c 54 3a 0a 20 20 20 20 63 61 73  e TK_LT:.    cas
5fd0: 65 20 54 4b 5f 4c 45 3a 0a 20 20 20 20 63 61 73  e TK_LE:.    cas
5fe0: 65 20 54 4b 5f 47 54 3a 0a 20 20 20 20 63 61 73  e TK_GT:.    cas
5ff0: 65 20 54 4b 5f 47 45 3a 0a 20 20 20 20 63 61 73  e TK_GE:.    cas
6000: 65 20 54 4b 5f 4e 45 3a 0a 20 20 20 20 63 61 73  e TK_NE:.    cas
6010: 65 20 54 4b 5f 45 51 3a 20 7b 0a 20 20 20 20 20  e TK_EQ: {.     
6020: 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28   sqliteExprCode(
6030: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
6040: 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71 6c  Left);.      sql
6050: 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72  iteExprCode(pPar
6060: 73 65 2c 20 70 45 78 70 72 2d 3e 70 52 69 67 68  se, pExpr->pRigh
6070: 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  t);.      sqlite
6080: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c  VdbeAddOp(v, op,
6090: 20 30 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20   0, dest);.     
60a0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
60b0: 20 20 63 61 73 65 20 54 4b 5f 4c 49 4b 45 3a 0a    case TK_LIKE:.
60c0: 20 20 20 20 63 61 73 65 20 54 4b 5f 47 4c 4f 42      case TK_GLOB
60d0: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
60e0: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
60f0: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
6100: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
6110: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78  Code(pParse, pEx
6120: 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20  pr->pRight);.   
6130: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
6140: 4f 70 28 76 2c 20 6f 70 2c 20 31 2c 20 64 65 73  Op(v, op, 1, des
6150: 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  t);.      break;
6160: 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20  .    }.    case 
6170: 54 4b 5f 49 53 4e 55 4c 4c 3a 0a 20 20 20 20 63  TK_ISNULL:.    c
6180: 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a 20  ase TK_NOTNULL: 
6190: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78  {.      sqliteEx
61a0: 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70  prCode(pParse, p
61b0: 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20  Expr->pLeft);.  
61c0: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
61d0: 64 4f 70 28 76 2c 20 6f 70 2c 20 30 2c 20 64 65  dOp(v, op, 0, de
61e0: 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  st);.      break
61f0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
6200: 20 54 4b 5f 49 4e 3a 20 7b 0a 20 20 20 20 20 20   TK_IN: {.      
6210: 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70  sqliteExprCode(p
6220: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c  Parse, pExpr->pL
6230: 65 66 74 29 3b 0a 20 20 20 20 20 20 69 66 28 20  eft);.      if( 
6240: 70 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 20 29  pExpr->pSelect )
6250: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
6260: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6270: 4e 6f 74 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d  NotFound, pExpr-
6280: 3e 69 54 61 62 6c 65 2c 20 64 65 73 74 29 3b 0a  >iTable, dest);.
6290: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
62a0: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
62b0: 64 64 4f 70 28 76 2c 20 4f 50 5f 53 65 74 4e 6f  ddOp(v, OP_SetNo
62c0: 74 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d 3e 69  tFound, pExpr->i
62d0: 54 61 62 6c 65 2c 20 64 65 73 74 29 3b 0a 20 20  Table, dest);.  
62e0: 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61      }.      brea
62f0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
6300: 65 20 54 4b 5f 42 45 54 57 45 45 4e 3a 20 7b 0a  e TK_BETWEEN: {.
6310: 20 20 20 20 20 20 69 6e 74 20 61 64 64 72 3b 0a        int addr;.
6320: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
6330: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78  Code(pParse, pEx
6340: 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20  pr->pLeft);.    
6350: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
6360: 70 28 76 2c 20 4f 50 5f 44 75 70 2c 20 30 2c 20  p(v, OP_Dup, 0, 
6370: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
6380: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
6390: 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61   pExpr->pList->a
63a0: 5b 30 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20  [0].pExpr);.    
63b0: 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 56    addr = sqliteV
63c0: 64 62 65 43 75 72 72 65 6e 74 41 64 64 72 28 76  dbeCurrentAddr(v
63d0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  );.      sqliteV
63e0: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 47  dbeAddOp(v, OP_G
63f0: 65 2c 20 30 2c 20 61 64 64 72 2b 33 29 3b 0a 20  e, 0, addr+3);. 
6400: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
6410: 64 64 4f 70 28 76 2c 20 4f 50 5f 50 6f 70 2c 20  ddOp(v, OP_Pop, 
6420: 31 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  1, 0);.      sql
6430: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
6440: 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20 64 65 73 74  OP_Goto, 0, dest
6450: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45  );.      sqliteE
6460: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
6470: 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b  pExpr->pList->a[
6480: 31 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20  1].pExpr);.     
6490: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
64a0: 28 76 2c 20 4f 50 5f 47 74 2c 20 30 2c 20 64 65  (v, OP_Gt, 0, de
64b0: 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  st);.      break
64c0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 64 65 66 61  ;.    }.    defa
64d0: 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c  ult: {.      sql
64e0: 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72  iteExprCode(pPar
64f0: 73 65 2c 20 70 45 78 70 72 29 3b 0a 20 20 20 20  se, pExpr);.    
6500: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
6510: 70 28 76 2c 20 4f 50 5f 4e 6f 74 2c 20 30 2c 20  p(v, OP_Not, 0, 
6520: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
6530: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6540: 49 66 2c 20 30 2c 20 64 65 73 74 29 3b 0a 20 20  If, 0, dest);.  
6550: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
6560: 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 44 6f  .  }.}../*.** Do
6570: 20 61 20 64 65 65 70 20 63 6f 6d 70 61 72 69 73   a deep comparis
6580: 6f 6e 20 6f 66 20 74 77 6f 20 65 78 70 72 65 73  on of two expres
6590: 73 69 6f 6e 20 74 72 65 65 73 2e 20 20 52 65 74  sion trees.  Ret
65a0: 75 72 6e 20 54 52 55 45 20 28 6e 6f 6e 2d 7a 65  urn TRUE (non-ze
65b0: 72 6f 29 0a 2a 2a 20 69 66 20 74 68 65 79 20 61  ro).** if they a
65c0: 72 65 20 69 64 65 6e 74 69 63 61 6c 20 61 6e 64  re identical and
65d0: 20 72 65 74 75 72 6e 20 46 41 4c 53 45 20 69 66   return FALSE if
65e0: 20 74 68 65 79 20 64 69 66 66 65 72 20 69 6e 20   they differ in 
65f0: 61 6e 79 20 77 61 79 2e 0a 2a 2f 0a 69 6e 74 20  any way..*/.int 
6600: 73 71 6c 69 74 65 45 78 70 72 43 6f 6d 70 61 72  sqliteExprCompar
6610: 65 28 45 78 70 72 20 2a 70 41 2c 20 45 78 70 72  e(Expr *pA, Expr
6620: 20 2a 70 42 29 7b 0a 20 20 69 6e 74 20 69 3b 0a   *pB){.  int i;.
6630: 20 20 69 66 28 20 70 41 3d 3d 30 20 29 7b 0a 20    if( pA==0 ){. 
6640: 20 20 20 72 65 74 75 72 6e 20 70 42 3d 3d 30 3b     return pB==0;
6650: 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 70 42 3d  .  }else if( pB=
6660: 3d 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e  =0 ){.    return
6670: 20 30 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70 41   0;.  }.  if( pA
6680: 2d 3e 6f 70 21 3d 70 42 2d 3e 6f 70 20 29 20 72  ->op!=pB->op ) r
6690: 65 74 75 72 6e 20 30 3b 0a 20 20 69 66 28 20 21  eturn 0;.  if( !
66a0: 73 71 6c 69 74 65 45 78 70 72 43 6f 6d 70 61 72  sqliteExprCompar
66b0: 65 28 70 41 2d 3e 70 4c 65 66 74 2c 20 70 42 2d  e(pA->pLeft, pB-
66c0: 3e 70 4c 65 66 74 29 20 29 20 72 65 74 75 72 6e  >pLeft) ) return
66d0: 20 30 3b 0a 20 20 69 66 28 20 21 73 71 6c 69 74   0;.  if( !sqlit
66e0: 65 45 78 70 72 43 6f 6d 70 61 72 65 28 70 41 2d  eExprCompare(pA-
66f0: 3e 70 52 69 67 68 74 2c 20 70 42 2d 3e 70 52 69  >pRight, pB->pRi
6700: 67 68 74 29 20 29 20 72 65 74 75 72 6e 20 30 3b  ght) ) return 0;
6710: 0a 20 20 69 66 28 20 70 41 2d 3e 70 4c 69 73 74  .  if( pA->pList
6720: 20 29 7b 0a 20 20 20 20 69 66 28 20 70 42 2d 3e   ){.    if( pB->
6730: 70 4c 69 73 74 3d 3d 30 20 29 20 72 65 74 75 72  pList==0 ) retur
6740: 6e 20 30 3b 0a 20 20 20 20 69 66 28 20 70 41 2d  n 0;.    if( pA-
6750: 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 21 3d 70  >pList->nExpr!=p
6760: 42 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 20  B->pList->nExpr 
6770: 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20  ) return 0;.    
6780: 66 6f 72 28 69 3d 30 3b 20 69 3c 70 41 2d 3e 70  for(i=0; i<pA->p
6790: 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b  List->nExpr; i++
67a0: 29 7b 0a 20 20 20 20 20 20 69 66 28 20 21 73 71  ){.      if( !sq
67b0: 6c 69 74 65 45 78 70 72 43 6f 6d 70 61 72 65 28  liteExprCompare(
67c0: 70 41 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e  pA->pList->a[i].
67d0: 70 45 78 70 72 2c 20 70 42 2d 3e 70 4c 69 73 74  pExpr, pB->pList
67e0: 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 29 20 29 7b  ->a[i].pExpr) ){
67f0: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
6800: 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  0;.      }.    }
6810: 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 70 42 2d  .  }else if( pB-
6820: 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20 20 72 65  >pList ){.    re
6830: 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20 20 69 66  turn 0;.  }.  if
6840: 28 20 70 41 2d 3e 70 53 65 6c 65 63 74 20 7c 7c  ( pA->pSelect ||
6850: 20 70 42 2d 3e 70 53 65 6c 65 63 74 20 29 20 72   pB->pSelect ) r
6860: 65 74 75 72 6e 20 30 3b 0a 20 20 69 66 28 20 70  eturn 0;.  if( p
6870: 41 2d 3e 74 6f 6b 65 6e 2e 7a 20 29 7b 0a 20 20  A->token.z ){.  
6880: 20 20 69 66 28 20 70 42 2d 3e 74 6f 6b 65 6e 2e    if( pB->token.
6890: 7a 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b  z==0 ) return 0;
68a0: 0a 20 20 20 20 69 66 28 20 70 42 2d 3e 74 6f 6b  .    if( pB->tok
68b0: 65 6e 2e 6e 21 3d 70 41 2d 3e 74 6f 6b 65 6e 2e  en.n!=pA->token.
68c0: 6e 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  n ) return 0;.  
68d0: 20 20 69 66 28 20 73 71 6c 69 74 65 53 74 72 4e    if( sqliteStrN
68e0: 49 43 6d 70 28 70 41 2d 3e 74 6f 6b 65 6e 2e 7a  ICmp(pA->token.z
68f0: 2c 20 70 42 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70  , pB->token.z, p
6900: 41 2d 3e 74 6f 6b 65 6e 2e 6e 29 21 3d 30 20 29  A->token.n)!=0 )
6910: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20   return 0;.  }. 
6920: 20 72 65 74 75 72 6e 20 31 3b 0a 7d 0a 0a 2f 2a   return 1;.}../*
6930: 0a 2a 2a 20 41 64 64 20 61 20 6e 65 77 20 65 6c  .** Add a new el
6940: 65 6d 65 6e 74 20 74 6f 20 74 68 65 20 70 50 61  ement to the pPa
6950: 72 73 65 2d 3e 61 41 67 67 5b 5d 20 61 72 72 61  rse->aAgg[] arra
6960: 79 20 61 6e 64 20 72 65 74 75 72 6e 20 69 74 73  y and return its
6970: 20 69 6e 64 65 78 2e 0a 2a 2f 0a 73 74 61 74 69   index..*/.stati
6980: 63 20 69 6e 74 20 61 70 70 65 6e 64 41 67 67 49  c int appendAggI
6990: 6e 66 6f 28 50 61 72 73 65 20 2a 70 50 61 72 73  nfo(Parse *pPars
69a0: 65 29 7b 0a 20 20 69 66 28 20 28 70 50 61 72 73  e){.  if( (pPars
69b0: 65 2d 3e 6e 41 67 67 20 26 20 30 78 37 29 3d 3d  e->nAgg & 0x7)==
69c0: 30 20 29 7b 0a 20 20 20 20 69 6e 74 20 61 6d 74  0 ){.    int amt
69d0: 20 3d 20 70 50 61 72 73 65 2d 3e 6e 41 67 67 20   = pParse->nAgg 
69e0: 2b 20 38 3b 0a 20 20 20 20 70 50 61 72 73 65 2d  + 8;.    pParse-
69f0: 3e 61 41 67 67 20 3d 20 73 71 6c 69 74 65 52 65  >aAgg = sqliteRe
6a00: 61 6c 6c 6f 63 28 70 50 61 72 73 65 2d 3e 61 41  alloc(pParse->aA
6a10: 67 67 2c 20 61 6d 74 2a 73 69 7a 65 6f 66 28 70  gg, amt*sizeof(p
6a20: 50 61 72 73 65 2d 3e 61 41 67 67 5b 30 5d 29 29  Parse->aAgg[0]))
6a30: 3b 0a 20 20 20 20 69 66 28 20 70 50 61 72 73 65  ;.    if( pParse
6a40: 2d 3e 61 41 67 67 3d 3d 30 20 29 7b 0a 20 20 20  ->aAgg==0 ){.   
6a50: 20 20 20 70 50 61 72 73 65 2d 3e 6e 41 67 67 20     pParse->nAgg 
6a60: 3d 20 30 3b 0a 20 20 20 20 20 20 72 65 74 75 72  = 0;.      retur
6a70: 6e 20 2d 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  n -1;.    }.  }.
6a80: 20 20 6d 65 6d 73 65 74 28 26 70 50 61 72 73 65    memset(&pParse
6a90: 2d 3e 61 41 67 67 5b 70 50 61 72 73 65 2d 3e 6e  ->aAgg[pParse->n
6aa0: 41 67 67 5d 2c 20 30 2c 20 73 69 7a 65 6f 66 28  Agg], 0, sizeof(
6ab0: 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 30 5d 29  pParse->aAgg[0])
6ac0: 29 3b 0a 20 20 72 65 74 75 72 6e 20 70 50 61 72  );.  return pPar
6ad0: 73 65 2d 3e 6e 41 67 67 2b 2b 3b 0a 7d 0a 0a 2f  se->nAgg++;.}../
6ae0: 2a 0a 2a 2a 20 41 6e 61 6c 79 7a 65 20 74 68 65  *.** Analyze the
6af0: 20 67 69 76 65 6e 20 65 78 70 72 65 73 73 69 6f   given expressio
6b00: 6e 20 6c 6f 6f 6b 69 6e 67 20 66 6f 72 20 61 67  n looking for ag
6b10: 67 72 65 67 61 74 65 20 66 75 6e 63 74 69 6f 6e  gregate function
6b20: 73 20 61 6e 64 0a 2a 2a 20 66 6f 72 20 76 61 72  s and.** for var
6b30: 69 61 62 6c 65 73 20 74 68 61 74 20 6e 65 65 64  iables that need
6b40: 20 74 6f 20 62 65 20 61 64 64 65 64 20 74 6f 20   to be added to 
6b50: 74 68 65 20 70 50 61 72 73 65 2d 3e 61 41 67 67  the pParse->aAgg
6b60: 5b 5d 20 61 72 72 61 79 2e 0a 2a 2a 20 4d 61 6b  [] array..** Mak
6b70: 65 20 61 64 64 69 74 69 6f 6e 61 6c 20 65 6e 74  e additional ent
6b80: 72 69 65 73 20 74 6f 20 74 68 65 20 70 50 61 72  ries to the pPar
6b90: 73 65 2d 3e 61 41 67 67 5b 5d 20 61 72 72 61 79  se->aAgg[] array
6ba0: 20 61 73 20 6e 65 63 65 73 73 61 72 79 2e 0a 2a   as necessary..*
6bb0: 2a 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69 6e  *.** This routin
6bc0: 65 20 73 68 6f 75 6c 64 20 6f 6e 6c 79 20 62 65  e should only be
6bd0: 20 63 61 6c 6c 65 64 20 61 66 74 65 72 20 74 68   called after th
6be0: 65 20 65 78 70 72 65 73 73 69 6f 6e 20 68 61 73  e expression has
6bf0: 20 62 65 65 6e 0a 2a 2a 20 61 6e 61 6c 79 7a 65   been.** analyze
6c00: 64 20 62 79 20 73 71 6c 69 74 65 45 78 70 72 52  d by sqliteExprR
6c10: 65 73 6f 6c 76 65 49 64 73 28 29 20 61 6e 64 20  esolveIds() and 
6c20: 73 71 6c 69 74 65 45 78 70 72 43 68 65 63 6b 28  sqliteExprCheck(
6c30: 29 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 65 72 72 6f  )..**.** If erro
6c40: 72 73 20 61 72 65 20 73 65 65 6e 2c 20 6c 65 61  rs are seen, lea
6c50: 76 65 20 61 6e 20 65 72 72 6f 72 20 6d 65 73 73  ve an error mess
6c60: 61 67 65 20 69 6e 20 7a 45 72 72 4d 73 67 20 61  age in zErrMsg a
6c70: 6e 64 20 72 65 74 75 72 6e 0a 2a 2a 20 74 68 65  nd return.** the
6c80: 20 6e 75 6d 62 65 72 20 6f 66 20 65 72 72 6f 72   number of error
6c90: 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  s..*/.int sqlite
6ca0: 45 78 70 72 41 6e 61 6c 79 7a 65 41 67 67 72 65  ExprAnalyzeAggre
6cb0: 67 61 74 65 73 28 50 61 72 73 65 20 2a 70 50 61  gates(Parse *pPa
6cc0: 72 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70 72  rse, Expr *pExpr
6cd0: 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 41 67  ){.  int i;.  Ag
6ce0: 67 45 78 70 72 20 2a 61 41 67 67 3b 0a 20 20 69  gExpr *aAgg;.  i
6cf0: 6e 74 20 6e 45 72 72 20 3d 20 30 3b 0a 0a 20 20  nt nErr = 0;..  
6d00: 69 66 28 20 70 45 78 70 72 3d 3d 30 20 29 20 72  if( pExpr==0 ) r
6d10: 65 74 75 72 6e 20 30 3b 0a 20 20 73 77 69 74 63  eturn 0;.  switc
6d20: 68 28 20 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a  h( pExpr->op ){.
6d30: 20 20 20 20 63 61 73 65 20 54 4b 5f 43 4f 4c 55      case TK_COLU
6d40: 4d 4e 3a 20 7b 0a 20 20 20 20 20 20 61 41 67 67  MN: {.      aAgg
6d50: 20 3d 20 70 50 61 72 73 65 2d 3e 61 41 67 67 3b   = pParse->aAgg;
6d60: 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20  .      for(i=0; 
6d70: 69 3c 70 50 61 72 73 65 2d 3e 6e 41 67 67 3b 20  i<pParse->nAgg; 
6d80: 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 69 66  i++){.        if
6d90: 28 20 61 41 67 67 5b 69 5d 2e 69 73 41 67 67 20  ( aAgg[i].isAgg 
6da0: 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20  ) continue;.    
6db0: 20 20 20 20 69 66 28 20 61 41 67 67 5b 69 5d 2e      if( aAgg[i].
6dc0: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 3d 3d 70  pExpr->iTable==p
6dd0: 45 78 70 72 2d 3e 69 54 61 62 6c 65 0a 20 20 20  Expr->iTable.   
6de0: 20 20 20 20 20 20 26 26 20 61 41 67 67 5b 69 5d        && aAgg[i]
6df0: 2e 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 3d  .pExpr->iColumn=
6e00: 3d 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20  =pExpr->iColumn 
6e10: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 62 72 65  ){.          bre
6e20: 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ak;.        }.  
6e30: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
6e40: 69 3e 3d 70 50 61 72 73 65 2d 3e 6e 41 67 67 20  i>=pParse->nAgg 
6e50: 29 7b 0a 20 20 20 20 20 20 20 20 69 20 3d 20 61  ){.        i = a
6e60: 70 70 65 6e 64 41 67 67 49 6e 66 6f 28 70 50 61  ppendAggInfo(pPa
6e70: 72 73 65 29 3b 0a 20 20 20 20 20 20 20 20 69 66  rse);.        if
6e80: 28 20 69 3c 30 20 29 20 72 65 74 75 72 6e 20 31  ( i<0 ) return 1
6e90: 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72 73 65  ;.        pParse
6ea0: 2d 3e 61 41 67 67 5b 69 5d 2e 69 73 41 67 67 20  ->aAgg[i].isAgg 
6eb0: 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 70 50 61  = 0;.        pPa
6ec0: 72 73 65 2d 3e 61 41 67 67 5b 69 5d 2e 70 45 78  rse->aAgg[i].pEx
6ed0: 70 72 20 3d 20 70 45 78 70 72 3b 0a 20 20 20 20  pr = pExpr;.    
6ee0: 20 20 7d 0a 20 20 20 20 20 20 70 45 78 70 72 2d    }.      pExpr-
6ef0: 3e 69 41 67 67 20 3d 20 69 3b 0a 20 20 20 20 20  >iAgg = i;.     
6f00: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
6f10: 20 20 63 61 73 65 20 54 4b 5f 41 47 47 5f 46 55    case TK_AGG_FU
6f20: 4e 43 54 49 4f 4e 3a 20 7b 0a 20 20 20 20 20 20  NCTION: {.      
6f30: 69 66 28 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75  if( pExpr->iColu
6f40: 6d 6e 3d 3d 46 4e 5f 43 6f 75 6e 74 20 7c 7c 20  mn==FN_Count || 
6f50: 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 3d 3d  pExpr->iColumn==
6f60: 46 4e 5f 41 76 67 20 29 7b 0a 20 20 20 20 20 20  FN_Avg ){.      
6f70: 20 20 69 66 28 20 70 50 61 72 73 65 2d 3e 69 41    if( pParse->iA
6f80: 67 67 43 6f 75 6e 74 3e 3d 30 20 29 7b 0a 20 20  ggCount>=0 ){.  
6f90: 20 20 20 20 20 20 20 20 69 20 3d 20 70 50 61 72          i = pPar
6fa0: 73 65 2d 3e 69 41 67 67 43 6f 75 6e 74 3b 0a 20  se->iAggCount;. 
6fb0: 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20         }else{.  
6fc0: 20 20 20 20 20 20 20 20 69 20 3d 20 61 70 70 65          i = appe
6fd0: 6e 64 41 67 67 49 6e 66 6f 28 70 50 61 72 73 65  ndAggInfo(pParse
6fe0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  );.          if(
6ff0: 20 69 3c 30 20 29 20 72 65 74 75 72 6e 20 31 3b   i<0 ) return 1;
7000: 0a 20 20 20 20 20 20 20 20 20 20 70 50 61 72 73  .          pPars
7010: 65 2d 3e 61 41 67 67 5b 69 5d 2e 69 73 41 67 67  e->aAgg[i].isAgg
7020: 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20   = 1;.          
7030: 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 69 5d 2e  pParse->aAgg[i].
7040: 70 45 78 70 72 20 3d 20 30 3b 0a 20 20 20 20 20  pExpr = 0;.     
7050: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 69 41 67       pParse->iAg
7060: 67 43 6f 75 6e 74 20 3d 20 69 3b 0a 20 20 20 20  gCount = i;.    
7070: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69 66      }.        if
7080: 28 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e  ( pExpr->iColumn
7090: 3d 3d 46 4e 5f 43 6f 75 6e 74 20 29 7b 0a 20 20  ==FN_Count ){.  
70a0: 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69          pExpr->i
70b0: 41 67 67 20 3d 20 69 3b 0a 20 20 20 20 20 20 20  Agg = i;.       
70c0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
70d0: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20    }.      }.    
70e0: 20 20 61 41 67 67 20 3d 20 70 50 61 72 73 65 2d    aAgg = pParse-
70f0: 3e 61 41 67 67 3b 0a 20 20 20 20 20 20 66 6f 72  >aAgg;.      for
7100: 28 69 3d 30 3b 20 69 3c 70 50 61 72 73 65 2d 3e  (i=0; i<pParse->
7110: 6e 41 67 67 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  nAgg; i++){.    
7120: 20 20 20 20 69 66 28 20 21 61 41 67 67 5b 69 5d      if( !aAgg[i]
7130: 2e 69 73 41 67 67 20 29 20 63 6f 6e 74 69 6e 75  .isAgg ) continu
7140: 65 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 73  e;.        if( s
7150: 71 6c 69 74 65 45 78 70 72 43 6f 6d 70 61 72 65  qliteExprCompare
7160: 28 61 41 67 67 5b 69 5d 2e 70 45 78 70 72 2c 20  (aAgg[i].pExpr, 
7170: 70 45 78 70 72 29 20 29 7b 0a 20 20 20 20 20 20  pExpr) ){.      
7180: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20      break;.     
7190: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
71a0: 20 20 20 69 66 28 20 69 3e 3d 70 50 61 72 73 65     if( i>=pParse
71b0: 2d 3e 6e 41 67 67 20 29 7b 0a 20 20 20 20 20 20  ->nAgg ){.      
71c0: 20 20 69 20 3d 20 61 70 70 65 6e 64 41 67 67 49    i = appendAggI
71d0: 6e 66 6f 28 70 50 61 72 73 65 29 3b 0a 20 20 20  nfo(pParse);.   
71e0: 20 20 20 20 20 69 66 28 20 69 3c 30 20 29 20 72       if( i<0 ) r
71f0: 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 20  eturn 1;.       
7200: 20 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 69 5d   pParse->aAgg[i]
7210: 2e 69 73 41 67 67 20 3d 20 31 3b 0a 20 20 20 20  .isAgg = 1;.    
7220: 20 20 20 20 70 50 61 72 73 65 2d 3e 61 41 67 67      pParse->aAgg
7230: 5b 69 5d 2e 70 45 78 70 72 20 3d 20 70 45 78 70  [i].pExpr = pExp
7240: 72 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  r;.      }.     
7250: 20 70 45 78 70 72 2d 3e 69 41 67 67 20 3d 20 69   pExpr->iAgg = i
7260: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
7270: 20 20 20 7d 0a 20 20 20 20 64 65 66 61 75 6c 74     }.    default
7280: 3a 20 7b 0a 20 20 20 20 20 20 69 66 28 20 70 45  : {.      if( pE
7290: 78 70 72 2d 3e 70 4c 65 66 74 20 29 7b 0a 20 20  xpr->pLeft ){.  
72a0: 20 20 20 20 20 20 6e 45 72 72 20 3d 20 73 71 6c        nErr = sql
72b0: 69 74 65 45 78 70 72 41 6e 61 6c 79 7a 65 41 67  iteExprAnalyzeAg
72c0: 67 72 65 67 61 74 65 73 28 70 50 61 72 73 65 2c  gregates(pParse,
72d0: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
72e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
72f0: 28 20 6e 45 72 72 3d 3d 30 20 26 26 20 70 45 78  ( nErr==0 && pEx
7300: 70 72 2d 3e 70 52 69 67 68 74 20 29 7b 0a 20 20  pr->pRight ){.  
7310: 20 20 20 20 20 20 6e 45 72 72 20 3d 20 73 71 6c        nErr = sql
7320: 69 74 65 45 78 70 72 41 6e 61 6c 79 7a 65 41 67  iteExprAnalyzeAg
7330: 67 72 65 67 61 74 65 73 28 70 50 61 72 73 65 2c  gregates(pParse,
7340: 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 3b   pExpr->pRight);
7350: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69  .      }.      i
7360: 66 28 20 6e 45 72 72 3d 3d 30 20 26 26 20 70 45  f( nErr==0 && pE
7370: 78 70 72 2d 3e 70 4c 69 73 74 20 29 7b 0a 20 20  xpr->pList ){.  
7380: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 70 45        int n = pE
7390: 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70  xpr->pList->nExp
73a0: 72 3b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69  r;.        int i
73b0: 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d  ;.        for(i=
73c0: 30 3b 20 6e 45 72 72 3d 3d 30 20 26 26 20 69 3c  0; nErr==0 && i<
73d0: 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20  n; i++){.       
73e0: 20 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74 65     nErr = sqlite
73f0: 45 78 70 72 41 6e 61 6c 79 7a 65 41 67 67 72 65  ExprAnalyzeAggre
7400: 67 61 74 65 73 28 70 50 61 72 73 65 2c 20 70 45  gates(pParse, pE
7410: 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d  xpr->pList->a[i]
7420: 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 20  .pExpr);.       
7430: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
7440: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
7450: 7d 0a 20 20 72 65 74 75 72 6e 20 6e 45 72 72 3b  }.  return nErr;
7460: 0a 7d 0a                                         .}.