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

Artifact c4c24c3af1eba094a816522eb0e085bed518ee16:


0000: 2f 2a 0a 2a 2a 20 43 6f 70 79 72 69 67 68 74 20  /*.** Copyright 
0010: 28 63 29 20 31 39 39 39 2c 20 32 30 30 30 20 44  (c) 1999, 2000 D
0020: 2e 20 52 69 63 68 61 72 64 20 48 69 70 70 0a 2a  . Richard Hipp.*
0030: 2a 0a 2a 2a 20 54 68 69 73 20 70 72 6f 67 72 61  *.** This progra
0040: 6d 20 69 73 20 66 72 65 65 20 73 6f 66 74 77 61  m is free softwa
0050: 72 65 3b 20 79 6f 75 20 63 61 6e 20 72 65 64 69  re; you can redi
0060: 73 74 72 69 62 75 74 65 20 69 74 20 61 6e 64 2f  stribute it and/
0070: 6f 72 0a 2a 2a 20 6d 6f 64 69 66 79 20 69 74 20  or.** modify it 
0080: 75 6e 64 65 72 20 74 68 65 20 74 65 72 6d 73 20  under the terms 
0090: 6f 66 20 74 68 65 20 47 4e 55 20 47 65 6e 65 72  of the GNU Gener
00a0: 61 6c 20 50 75 62 6c 69 63 0a 2a 2a 20 4c 69 63  al Public.** Lic
00b0: 65 6e 73 65 20 61 73 20 70 75 62 6c 69 73 68 65  ense as publishe
00c0: 64 20 62 79 20 74 68 65 20 46 72 65 65 20 53 6f  d by the Free So
00d0: 66 74 77 61 72 65 20 46 6f 75 6e 64 61 74 69 6f  ftware Foundatio
00e0: 6e 3b 20 65 69 74 68 65 72 0a 2a 2a 20 76 65 72  n; either.** ver
00f0: 73 69 6f 6e 20 32 20 6f 66 20 74 68 65 20 4c 69  sion 2 of the Li
0100: 63 65 6e 73 65 2c 20 6f 72 20 28 61 74 20 79 6f  cense, or (at yo
0110: 75 72 20 6f 70 74 69 6f 6e 29 20 61 6e 79 20 6c  ur option) any l
0120: 61 74 65 72 20 76 65 72 73 69 6f 6e 2e 0a 2a 2a  ater version..**
0130: 0a 2a 2a 20 54 68 69 73 20 70 72 6f 67 72 61 6d  .** This program
0140: 20 69 73 20 64 69 73 74 72 69 62 75 74 65 64 20   is distributed 
0150: 69 6e 20 74 68 65 20 68 6f 70 65 20 74 68 61 74  in the hope that
0160: 20 69 74 20 77 69 6c 6c 20 62 65 20 75 73 65 66   it will be usef
0170: 75 6c 2c 0a 2a 2a 20 62 75 74 20 57 49 54 48 4f  ul,.** but WITHO
0180: 55 54 20 41 4e 59 20 57 41 52 52 41 4e 54 59 3b  UT ANY WARRANTY;
0190: 20 77 69 74 68 6f 75 74 20 65 76 65 6e 20 74 68   without even th
01a0: 65 20 69 6d 70 6c 69 65 64 20 77 61 72 72 61 6e  e implied warran
01b0: 74 79 20 6f 66 0a 2a 2a 20 4d 45 52 43 48 41 4e  ty of.** MERCHAN
01c0: 54 41 42 49 4c 49 54 59 20 6f 72 20 46 49 54 4e  TABILITY or FITN
01d0: 45 53 53 20 46 4f 52 20 41 20 50 41 52 54 49 43  ESS FOR A PARTIC
01e0: 55 4c 41 52 20 50 55 52 50 4f 53 45 2e 20 20 53  ULAR PURPOSE.  S
01f0: 65 65 20 74 68 65 20 47 4e 55 0a 2a 2a 20 47 65  ee the GNU.** Ge
0200: 6e 65 72 61 6c 20 50 75 62 6c 69 63 20 4c 69 63  neral Public Lic
0210: 65 6e 73 65 20 66 6f 72 20 6d 6f 72 65 20 64 65  ense for more de
0220: 74 61 69 6c 73 2e 0a 2a 2a 20 0a 2a 2a 20 59 6f  tails..** .** Yo
0230: 75 20 73 68 6f 75 6c 64 20 68 61 76 65 20 72 65  u should have re
0240: 63 65 69 76 65 64 20 61 20 63 6f 70 79 20 6f 66  ceived a copy of
0250: 20 74 68 65 20 47 4e 55 20 47 65 6e 65 72 61 6c   the GNU General
0260: 20 50 75 62 6c 69 63 0a 2a 2a 20 4c 69 63 65 6e   Public.** Licen
0270: 73 65 20 61 6c 6f 6e 67 20 77 69 74 68 20 74 68  se along with th
0280: 69 73 20 6c 69 62 72 61 72 79 3b 20 69 66 20 6e  is library; if n
0290: 6f 74 2c 20 77 72 69 74 65 20 74 6f 20 74 68 65  ot, write to the
02a0: 0a 2a 2a 20 46 72 65 65 20 53 6f 66 74 77 61 72  .** Free Softwar
02b0: 65 20 46 6f 75 6e 64 61 74 69 6f 6e 2c 20 49 6e  e Foundation, In
02c0: 63 2e 2c 20 35 39 20 54 65 6d 70 6c 65 20 50 6c  c., 59 Temple Pl
02d0: 61 63 65 20 2d 20 53 75 69 74 65 20 33 33 30 2c  ace - Suite 330,
02e0: 0a 2a 2a 20 42 6f 73 74 6f 6e 2c 20 4d 41 20 20  .** Boston, MA  
02f0: 30 32 31 31 31 2d 31 33 30 37 2c 20 55 53 41 2e  02111-1307, USA.
0300: 0a 2a 2a 0a 2a 2a 20 41 75 74 68 6f 72 20 63 6f  .**.** Author co
0310: 6e 74 61 63 74 20 69 6e 66 6f 72 6d 61 74 69 6f  ntact informatio
0320: 6e 3a 0a 2a 2a 20 20 20 64 72 68 40 68 77 61 63  n:.**   drh@hwac
0330: 69 2e 63 6f 6d 0a 2a 2a 20 20 20 68 74 74 70 3a  i.com.**   http:
0340: 2f 2f 77 77 77 2e 68 77 61 63 69 2e 63 6f 6d 2f  //www.hwaci.com/
0350: 64 72 68 2f 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a  drh/.**.********
0360: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0370: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0380: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0390: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
03a0: 2a 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63  *.** This file c
03b0: 6f 6e 74 61 69 6e 73 20 72 6f 75 74 69 6e 65 73  ontains routines
03c0: 20 75 73 65 64 20 66 6f 72 20 61 6e 61 6c 79 7a   used for analyz
03d0: 69 6e 67 20 65 78 70 72 65 73 73 69 6f 6e 73 20  ing expressions 
03e0: 61 6e 64 0a 2a 2a 20 66 6f 72 20 67 65 6e 65 72  and.** for gener
03f0: 61 74 69 6e 67 20 56 44 42 45 20 63 6f 64 65 20  ating VDBE code 
0400: 74 68 61 74 20 65 76 61 6c 75 61 74 65 73 20 65  that evaluates e
0410: 78 70 72 65 73 73 69 6f 6e 73 2e 0a 2a 2a 0a 2a  xpressions..**.*
0420: 2a 20 24 49 64 3a 20 65 78 70 72 2e 63 2c 76 20  * $Id: expr.c,v 
0430: 31 2e 32 34 20 32 30 30 31 2f 30 34 2f 31 31 20  1.24 2001/04/11 
0440: 31 34 3a 32 38 3a 34 32 20 64 72 68 20 45 78 70  14:28:42 drh Exp
0450: 20 24 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22   $.*/.#include "
0460: 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a 0a 2f 2a  sqliteInt.h"../*
0470: 0a 2a 2a 20 57 61 6c 6b 20 61 6e 20 65 78 70 72  .** Walk an expr
0480: 65 73 73 69 6f 6e 20 74 72 65 65 2e 20 20 52 65  ession tree.  Re
0490: 74 75 72 6e 20 31 20 69 66 20 74 68 65 20 65 78  turn 1 if the ex
04a0: 70 72 65 73 73 69 6f 6e 20 69 73 20 63 6f 6e 73  pression is cons
04b0: 74 61 6e 74 0a 2a 2a 20 61 6e 64 20 30 20 69 66  tant.** and 0 if
04c0: 20 69 74 20 69 6e 76 6f 6c 76 65 73 20 76 61 72   it involves var
04d0: 69 61 62 6c 65 73 2e 0a 2a 2f 0a 73 74 61 74 69  iables..*/.stati
04e0: 63 20 69 6e 74 20 69 73 43 6f 6e 73 74 61 6e 74  c int isConstant
04f0: 28 45 78 70 72 20 2a 70 29 7b 0a 20 20 73 77 69  (Expr *p){.  swi
0500: 74 63 68 28 20 70 2d 3e 6f 70 20 29 7b 0a 20 20  tch( p->op ){.  
0510: 20 20 63 61 73 65 20 54 4b 5f 49 44 3a 0a 20 20    case TK_ID:.  
0520: 20 20 63 61 73 65 20 54 4b 5f 43 4f 4c 55 4d 4e    case TK_COLUMN
0530: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 44 4f  :.    case TK_DO
0540: 54 3a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  T:.      return 
0550: 30 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20  0;.    default: 
0560: 7b 0a 20 20 20 20 20 20 69 66 28 20 70 2d 3e 70  {.      if( p->p
0570: 4c 65 66 74 20 26 26 20 21 69 73 43 6f 6e 73 74  Left && !isConst
0580: 61 6e 74 28 70 2d 3e 70 4c 65 66 74 29 20 29 20  ant(p->pLeft) ) 
0590: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20  return 0;.      
05a0: 69 66 28 20 70 2d 3e 70 52 69 67 68 74 20 26 26  if( p->pRight &&
05b0: 20 21 69 73 43 6f 6e 73 74 61 6e 74 28 70 2d 3e   !isConstant(p->
05c0: 70 52 69 67 68 74 29 20 29 20 72 65 74 75 72 6e  pRight) ) return
05d0: 20 30 3b 0a 20 20 20 20 20 20 69 66 28 20 70 2d   0;.      if( p-
05e0: 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20 20 20 20  >pList ){.      
05f0: 20 20 69 6e 74 20 69 3b 0a 20 20 20 20 20 20 20    int i;.       
0600: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 2d 3e 70   for(i=0; i<p->p
0610: 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b  List->nExpr; i++
0620: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  ){.          if(
0630: 20 21 69 73 43 6f 6e 73 74 61 6e 74 28 70 2d 3e   !isConstant(p->
0640: 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70  pList->a[i].pExp
0650: 72 29 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  r) ) return 0;. 
0660: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
0670: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
0680: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
0690: 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 61 6c   1;.}../*.** Wal
06a0: 6b 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e  k the expression
06b0: 20 74 72 65 65 20 61 6e 64 20 70 72 6f 63 65 73   tree and proces
06c0: 73 20 6f 70 65 72 61 74 6f 72 73 20 6f 66 20 74  s operators of t
06d0: 68 65 20 66 6f 72 6d 3a 0a 2a 2a 0a 2a 2a 20 20  he form:.**.**  
06e0: 20 20 20 20 20 65 78 70 72 20 49 4e 20 28 53 45       expr IN (SE
06f0: 4c 45 43 54 20 2e 2e 2e 29 0a 2a 2a 0a 2a 2a 20  LECT ...).**.** 
0700: 54 68 65 73 65 20 6f 70 65 72 61 74 6f 72 73 20  These operators 
0710: 68 61 76 65 20 74 6f 20 62 65 20 70 72 6f 63 65  have to be proce
0720: 73 73 65 64 20 62 65 66 6f 72 65 20 63 6f 6c 75  ssed before colu
0730: 6d 6e 20 6e 61 6d 65 73 20 61 72 65 0a 2a 2a 20  mn names are.** 
0740: 72 65 73 6f 6c 76 65 64 20 62 65 63 61 75 73 65  resolved because
0750: 20 65 61 63 68 20 73 75 63 68 20 6f 70 65 72 61   each such opera
0760: 74 6f 72 20 69 6e 63 72 65 6d 65 6e 74 73 20 70  tor increments p
0770: 50 61 72 73 65 2d 3e 6e 54 61 62 0a 2a 2a 20 74  Parse->nTab.** t
0780: 6f 20 72 65 73 65 72 76 65 20 63 75 72 73 6f 72  o reserve cursor
0790: 20 6e 75 6d 62 65 72 73 20 66 6f 72 20 69 74 73   numbers for its
07a0: 20 6f 77 6e 20 75 73 65 2e 20 20 42 75 74 20 70   own use.  But p
07b0: 50 61 72 73 65 2d 3e 6e 54 61 62 0a 2a 2a 20 6e  Parse->nTab.** n
07c0: 65 65 64 73 20 74 6f 20 62 65 20 63 6f 6e 73 74  eeds to be const
07d0: 61 6e 74 20 6f 6e 63 65 20 77 65 20 62 65 67 69  ant once we begi
07e0: 6e 20 72 65 73 6f 6c 76 69 6e 67 20 63 6f 6c 75  n resolving colu
07f0: 6d 6e 20 6e 61 6d 65 73 2e 0a 2a 2a 0a 2a 2a 20  mn names..**.** 
0800: 41 63 74 75 61 6c 6c 79 2c 20 74 68 65 20 70 72  Actually, the pr
0810: 6f 63 65 73 73 69 6e 67 20 6f 66 20 49 4e 2d 53  ocessing of IN-S
0820: 45 4c 45 43 54 20 69 73 20 6f 6e 6c 79 20 73 74  ELECT is only st
0830: 61 72 74 65 64 20 62 79 20 74 68 69 73 0a 2a 2a  arted by this.**
0840: 20 72 6f 75 74 69 6e 65 2e 20 20 54 68 69 73 20   routine.  This 
0850: 72 6f 75 74 69 6e 65 20 61 6c 6c 6f 63 61 74 65  routine allocate
0860: 73 20 61 20 63 75 72 73 6f 72 20 6e 75 6d 62 65  s a cursor numbe
0870: 72 20 74 6f 20 74 68 65 20 49 4e 2d 53 45 4c 45  r to the IN-SELE
0880: 43 54 0a 2a 2a 20 61 6e 64 20 74 68 65 6e 20 6d  CT.** and then m
0890: 6f 76 65 73 20 6f 6e 2e 20 20 54 68 65 20 63 6f  oves on.  The co
08a0: 64 65 20 67 65 6e 65 72 61 74 69 6f 6e 20 69 73  de generation is
08b0: 20 64 6f 6e 65 20 62 79 20 0a 2a 2a 20 73 71 6c   done by .** sql
08c0: 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65 49 64  iteExprResolveId
08d0: 73 28 29 20 77 68 69 63 68 20 6d 75 73 74 20 62  s() which must b
08e0: 65 20 63 61 6c 6c 65 64 20 61 66 74 65 72 77 61  e called afterwa
08f0: 72 64 73 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  rds..*/.void sql
0900: 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65 49 6e  iteExprResolveIn
0910: 53 65 6c 65 63 74 28 50 61 72 73 65 20 2a 70 50  Select(Parse *pP
0920: 61 72 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70  arse, Expr *pExp
0930: 72 29 7b 0a 20 20 69 66 28 20 70 45 78 70 72 3d  r){.  if( pExpr=
0940: 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20 20 69  =0 ) return;.  i
0950: 66 28 20 70 45 78 70 72 2d 3e 6f 70 3d 3d 54 4b  f( pExpr->op==TK
0960: 5f 49 4e 20 26 26 20 70 45 78 70 72 2d 3e 70 53  _IN && pExpr->pS
0970: 65 6c 65 63 74 21 3d 30 20 29 7b 0a 20 20 20 20  elect!=0 ){.    
0980: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20  pExpr->iTable = 
0990: 70 50 61 72 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a  pParse->nTab++;.
09a0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 69 66 28    }else{.    if(
09b0: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 29 20   pExpr->pLeft ) 
09c0: 73 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76  sqliteExprResolv
09d0: 65 49 6e 53 65 6c 65 63 74 28 70 50 61 72 73 65  eInSelect(pParse
09e0: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
09f0: 0a 20 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e  .    if( pExpr->
0a00: 70 52 69 67 68 74 20 29 20 73 71 6c 69 74 65 45  pRight ) sqliteE
0a10: 78 70 72 52 65 73 6f 6c 76 65 49 6e 53 65 6c 65  xprResolveInSele
0a20: 63 74 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  ct(pParse, pExpr
0a30: 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20 20 69  ->pRight);.    i
0a40: 66 28 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 20  f( pExpr->pList 
0a50: 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a  ){.      int i;.
0a60: 20 20 20 20 20 20 45 78 70 72 4c 69 73 74 20 2a        ExprList *
0a70: 70 4c 69 73 74 20 3d 20 70 45 78 70 72 2d 3e 70  pList = pExpr->p
0a80: 4c 69 73 74 3b 0a 20 20 20 20 20 20 66 6f 72 28  List;.      for(
0a90: 69 3d 30 3b 20 69 3c 70 4c 69 73 74 2d 3e 6e 45  i=0; i<pList->nE
0aa0: 78 70 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20  xpr; i++){.     
0ab0: 20 20 20 73 71 6c 69 74 65 45 78 70 72 52 65 73     sqliteExprRes
0ac0: 6f 6c 76 65 49 6e 53 65 6c 65 63 74 28 70 50 61  olveInSelect(pPa
0ad0: 72 73 65 2c 20 70 4c 69 73 74 2d 3e 61 5b 69 5d  rse, pList->a[i]
0ae0: 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 7d  .pExpr);.      }
0af0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a  .    }.  }.}../*
0b00: 0a 2a 2a 20 52 65 74 75 72 6e 20 54 52 55 45 20  .** Return TRUE 
0b10: 69 66 20 74 68 65 20 67 69 76 65 6e 20 73 74 72  if the given str
0b20: 69 6e 67 20 69 73 20 61 20 72 6f 77 2d 69 64 20  ing is a row-id 
0b30: 63 6f 6c 75 6d 6e 20 6e 61 6d 65 2e 0a 2a 2f 0a  column name..*/.
0b40: 73 74 61 74 69 63 20 69 6e 74 20 73 71 6c 69 74  static int sqlit
0b50: 65 49 73 52 6f 77 69 64 28 63 6f 6e 73 74 20 63  eIsRowid(const c
0b60: 68 61 72 20 2a 7a 29 7b 0a 20 20 69 66 28 20 73  har *z){.  if( s
0b70: 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 2c 20  qliteStrICmp(z, 
0b80: 22 5f 52 4f 57 49 44 5f 22 29 3d 3d 30 20 29 20  "_ROWID_")==0 ) 
0b90: 72 65 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20  return 1;.  if( 
0ba0: 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 2c  sqliteStrICmp(z,
0bb0: 20 22 52 4f 57 49 44 22 29 3d 3d 30 20 29 20 72   "ROWID")==0 ) r
0bc0: 65 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20 73  eturn 1;.  if( s
0bd0: 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 2c 20  qliteStrICmp(z, 
0be0: 22 4f 49 44 22 29 3d 3d 30 20 29 20 72 65 74 75  "OID")==0 ) retu
0bf0: 72 6e 20 31 3b 0a 20 20 72 65 74 75 72 6e 20 30  rn 1;.  return 0
0c00: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20  ;.}../*.** This 
0c10: 72 6f 75 74 69 6e 65 20 77 61 6c 6b 73 20 61 6e  routine walks an
0c20: 20 65 78 70 72 65 73 73 69 6f 6e 20 74 72 65 65   expression tree
0c30: 20 61 6e 64 20 72 65 73 6f 6c 76 65 73 20 72 65   and resolves re
0c40: 66 65 72 65 6e 63 65 73 20 74 6f 0a 2a 2a 20 74  ferences to.** t
0c50: 61 62 6c 65 20 63 6f 6c 75 6d 6e 73 2e 20 20 4e  able columns.  N
0c60: 6f 64 65 73 20 6f 66 20 74 68 65 20 66 6f 72 6d  odes of the form
0c70: 20 49 44 2e 49 44 20 6f 72 20 49 44 20 72 65 73   ID.ID or ID res
0c80: 6f 6c 76 65 20 69 6e 74 6f 20 61 6e 0a 2a 2a 20  olve into an.** 
0c90: 69 6e 64 65 78 20 74 6f 20 74 68 65 20 74 61 62  index to the tab
0ca0: 6c 65 20 69 6e 20 74 68 65 20 74 61 62 6c 65 20  le in the table 
0cb0: 6c 69 73 74 20 61 6e 64 20 61 20 63 6f 6c 75 6d  list and a colum
0cc0: 6e 20 6f 66 66 73 65 74 2e 20 20 54 68 65 20 6f  n offset.  The o
0cd0: 70 63 6f 64 65 0a 2a 2a 20 66 6f 72 20 73 75 63  pcode.** for suc
0ce0: 68 20 6e 6f 64 65 73 20 69 73 20 63 68 61 6e 67  h nodes is chang
0cf0: 65 64 20 74 6f 20 54 4b 5f 43 4f 4c 55 4d 4e 2e  ed to TK_COLUMN.
0d00: 20 20 54 68 65 20 69 54 61 62 6c 65 20 76 61 6c    The iTable val
0d10: 75 65 20 69 73 20 63 68 61 6e 67 65 64 0a 2a 2a  ue is changed.**
0d20: 20 74 6f 20 74 68 65 20 69 6e 64 65 78 20 6f 66   to the index of
0d30: 20 74 68 65 20 72 65 66 65 72 65 6e 63 65 64 20   the referenced 
0d40: 74 61 62 6c 65 20 69 6e 20 70 54 61 62 4c 69 73  table in pTabLis
0d50: 74 20 70 6c 75 73 20 74 68 65 20 70 50 61 72 73  t plus the pPars
0d60: 65 2d 3e 6e 54 61 62 0a 2a 2a 20 76 61 6c 75 65  e->nTab.** value
0d70: 2e 20 20 54 68 65 20 69 43 6f 6c 75 6d 6e 20 76  .  The iColumn v
0d80: 61 6c 75 65 20 69 73 20 63 68 61 6e 67 65 64 20  alue is changed 
0d90: 74 6f 20 74 68 65 20 69 6e 64 65 78 20 6f 66 20  to the index of 
0da0: 74 68 65 20 63 6f 6c 75 6d 6e 20 6f 66 20 74 68  the column of th
0db0: 65 20 0a 2a 2a 20 72 65 66 65 72 65 6e 63 65 64  e .** referenced
0dc0: 20 74 61 62 6c 65 2e 0a 2a 2a 0a 2a 2a 20 57 65   table..**.** We
0dd0: 20 61 6c 73 6f 20 63 68 65 63 6b 20 66 6f 72 20   also check for 
0de0: 69 6e 73 74 61 6e 63 65 73 20 6f 66 20 74 68 65  instances of the
0df0: 20 49 4e 20 6f 70 65 72 61 74 6f 72 2e 20 20 49   IN operator.  I
0e00: 4e 20 63 6f 6d 65 73 20 69 6e 20 74 77 6f 0a 2a  N comes in two.*
0e10: 2a 20 66 6f 72 6d 73 3a 0a 2a 2a 0a 2a 2a 20 20  * forms:.**.**  
0e20: 20 20 20 20 20 20 20 20 20 65 78 70 72 20 49 4e           expr IN
0e30: 20 28 65 78 70 72 6c 69 73 74 29 0a 2a 2a 20 61   (exprlist).** a
0e40: 6e 64 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20  nd.**           
0e50: 65 78 70 72 20 49 4e 20 28 53 45 4c 45 43 54 20  expr IN (SELECT 
0e60: 2e 2e 2e 29 0a 2a 2a 0a 2a 2a 20 54 68 65 20 66  ...).**.** The f
0e70: 69 72 73 74 20 66 6f 72 6d 20 69 73 20 68 61 6e  irst form is han
0e80: 64 6c 65 64 20 62 79 20 63 72 65 61 74 69 6e 67  dled by creating
0e90: 20 61 20 73 65 74 20 68 6f 6c 64 69 6e 67 20 74   a set holding t
0ea0: 68 65 20 6c 69 73 74 0a 2a 2a 20 6f 66 20 61 6c  he list.** of al
0eb0: 6c 6f 77 65 64 20 76 61 6c 75 65 73 2e 20 20 54  lowed values.  T
0ec0: 68 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d 20 63  he second form c
0ed0: 61 75 73 65 73 20 74 68 65 20 53 45 4c 45 43 54  auses the SELECT
0ee0: 20 74 6f 20 67 65 6e 65 72 61 74 65 20 0a 2a 2a   to generate .**
0ef0: 20 61 20 74 65 6d 70 6f 72 61 72 79 20 74 61 62   a temporary tab
0f00: 6c 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 72  le..**.** This r
0f10: 6f 75 74 69 6e 65 20 61 6c 73 6f 20 6c 6f 6f 6b  outine also look
0f20: 73 20 66 6f 72 20 73 63 61 6c 61 72 20 53 45 4c  s for scalar SEL
0f30: 45 43 54 73 20 74 68 61 74 20 61 72 65 20 70 61  ECTs that are pa
0f40: 72 74 20 6f 66 20 61 6e 20 65 78 70 72 65 73 73  rt of an express
0f50: 69 6f 6e 2e 0a 2a 2a 20 49 66 20 69 74 20 66 69  ion..** If it fi
0f60: 6e 64 73 20 61 6e 79 2c 20 69 74 20 67 65 6e 65  nds any, it gene
0f70: 72 61 74 65 73 20 63 6f 64 65 20 74 6f 20 77 72  rates code to wr
0f80: 69 74 65 20 74 68 65 20 76 61 6c 75 65 20 6f 66  ite the value of
0f90: 20 74 68 61 74 20 73 65 6c 65 63 74 0a 2a 2a 20   that select.** 
0fa0: 69 6e 74 6f 20 61 20 6d 65 6d 6f 72 79 20 63 65  into a memory ce
0fb0: 6c 6c 2e 0a 2a 2a 0a 2a 2a 20 55 6e 6b 6e 6f 77  ll..**.** Unknow
0fc0: 6e 20 63 6f 6c 75 6d 6e 73 20 6f 72 20 74 61 62  n columns or tab
0fd0: 6c 65 73 20 70 72 6f 76 6f 6b 65 20 61 6e 20 65  les provoke an e
0fe0: 72 72 6f 72 2e 20 20 54 68 65 20 66 75 6e 63 74  rror.  The funct
0ff0: 69 6f 6e 20 72 65 74 75 72 6e 73 0a 2a 2a 20 74  ion returns.** t
1000: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 65 72 72  he number of err
1010: 6f 72 73 20 73 65 65 6e 20 61 6e 64 20 6c 65 61  ors seen and lea
1020: 76 65 73 20 61 6e 20 65 72 72 6f 72 20 6d 65 73  ves an error mes
1030: 73 61 67 65 20 6f 6e 20 70 50 61 72 73 65 2d 3e  sage on pParse->
1040: 7a 45 72 72 4d 73 67 2e 0a 2a 2f 0a 69 6e 74 20  zErrMsg..*/.int 
1050: 73 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76  sqliteExprResolv
1060: 65 49 64 73 28 50 61 72 73 65 20 2a 70 50 61 72  eIds(Parse *pPar
1070: 73 65 2c 20 49 64 4c 69 73 74 20 2a 70 54 61 62  se, IdList *pTab
1080: 4c 69 73 74 2c 20 45 78 70 72 20 2a 70 45 78 70  List, Expr *pExp
1090: 72 29 7b 0a 20 20 69 66 28 20 70 45 78 70 72 3d  r){.  if( pExpr=
10a0: 3d 30 20 7c 7c 20 70 54 61 62 4c 69 73 74 3d 3d  =0 || pTabList==
10b0: 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  0 ) return 0;.  
10c0: 73 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f  switch( pExpr->o
10d0: 70 20 29 7b 0a 20 20 20 20 2f 2a 20 41 20 6c 6f  p ){.    /* A lo
10e0: 6e 65 20 69 64 65 6e 74 69 66 69 65 72 20 2a 2f  ne identifier */
10f0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 44 3a  .    case TK_ID:
1100: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 63 6e 74   {.      int cnt
1110: 20 3d 20 30 3b 20 20 20 20 20 20 2f 2a 20 4e 75   = 0;      /* Nu
1120: 6d 62 65 72 20 6f 66 20 6d 61 74 63 68 65 73 20  mber of matches 
1130: 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 20  */.      int i; 
1140: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4c 6f             /* Lo
1150: 6f 70 20 63 6f 75 6e 74 65 72 20 2a 2f 0a 20 20  op counter */.  
1160: 20 20 20 20 63 68 61 72 20 2a 7a 20 3d 20 73 71      char *z = sq
1170: 6c 69 74 65 53 74 72 4e 44 75 70 28 70 45 78 70  liteStrNDup(pExp
1180: 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70  r->token.z, pExp
1190: 72 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20  r->token.n);.   
11a0: 20 20 20 69 66 28 20 7a 3d 3d 30 20 29 20 72 65     if( z==0 ) re
11b0: 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 66 6f  turn 1;.      fo
11c0: 72 28 69 3d 30 3b 20 69 3c 70 54 61 62 4c 69 73  r(i=0; i<pTabLis
11d0: 74 2d 3e 6e 49 64 3b 20 69 2b 2b 29 7b 0a 20 20  t->nId; i++){.  
11e0: 20 20 20 20 20 20 69 6e 74 20 6a 3b 0a 20 20 20        int j;.   
11f0: 20 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62       Table *pTab
1200: 20 3d 20 70 54 61 62 4c 69 73 74 2d 3e 61 5b 69   = pTabList->a[i
1210: 5d 2e 70 54 61 62 3b 0a 20 20 20 20 20 20 20 20  ].pTab;.        
1220: 69 66 28 20 70 54 61 62 3d 3d 30 20 29 20 63 6f  if( pTab==0 ) co
1230: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20  ntinue;.        
1240: 66 6f 72 28 6a 3d 30 3b 20 6a 3c 70 54 61 62 2d  for(j=0; j<pTab-
1250: 3e 6e 43 6f 6c 3b 20 6a 2b 2b 29 7b 0a 20 20 20  >nCol; j++){.   
1260: 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74         if( sqlit
1270: 65 53 74 72 49 43 6d 70 28 70 54 61 62 2d 3e 61  eStrICmp(pTab->a
1280: 43 6f 6c 5b 6a 5d 2e 7a 4e 61 6d 65 2c 20 7a 29  Col[j].zName, z)
1290: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ==0 ){.         
12a0: 20 20 20 63 6e 74 2b 2b 3b 0a 20 20 20 20 20 20     cnt++;.      
12b0: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 54 61        pExpr->iTa
12c0: 62 6c 65 20 3d 20 69 20 2b 20 70 50 61 72 73 65  ble = i + pParse
12d0: 2d 3e 6e 54 61 62 3b 0a 20 20 20 20 20 20 20 20  ->nTab;.        
12e0: 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75      pExpr->iColu
12f0: 6d 6e 20 3d 20 6a 3b 0a 20 20 20 20 20 20 20 20  mn = j;.        
1300: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
1310: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
1320: 63 6e 74 3d 3d 30 20 26 26 20 73 71 6c 69 74 65  cnt==0 && sqlite
1330: 49 73 52 6f 77 69 64 28 7a 29 20 29 7b 0a 20 20  IsRowid(z) ){.  
1340: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f        pExpr->iCo
1350: 6c 75 6d 6e 20 3d 20 2d 31 3b 0a 20 20 20 20 20  lumn = -1;.     
1360: 20 20 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65     pExpr->iTable
1370: 20 3d 20 70 50 61 72 73 65 2d 3e 6e 54 61 62 3b   = pParse->nTab;
1380: 0a 20 20 20 20 20 20 20 20 63 6e 74 20 3d 20 31  .        cnt = 1
1390: 20 2b 20 28 70 54 61 62 4c 69 73 74 2d 3e 6e 49   + (pTabList->nI
13a0: 64 3e 31 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  d>1);.      }.  
13b0: 20 20 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a      sqliteFree(z
13c0: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 63 6e 74  );.      if( cnt
13d0: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 73  ==0 ){.        s
13e0: 71 6c 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28  qliteSetNString(
13f0: 26 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67  &pParse->zErrMsg
1400: 2c 20 22 6e 6f 20 73 75 63 68 20 63 6f 6c 75 6d  , "no such colum
1410: 6e 3a 20 22 2c 20 2d 31 2c 20 20 0a 20 20 20 20  n: ", -1,  .    
1420: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b        pExpr->tok
1430: 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b  en.z, pExpr->tok
1440: 65 6e 2e 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20  en.n, 0);.      
1450: 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b    pParse->nErr++
1460: 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ;.        return
1470: 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20   1;.      }else 
1480: 69 66 28 20 63 6e 74 3e 31 20 29 7b 0a 20 20 20  if( cnt>1 ){.   
1490: 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53       sqliteSetNS
14a0: 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a  tring(&pParse->z
14b0: 45 72 72 4d 73 67 2c 20 22 61 6d 62 69 67 75 6f  ErrMsg, "ambiguo
14c0: 75 73 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 3a 20  us column name: 
14d0: 22 2c 20 2d 31 2c 20 20 0a 20 20 20 20 20 20 20  ", -1,  .       
14e0: 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e     pExpr->token.
14f0: 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e  z, pExpr->token.
1500: 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70  n, 0);.        p
1510: 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20  Parse->nErr++;. 
1520: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b         return 1;
1530: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 70  .      }.      p
1540: 45 78 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 43 4f  Expr->op = TK_CO
1550: 4c 55 4d 4e 3b 0a 20 20 20 20 20 20 62 72 65 61  LUMN;.      brea
1560: 6b 3b 20 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20  k; .    }.  .   
1570: 20 2f 2a 20 41 20 74 61 62 6c 65 20 6e 61 6d 65   /* A table name
1580: 20 61 6e 64 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65   and column name
1590: 3a 20 20 49 44 2e 49 44 20 2a 2f 0a 20 20 20 20  :  ID.ID */.    
15a0: 63 61 73 65 20 54 4b 5f 44 4f 54 3a 20 7b 0a 20  case TK_DOT: {. 
15b0: 20 20 20 20 20 69 6e 74 20 63 6e 74 20 3d 20 30       int cnt = 0
15c0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ;             /*
15d0: 20 4e 75 6d 62 65 72 20 6f 66 20 6d 61 74 63 68   Number of match
15e0: 65 73 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20  es */.      int 
15f0: 63 6e 74 54 61 62 20 3d 20 30 3b 20 20 20 20 20  cntTab = 0;     
1600: 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f       /* Number o
1610: 66 20 6d 61 74 63 68 69 6e 67 20 74 61 62 6c 65  f matching table
1620: 73 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 69  s */.      int i
1630: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
1640: 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e      /* Loop coun
1650: 74 65 72 20 2a 2f 0a 20 20 20 20 20 20 45 78 70  ter */.      Exp
1660: 72 20 2a 70 4c 65 66 74 2c 20 2a 70 52 69 67 68  r *pLeft, *pRigh
1670: 74 3b 20 20 20 20 2f 2a 20 4c 65 66 74 20 61 6e  t;    /* Left an
1680: 64 20 72 69 67 68 74 20 73 75 62 62 72 61 6e 63  d right subbranc
1690: 68 65 73 20 6f 66 20 74 68 65 20 65 78 70 72 20  hes of the expr 
16a0: 2a 2f 0a 20 20 20 20 20 20 63 68 61 72 20 2a 7a  */.      char *z
16b0: 4c 65 66 74 2c 20 2a 7a 52 69 67 68 74 3b 20 20  Left, *zRight;  
16c0: 20 20 2f 2a 20 54 65 78 74 20 6f 66 20 61 6e 20    /* Text of an 
16d0: 69 64 65 6e 74 69 66 69 65 72 20 2a 2f 0a 0a 20  identifier */.. 
16e0: 20 20 20 20 20 70 4c 65 66 74 20 3d 20 70 45 78       pLeft = pEx
16f0: 70 72 2d 3e 70 4c 65 66 74 3b 0a 20 20 20 20 20  pr->pLeft;.     
1700: 20 70 52 69 67 68 74 20 3d 20 70 45 78 70 72 2d   pRight = pExpr-
1710: 3e 70 52 69 67 68 74 3b 0a 20 20 20 20 20 20 61  >pRight;.      a
1720: 73 73 65 72 74 28 20 70 4c 65 66 74 20 26 26 20  ssert( pLeft && 
1730: 70 4c 65 66 74 2d 3e 6f 70 3d 3d 54 4b 5f 49 44  pLeft->op==TK_ID
1740: 20 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74   );.      assert
1750: 28 20 70 52 69 67 68 74 20 26 26 20 70 52 69 67  ( pRight && pRig
1760: 68 74 2d 3e 6f 70 3d 3d 54 4b 5f 49 44 20 29 3b  ht->op==TK_ID );
1770: 0a 20 20 20 20 20 20 7a 4c 65 66 74 20 3d 20 73  .      zLeft = s
1780: 71 6c 69 74 65 53 74 72 4e 44 75 70 28 70 4c 65  qliteStrNDup(pLe
1790: 66 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 4c 65  ft->token.z, pLe
17a0: 66 74 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20  ft->token.n);.  
17b0: 20 20 20 20 7a 52 69 67 68 74 20 3d 20 73 71 6c      zRight = sql
17c0: 69 74 65 53 74 72 4e 44 75 70 28 70 52 69 67 68  iteStrNDup(pRigh
17d0: 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 52 69 67  t->token.z, pRig
17e0: 68 74 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20  ht->token.n);.  
17f0: 20 20 20 20 69 66 28 20 7a 4c 65 66 74 3d 3d 30      if( zLeft==0
1800: 20 7c 7c 20 7a 52 69 67 68 74 3d 3d 30 20 29 7b   || zRight==0 ){
1810: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 46  .        sqliteF
1820: 72 65 65 28 7a 4c 65 66 74 29 3b 0a 20 20 20 20  ree(zLeft);.    
1830: 20 20 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a      sqliteFree(z
1840: 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20 20 20  Right);.        
1850: 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20  return 1;.      
1860: 7d 0a 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69  }.      pExpr->i
1870: 54 61 62 6c 65 20 3d 20 2d 31 3b 0a 20 20 20 20  Table = -1;.    
1880: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 54 61    for(i=0; i<pTa
1890: 62 4c 69 73 74 2d 3e 6e 49 64 3b 20 69 2b 2b 29  bList->nId; i++)
18a0: 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6a 3b  {.        int j;
18b0: 0a 20 20 20 20 20 20 20 20 63 68 61 72 20 2a 7a  .        char *z
18c0: 54 61 62 3b 0a 20 20 20 20 20 20 20 20 54 61 62  Tab;.        Tab
18d0: 6c 65 20 2a 70 54 61 62 20 3d 20 70 54 61 62 4c  le *pTab = pTabL
18e0: 69 73 74 2d 3e 61 5b 69 5d 2e 70 54 61 62 3b 0a  ist->a[i].pTab;.
18f0: 20 20 20 20 20 20 20 20 69 66 28 20 70 54 61 62          if( pTab
1900: 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a  ==0 ) continue;.
1910: 20 20 20 20 20 20 20 20 69 66 28 20 70 54 61 62          if( pTab
1920: 4c 69 73 74 2d 3e 61 5b 69 5d 2e 7a 41 6c 69 61  List->a[i].zAlia
1930: 73 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 7a  s ){.          z
1940: 54 61 62 20 3d 20 70 54 61 62 4c 69 73 74 2d 3e  Tab = pTabList->
1950: 61 5b 69 5d 2e 7a 41 6c 69 61 73 3b 0a 20 20 20  a[i].zAlias;.   
1960: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
1970: 20 20 20 20 20 20 7a 54 61 62 20 3d 20 70 54 61        zTab = pTa
1980: 62 2d 3e 7a 4e 61 6d 65 3b 0a 20 20 20 20 20 20  b->zName;.      
1990: 20 20 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20    }.        if( 
19a0: 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a 54  sqliteStrICmp(zT
19b0: 61 62 2c 20 7a 4c 65 66 74 29 21 3d 30 20 29 20  ab, zLeft)!=0 ) 
19c0: 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20  continue;.      
19d0: 20 20 69 66 28 20 30 3d 3d 28 63 6e 74 54 61 62    if( 0==(cntTab
19e0: 2b 2b 29 20 29 20 70 45 78 70 72 2d 3e 69 54 61  ++) ) pExpr->iTa
19f0: 62 6c 65 20 3d 20 69 20 2b 20 70 50 61 72 73 65  ble = i + pParse
1a00: 2d 3e 6e 54 61 62 3b 0a 20 20 20 20 20 20 20 20  ->nTab;.        
1a10: 66 6f 72 28 6a 3d 30 3b 20 6a 3c 70 54 61 62 2d  for(j=0; j<pTab-
1a20: 3e 6e 43 6f 6c 3b 20 6a 2b 2b 29 7b 0a 20 20 20  >nCol; j++){.   
1a30: 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74         if( sqlit
1a40: 65 53 74 72 49 43 6d 70 28 70 54 61 62 2d 3e 61  eStrICmp(pTab->a
1a50: 43 6f 6c 5b 6a 5d 2e 7a 4e 61 6d 65 2c 20 7a 52  Col[j].zName, zR
1a60: 69 67 68 74 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ight)==0 ){.    
1a70: 20 20 20 20 20 20 20 20 63 6e 74 2b 2b 3b 0a 20          cnt++;. 
1a80: 20 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72             pExpr
1a90: 2d 3e 69 54 61 62 6c 65 20 3d 20 69 20 2b 20 70  ->iTable = i + p
1aa0: 50 61 72 73 65 2d 3e 6e 54 61 62 3b 0a 20 20 20  Parse->nTab;.   
1ab0: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
1ac0: 69 43 6f 6c 75 6d 6e 20 3d 20 6a 3b 0a 20 20 20  iColumn = j;.   
1ad0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
1ae0: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
1af0: 20 69 66 28 20 63 6e 74 3d 3d 30 20 26 26 20 63   if( cnt==0 && c
1b00: 6e 74 54 61 62 3d 3d 31 20 26 26 20 73 71 6c 69  ntTab==1 && sqli
1b10: 74 65 49 73 52 6f 77 69 64 28 7a 52 69 67 68 74  teIsRowid(zRight
1b20: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 63 6e 74  ) ){.        cnt
1b30: 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 70 45   = 1;.        pE
1b40: 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20 2d  xpr->iColumn = -
1b50: 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  1;.      }.     
1b60: 20 73 71 6c 69 74 65 46 72 65 65 28 7a 4c 65 66   sqliteFree(zLef
1b70: 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  t);.      sqlite
1b80: 46 72 65 65 28 7a 52 69 67 68 74 29 3b 0a 20 20  Free(zRight);.  
1b90: 20 20 20 20 69 66 28 20 63 6e 74 3d 3d 30 20 29      if( cnt==0 )
1ba0: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
1bb0: 53 65 74 4e 53 74 72 69 6e 67 28 26 70 50 61 72  SetNString(&pPar
1bc0: 73 65 2d 3e 7a 45 72 72 4d 73 67 2c 20 22 6e 6f  se->zErrMsg, "no
1bd0: 20 73 75 63 68 20 63 6f 6c 75 6d 6e 3a 20 22 2c   such column: ",
1be0: 20 2d 31 2c 20 20 0a 20 20 20 20 20 20 20 20 20   -1,  .         
1bf0: 20 70 4c 65 66 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c   pLeft->token.z,
1c00: 20 70 4c 65 66 74 2d 3e 74 6f 6b 65 6e 2e 6e 2c   pLeft->token.n,
1c10: 20 22 2e 22 2c 20 31 2c 20 0a 20 20 20 20 20 20   ".", 1, .      
1c20: 20 20 20 20 70 52 69 67 68 74 2d 3e 74 6f 6b 65      pRight->toke
1c30: 6e 2e 7a 2c 20 70 52 69 67 68 74 2d 3e 74 6f 6b  n.z, pRight->tok
1c40: 65 6e 2e 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20  en.n, 0);.      
1c50: 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b    pParse->nErr++
1c60: 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ;.        return
1c70: 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20   1;.      }else 
1c80: 69 66 28 20 63 6e 74 3e 31 20 29 7b 0a 20 20 20  if( cnt>1 ){.   
1c90: 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53       sqliteSetNS
1ca0: 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a  tring(&pParse->z
1cb0: 45 72 72 4d 73 67 2c 20 22 61 6d 62 69 67 75 6f  ErrMsg, "ambiguo
1cc0: 75 73 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 3a 20  us column name: 
1cd0: 22 2c 20 2d 31 2c 20 20 0a 20 20 20 20 20 20 20  ", -1,  .       
1ce0: 20 20 20 70 4c 65 66 74 2d 3e 74 6f 6b 65 6e 2e     pLeft->token.
1cf0: 7a 2c 20 70 4c 65 66 74 2d 3e 74 6f 6b 65 6e 2e  z, pLeft->token.
1d00: 6e 2c 20 22 2e 22 2c 20 31 2c 0a 20 20 20 20 20  n, ".", 1,.     
1d10: 20 20 20 20 20 70 52 69 67 68 74 2d 3e 74 6f 6b       pRight->tok
1d20: 65 6e 2e 7a 2c 20 70 52 69 67 68 74 2d 3e 74 6f  en.z, pRight->to
1d30: 6b 65 6e 2e 6e 2c 20 30 29 3b 0a 20 20 20 20 20  ken.n, 0);.     
1d40: 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b     pParse->nErr+
1d50: 2b 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  +;.        retur
1d60: 6e 20 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n 1;.      }.   
1d70: 20 20 20 73 71 6c 69 74 65 45 78 70 72 44 65 6c     sqliteExprDel
1d80: 65 74 65 28 70 4c 65 66 74 29 3b 0a 20 20 20 20  ete(pLeft);.    
1d90: 20 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 3d    pExpr->pLeft =
1da0: 20 30 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   0;.      sqlite
1db0: 45 78 70 72 44 65 6c 65 74 65 28 70 52 69 67 68  ExprDelete(pRigh
1dc0: 74 29 3b 0a 20 20 20 20 20 20 70 45 78 70 72 2d  t);.      pExpr-
1dd0: 3e 70 52 69 67 68 74 20 3d 20 30 3b 0a 20 20 20  >pRight = 0;.   
1de0: 20 20 20 70 45 78 70 72 2d 3e 6f 70 20 3d 20 54     pExpr->op = T
1df0: 4b 5f 43 4f 4c 55 4d 4e 3b 0a 20 20 20 20 20 20  K_COLUMN;.      
1e00: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 20 20  break;.    }..  
1e10: 20 20 63 61 73 65 20 54 4b 5f 49 4e 3a 20 7b 0a    case TK_IN: {.
1e20: 20 20 20 20 20 20 56 64 62 65 20 2a 76 20 3d 20        Vdbe *v = 
1e30: 73 71 6c 69 74 65 47 65 74 56 64 62 65 28 70 50  sqliteGetVdbe(pP
1e40: 61 72 73 65 29 3b 0a 20 20 20 20 20 20 69 66 28  arse);.      if(
1e50: 20 76 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 31   v==0 ) return 1
1e60: 3b 0a 20 20 20 20 20 20 69 66 28 20 73 71 6c 69  ;.      if( sqli
1e70: 74 65 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73  teExprResolveIds
1e80: 28 70 50 61 72 73 65 2c 20 70 54 61 62 4c 69 73  (pParse, pTabLis
1e90: 74 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29  t, pExpr->pLeft)
1ea0: 20 29 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75   ){.        retu
1eb0: 72 6e 20 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20  rn 1;.      }.  
1ec0: 20 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 70      if( pExpr->p
1ed0: 53 65 6c 65 63 74 20 29 7b 0a 20 20 20 20 20 20  Select ){.      
1ee0: 20 20 2f 2a 20 43 61 73 65 20 31 3a 20 20 20 20    /* Case 1:    
1ef0: 20 65 78 70 72 20 49 4e 20 28 53 45 4c 45 43 54   expr IN (SELECT
1f00: 20 2e 2e 2e 29 0a 20 20 20 20 20 20 20 20 2a 2a   ...).        **
1f10: 0a 20 20 20 20 20 20 20 20 2a 2a 20 47 65 6e 65  .        ** Gene
1f20: 72 61 74 65 20 63 6f 64 65 20 74 6f 20 77 72 69  rate code to wri
1f30: 74 65 20 74 68 65 20 72 65 73 75 6c 74 73 20 6f  te the results o
1f40: 66 20 74 68 65 20 73 65 6c 65 63 74 20 69 6e 74  f the select int
1f50: 6f 20 61 20 74 65 6d 70 6f 72 61 72 79 0a 20 20  o a temporary.  
1f60: 20 20 20 20 20 20 2a 2a 20 74 61 62 6c 65 2e 20        ** table. 
1f70: 20 54 68 65 20 63 75 72 73 6f 72 20 6e 75 6d 62   The cursor numb
1f80: 65 72 20 6f 66 20 74 68 65 20 74 65 6d 70 6f 72  er of the tempor
1f90: 61 72 79 20 74 61 62 6c 65 20 68 61 73 20 61 6c  ary table has al
1fa0: 72 65 61 64 79 0a 20 20 20 20 20 20 20 20 2a 2a  ready.        **
1fb0: 20 62 65 65 6e 20 70 75 74 20 69 6e 20 69 54 61   been put in iTa
1fc0: 62 6c 65 20 62 79 20 73 71 6c 69 74 65 45 78 70  ble by sqliteExp
1fd0: 72 52 65 73 6f 6c 76 65 49 6e 53 65 6c 65 63 74  rResolveInSelect
1fe0: 28 29 2e 0a 20 20 20 20 20 20 20 20 2a 2f 0a 20  ()..        */. 
1ff0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
2000: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4f 70 65  eAddOp(v, OP_Ope
2010: 6e 49 64 78 2c 20 70 45 78 70 72 2d 3e 69 54 61  nIdx, pExpr->iTa
2020: 62 6c 65 2c 20 31 2c 20 30 2c 20 30 29 3b 0a 20  ble, 1, 0, 0);. 
2030: 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74         if( sqlit
2040: 65 53 65 6c 65 63 74 28 70 50 61 72 73 65 2c 20  eSelect(pParse, 
2050: 70 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 2c 20  pExpr->pSelect, 
2060: 53 52 54 5f 53 65 74 2c 20 70 45 78 70 72 2d 3e  SRT_Set, pExpr->
2070: 69 54 61 62 6c 65 29 20 29 3b 0a 20 20 20 20 20  iTable) );.     
2080: 20 7d 65 6c 73 65 20 69 66 28 20 70 45 78 70 72   }else if( pExpr
2090: 2d 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20 20 20  ->pList ){.     
20a0: 20 20 20 2f 2a 20 43 61 73 65 20 32 3a 20 20 20     /* Case 2:   
20b0: 20 20 65 78 70 72 20 49 4e 20 28 65 78 70 72 6c    expr IN (exprl
20c0: 69 73 74 29 0a 20 20 20 20 20 20 20 20 2a 2a 0a  ist).        **.
20d0: 20 20 20 20 20 20 20 20 2a 2a 20 43 72 65 61 74          ** Creat
20e0: 65 20 61 20 73 65 74 20 74 6f 20 70 75 74 20 74  e a set to put t
20f0: 68 65 20 65 78 70 72 6c 69 73 74 20 76 61 6c 75  he exprlist valu
2100: 65 73 20 69 6e 2e 20 20 54 68 65 20 53 65 74 20  es in.  The Set 
2110: 69 64 20 69 73 20 73 74 6f 72 65 64 0a 20 20 20  id is stored.   
2120: 20 20 20 20 20 2a 2a 20 69 6e 20 69 54 61 62 6c       ** in iTabl
2130: 65 2e 0a 20 20 20 20 20 20 20 20 2a 2f 0a 20 20  e..        */.  
2140: 20 20 20 20 20 20 69 6e 74 20 69 2c 20 69 53 65        int i, iSe
2150: 74 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69  t;.        for(i
2160: 3d 30 3b 20 69 3c 70 45 78 70 72 2d 3e 70 4c 69  =0; i<pExpr->pLi
2170: 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b  st->nExpr; i++){
2180: 0a 20 20 20 20 20 20 20 20 20 20 45 78 70 72 20  .          Expr 
2190: 2a 70 45 32 20 3d 20 70 45 78 70 72 2d 3e 70 4c  *pE2 = pExpr->pL
21a0: 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 3b  ist->a[i].pExpr;
21b0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 21  .          if( !
21c0: 69 73 43 6f 6e 73 74 61 6e 74 28 70 45 32 29 20  isConstant(pE2) 
21d0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 73  ){.            s
21e0: 71 6c 69 74 65 53 65 74 53 74 72 69 6e 67 28 26  qliteSetString(&
21f0: 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 2c  pParse->zErrMsg,
2200: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22  .              "
2210: 72 69 67 68 74 2d 68 61 6e 64 20 73 69 64 65 20  right-hand side 
2220: 6f 66 20 49 4e 20 6f 70 65 72 61 74 6f 72 20 6d  of IN operator m
2230: 75 73 74 20 62 65 20 63 6f 6e 73 74 61 6e 74 22  ust be constant"
2240: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , 0);.          
2250: 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b    pParse->nErr++
2260: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ;.            re
2270: 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20  turn 1;.        
2280: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 69 66    }.          if
2290: 28 20 73 71 6c 69 74 65 45 78 70 72 43 68 65 63  ( sqliteExprChec
22a0: 6b 28 70 50 61 72 73 65 2c 20 70 45 32 2c 20 30  k(pParse, pE2, 0
22b0: 2c 20 30 29 20 29 7b 0a 20 20 20 20 20 20 20 20  , 0) ){.        
22c0: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
22d0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
22e0: 20 20 7d 0a 20 20 20 20 20 20 20 20 69 53 65 74    }.        iSet
22f0: 20 3d 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65   = pExpr->iTable
2300: 20 3d 20 70 50 61 72 73 65 2d 3e 6e 53 65 74 2b   = pParse->nSet+
2310: 2b 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69  +;.        for(i
2320: 3d 30 3b 20 69 3c 70 45 78 70 72 2d 3e 70 4c 69  =0; i<pExpr->pLi
2330: 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b  st->nExpr; i++){
2340: 0a 20 20 20 20 20 20 20 20 20 20 45 78 70 72 20  .          Expr 
2350: 2a 70 45 32 20 3d 20 70 45 78 70 72 2d 3e 70 4c  *pE2 = pExpr->pL
2360: 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 3b  ist->a[i].pExpr;
2370: 0a 20 20 20 20 20 20 20 20 20 20 73 77 69 74 63  .          switc
2380: 68 28 20 70 45 32 2d 3e 6f 70 20 29 7b 0a 20 20  h( pE2->op ){.  
2390: 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20 54            case T
23a0: 4b 5f 46 4c 4f 41 54 3a 0a 20 20 20 20 20 20 20  K_FLOAT:.       
23b0: 20 20 20 20 20 63 61 73 65 20 54 4b 5f 49 4e 54       case TK_INT
23c0: 45 47 45 52 3a 0a 20 20 20 20 20 20 20 20 20 20  EGER:.          
23d0: 20 20 63 61 73 65 20 54 4b 5f 53 54 52 49 4e 47    case TK_STRING
23e0: 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  : {.            
23f0: 20 20 69 6e 74 20 61 64 64 72 20 3d 20 73 71 6c    int addr = sql
2400: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
2410: 4f 50 5f 53 65 74 49 6e 73 65 72 74 2c 20 69 53  OP_SetInsert, iS
2420: 65 74 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20  et, 0, 0, 0);.  
2430: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
2440: 74 65 56 64 62 65 43 68 61 6e 67 65 50 33 28 76  teVdbeChangeP3(v
2450: 2c 20 61 64 64 72 2c 20 70 45 32 2d 3e 74 6f 6b  , addr, pE2->tok
2460: 65 6e 2e 7a 2c 20 70 45 32 2d 3e 74 6f 6b 65 6e  en.z, pE2->token
2470: 2e 6e 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  .n);.           
2480: 20 20 20 73 71 6c 69 74 65 56 64 62 65 44 65 71     sqliteVdbeDeq
2490: 75 6f 74 65 50 33 28 76 2c 20 61 64 64 72 29 3b  uoteP3(v, addr);
24a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62  .              b
24b0: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20  reak;.          
24c0: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
24d0: 64 65 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20  default: {.     
24e0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 45           sqliteE
24f0: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
2500: 70 45 32 29 3b 0a 20 20 20 20 20 20 20 20 20 20  pE2);.          
2510: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
2520: 64 4f 70 28 76 2c 20 4f 50 5f 53 65 74 49 6e 73  dOp(v, OP_SetIns
2530: 65 72 74 2c 20 69 53 65 74 2c 20 30 2c 20 30 2c  ert, iSet, 0, 0,
2540: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20   0);.           
2550: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
2560: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
2570: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
2580: 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61      }.      brea
2590: 6b 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 63 61  k;.    }..    ca
25a0: 73 65 20 54 4b 5f 53 45 4c 45 43 54 3a 20 7b 0a  se TK_SELECT: {.
25b0: 20 20 20 20 20 20 2f 2a 20 54 68 69 73 20 68 61        /* This ha
25c0: 73 20 74 6f 20 62 65 20 61 20 73 63 61 6c 61 72  s to be a scalar
25d0: 20 53 45 4c 45 43 54 2e 20 20 47 65 6e 65 72 61   SELECT.  Genera
25e0: 74 65 20 63 6f 64 65 20 74 6f 20 70 75 74 20 74  te code to put t
25f0: 68 65 0a 20 20 20 20 20 20 2a 2a 20 76 61 6c 75  he.      ** valu
2600: 65 20 6f 66 20 74 68 69 73 20 73 65 6c 65 63 74  e of this select
2610: 20 69 6e 20 61 20 6d 65 6d 6f 72 79 20 63 65 6c   in a memory cel
2620: 6c 20 61 6e 64 20 72 65 63 6f 72 64 20 74 68 65  l and record the
2630: 20 6e 75 6d 62 65 72 0a 20 20 20 20 20 20 2a 2a   number.      **
2640: 20 6f 66 20 74 68 65 20 6d 65 6d 6f 72 79 20 63   of the memory c
2650: 65 6c 6c 20 69 6e 20 69 43 6f 6c 75 6d 6e 2e 0a  ell in iColumn..
2660: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 70        */.      p
2670: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20  Expr->iColumn = 
2680: 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 2b 2b 3b 0a  pParse->nMem++;.
2690: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
26a0: 53 65 6c 65 63 74 28 70 50 61 72 73 65 2c 20 70  Select(pParse, p
26b0: 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 2c 20 53  Expr->pSelect, S
26c0: 52 54 5f 4d 65 6d 2c 20 70 45 78 70 72 2d 3e 69  RT_Mem, pExpr->i
26d0: 43 6f 6c 75 6d 6e 29 20 29 7b 0a 20 20 20 20 20  Column) ){.     
26e0: 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20     return 1;.   
26f0: 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61 6b     }.      break
2700: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  ;.    }..    /* 
2710: 46 6f 72 20 61 6c 6c 20 65 6c 73 65 2c 20 6a 75  For all else, ju
2720: 73 74 20 72 65 63 75 72 73 69 76 65 6c 79 20 77  st recursively w
2730: 61 6c 6b 20 74 68 65 20 74 72 65 65 20 2a 2f 0a  alk the tree */.
2740: 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b 0a 20      default: {. 
2750: 20 20 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e       if( pExpr->
2760: 70 4c 65 66 74 0a 20 20 20 20 20 20 26 26 20 73  pLeft.      && s
2770: 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65  qliteExprResolve
2780: 49 64 73 28 70 50 61 72 73 65 2c 20 70 54 61 62  Ids(pParse, pTab
2790: 4c 69 73 74 2c 20 70 45 78 70 72 2d 3e 70 4c 65  List, pExpr->pLe
27a0: 66 74 29 20 29 7b 0a 20 20 20 20 20 20 20 20 72  ft) ){.        r
27b0: 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 7d  eturn 1;.      }
27c0: 0a 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72  .      if( pExpr
27d0: 2d 3e 70 52 69 67 68 74 20 0a 20 20 20 20 20 20  ->pRight .      
27e0: 26 26 20 73 71 6c 69 74 65 45 78 70 72 52 65 73  && sqliteExprRes
27f0: 6f 6c 76 65 49 64 73 28 70 50 61 72 73 65 2c 20  olveIds(pParse, 
2800: 70 54 61 62 4c 69 73 74 2c 20 70 45 78 70 72 2d  pTabList, pExpr-
2810: 3e 70 52 69 67 68 74 29 20 29 7b 0a 20 20 20 20  >pRight) ){.    
2820: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
2830: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
2840: 70 45 78 70 72 2d 3e 70 4c 69 73 74 20 29 7b 0a  pExpr->pList ){.
2850: 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20          int i;. 
2860: 20 20 20 20 20 20 20 45 78 70 72 4c 69 73 74 20         ExprList 
2870: 2a 70 4c 69 73 74 20 3d 20 70 45 78 70 72 2d 3e  *pList = pExpr->
2880: 70 4c 69 73 74 3b 0a 20 20 20 20 20 20 20 20 66  pList;.        f
2890: 6f 72 28 69 3d 30 3b 20 69 3c 70 4c 69 73 74 2d  or(i=0; i<pList-
28a0: 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a 20 20  >nExpr; i++){.  
28b0: 20 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69          if( sqli
28c0: 74 65 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73  teExprResolveIds
28d0: 28 70 50 61 72 73 65 2c 20 70 54 61 62 4c 69 73  (pParse, pTabLis
28e0: 74 2c 20 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70  t, pList->a[i].p
28f0: 45 78 70 72 29 20 29 7b 0a 20 20 20 20 20 20 20  Expr) ){.       
2900: 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20       return 1;. 
2910: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
2920: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
2930: 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20   }.  }.  return 
2940: 30 3b 0a 7d 0a 0a 23 69 66 20 30 20 2f 2a 20 4e  0;.}..#if 0 /* N
2950: 4f 54 20 55 53 45 44 20 2a 2f 0a 2f 2a 0a 2a 2a  OT USED */./*.**
2960: 20 43 6f 6d 70 61 72 65 20 61 20 74 6f 6b 65 6e   Compare a token
2970: 20 61 67 61 69 6e 73 74 20 61 20 73 74 72 69 6e   against a strin
2980: 67 2e 20 20 52 65 74 75 72 6e 20 54 52 55 45 20  g.  Return TRUE 
2990: 69 66 20 74 68 65 79 20 6d 61 74 63 68 2e 0a 2a  if they match..*
29a0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 73 71 6c  /.static int sql
29b0: 69 74 65 54 6f 6b 65 6e 43 6d 70 28 54 6f 6b 65  iteTokenCmp(Toke
29c0: 6e 20 2a 70 54 6f 6b 65 6e 2c 20 63 6f 6e 73 74  n *pToken, const
29d0: 20 63 68 61 72 20 2a 7a 53 74 72 29 7b 0a 20 20   char *zStr){.  
29e0: 69 6e 74 20 6e 20 3d 20 73 74 72 6c 65 6e 28 7a  int n = strlen(z
29f0: 53 74 72 29 3b 0a 20 20 69 66 28 20 6e 21 3d 70  Str);.  if( n!=p
2a00: 54 6f 6b 65 6e 2d 3e 6e 20 29 20 72 65 74 75 72  Token->n ) retur
2a10: 6e 20 30 3b 0a 20 20 72 65 74 75 72 6e 20 73 71  n 0;.  return sq
2a20: 6c 69 74 65 53 74 72 4e 49 43 6d 70 28 70 54 6f  liteStrNICmp(pTo
2a30: 6b 65 6e 2d 3e 7a 2c 20 7a 53 74 72 2c 20 6e 29  ken->z, zStr, n)
2a40: 3d 3d 30 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f  ==0;.}.#endif../
2a50: 2a 0a 2a 2a 20 43 6f 6e 76 65 72 74 20 61 20 66  *.** Convert a f
2a60: 75 6e 63 74 69 6f 6e 20 6e 61 6d 65 20 69 6e 74  unction name int
2a70: 6f 20 69 74 73 20 69 6e 74 65 67 65 72 20 69 64  o its integer id
2a80: 65 6e 74 69 66 69 65 72 2e 20 20 52 65 74 75 72  entifier.  Retur
2a90: 6e 20 74 68 65 0a 2a 2a 20 69 64 65 6e 74 69 66  n the.** identif
2aa0: 69 65 72 2e 20 20 52 65 74 75 72 6e 20 46 4e 5f  ier.  Return FN_
2ab0: 55 6e 6b 6e 6f 77 6e 20 69 66 20 74 68 65 20 66  Unknown if the f
2ac0: 75 6e 63 74 69 6f 6e 20 6e 61 6d 65 20 69 73 20  unction name is 
2ad0: 75 6e 6b 6e 6f 77 6e 2e 0a 2a 2f 0a 69 6e 74 20  unknown..*/.int 
2ae0: 73 71 6c 69 74 65 46 75 6e 63 49 64 28 54 6f 6b  sqliteFuncId(Tok
2af0: 65 6e 20 2a 70 54 6f 6b 65 6e 29 7b 0a 20 20 73  en *pToken){.  s
2b00: 74 61 74 69 63 20 63 6f 6e 73 74 20 73 74 72 75  tatic const stru
2b10: 63 74 20 7b 0a 20 20 20 20 20 63 68 61 72 20 2a  ct {.     char *
2b20: 7a 4e 61 6d 65 3b 0a 20 20 20 20 20 69 6e 74 20  zName;.     int 
2b30: 6c 65 6e 3b 0a 20 20 20 20 20 69 6e 74 20 69 64  len;.     int id
2b40: 3b 0a 20 20 7d 20 61 46 75 6e 63 5b 5d 20 3d 20  ;.  } aFunc[] = 
2b50: 7b 0a 20 20 20 20 20 7b 20 22 63 6f 75 6e 74 22  {.     { "count"
2b60: 2c 20 20 35 2c 20 46 4e 5f 43 6f 75 6e 74 20 7d  ,  5, FN_Count }
2b70: 2c 0a 20 20 20 20 20 7b 20 22 6d 69 6e 22 2c 20  ,.     { "min", 
2b80: 20 20 20 33 2c 20 46 4e 5f 4d 69 6e 20 20 20 7d     3, FN_Min   }
2b90: 2c 0a 20 20 20 20 20 7b 20 22 6d 61 78 22 2c 20  ,.     { "max", 
2ba0: 20 20 20 33 2c 20 46 4e 5f 4d 61 78 20 20 20 7d     3, FN_Max   }
2bb0: 2c 0a 20 20 20 20 20 7b 20 22 73 75 6d 22 2c 20  ,.     { "sum", 
2bc0: 20 20 20 33 2c 20 46 4e 5f 53 75 6d 20 20 20 7d     3, FN_Sum   }
2bd0: 2c 0a 20 20 20 20 20 7b 20 22 61 76 67 22 2c 20  ,.     { "avg", 
2be0: 20 20 20 33 2c 20 46 4e 5f 41 76 67 20 20 20 7d     3, FN_Avg   }
2bf0: 2c 0a 20 20 20 20 20 7b 20 22 66 63 6e 74 22 2c  ,.     { "fcnt",
2c00: 20 20 20 34 2c 20 46 4e 5f 46 63 6e 74 20 20 7d     4, FN_Fcnt  }
2c10: 2c 20 20 2f 2a 20 55 73 65 64 20 66 6f 72 20 74  ,  /* Used for t
2c20: 65 73 74 69 6e 67 20 6f 6e 6c 79 20 2a 2f 0a 20  esting only */. 
2c30: 20 20 20 20 7b 20 22 6c 65 6e 67 74 68 22 2c 20      { "length", 
2c40: 36 2c 20 46 4e 5f 4c 65 6e 67 74 68 7d 2c 0a 20  6, FN_Length},. 
2c50: 20 20 20 20 7b 20 22 73 75 62 73 74 72 22 2c 20      { "substr", 
2c60: 36 2c 20 46 4e 5f 53 75 62 73 74 72 7d 2c 0a 20  6, FN_Substr},. 
2c70: 20 7d 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 66   };.  int i;.  f
2c80: 6f 72 28 69 3d 30 3b 20 69 3c 41 72 72 61 79 53  or(i=0; i<ArrayS
2c90: 69 7a 65 28 61 46 75 6e 63 29 3b 20 69 2b 2b 29  ize(aFunc); i++)
2ca0: 7b 0a 20 20 20 20 69 66 28 20 61 46 75 6e 63 5b  {.    if( aFunc[
2cb0: 69 5d 2e 6c 65 6e 3d 3d 70 54 6f 6b 65 6e 2d 3e  i].len==pToken->
2cc0: 6e 20 0a 20 20 20 20 20 26 26 20 73 71 6c 69 74  n .     && sqlit
2cd0: 65 53 74 72 4e 49 43 6d 70 28 70 54 6f 6b 65 6e  eStrNICmp(pToken
2ce0: 2d 3e 7a 2c 20 61 46 75 6e 63 5b 69 5d 2e 7a 4e  ->z, aFunc[i].zN
2cf0: 61 6d 65 2c 20 61 46 75 6e 63 5b 69 5d 2e 6c 65  ame, aFunc[i].le
2d00: 6e 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  n)==0 ){.       
2d10: 72 65 74 75 72 6e 20 61 46 75 6e 63 5b 69 5d 2e  return aFunc[i].
2d20: 69 64 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  id;.    }.  }.  
2d30: 72 65 74 75 72 6e 20 46 4e 5f 55 6e 6b 6e 6f 77  return FN_Unknow
2d40: 6e 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 45 72 72 6f  n;.}../*.** Erro
2d50: 72 20 63 68 65 63 6b 20 74 68 65 20 66 75 6e 63  r check the func
2d60: 74 69 6f 6e 73 20 69 6e 20 61 6e 20 65 78 70 72  tions in an expr
2d70: 65 73 73 69 6f 6e 2e 20 20 4d 61 6b 65 20 73 75  ession.  Make su
2d80: 72 65 20 61 6c 6c 0a 2a 2a 20 66 75 6e 63 74 69  re all.** functi
2d90: 6f 6e 20 6e 61 6d 65 73 20 61 72 65 20 72 65 63  on names are rec
2da0: 6f 67 6e 69 7a 65 64 20 61 6e 64 20 61 6c 6c 20  ognized and all 
2db0: 66 75 6e 63 74 69 6f 6e 73 20 68 61 76 65 20 74  functions have t
2dc0: 68 65 20 63 6f 72 72 65 63 74 0a 2a 2a 20 6e 75  he correct.** nu
2dd0: 6d 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e 74  mber of argument
2de0: 73 2e 20 20 4c 65 61 76 65 20 61 6e 20 65 72 72  s.  Leave an err
2df0: 6f 72 20 6d 65 73 73 61 67 65 20 69 6e 20 70 50  or message in pP
2e00: 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 0a 2a 2a  arse->zErrMsg.**
2e10: 20 69 66 20 61 6e 79 74 68 69 6e 67 20 69 73 20   if anything is 
2e20: 61 6d 69 73 73 2e 20 20 52 65 74 75 72 6e 20 74  amiss.  Return t
2e30: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 65 72 72  he number of err
2e40: 6f 72 73 2e 0a 2a 2a 0a 2a 2a 20 69 66 20 70 49  ors..**.** if pI
2e50: 73 41 67 67 20 69 73 20 6e 6f 74 20 6e 75 6c 6c  sAgg is not null
2e60: 20 61 6e 64 20 74 68 69 73 20 65 78 70 72 65 73   and this expres
2e70: 73 69 6f 6e 20 69 73 20 61 6e 20 61 67 67 72 65  sion is an aggre
2e80: 67 61 74 65 20 66 75 6e 63 74 69 6f 6e 0a 2a 2a  gate function.**
2e90: 20 28 6c 69 6b 65 20 63 6f 75 6e 74 28 2a 29 20   (like count(*) 
2ea0: 6f 72 20 6d 61 78 28 76 61 6c 75 65 29 29 20 74  or max(value)) t
2eb0: 68 65 6e 20 77 72 69 74 65 20 61 20 31 20 69 6e  hen write a 1 in
2ec0: 74 6f 20 2a 70 49 73 41 67 67 2e 0a 2a 2f 0a 69  to *pIsAgg..*/.i
2ed0: 6e 74 20 73 71 6c 69 74 65 45 78 70 72 43 68 65  nt sqliteExprChe
2ee0: 63 6b 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  ck(Parse *pParse
2ef0: 2c 20 45 78 70 72 20 2a 70 45 78 70 72 2c 20 69  , Expr *pExpr, i
2f00: 6e 74 20 61 6c 6c 6f 77 41 67 67 2c 20 69 6e 74  nt allowAgg, int
2f10: 20 2a 70 49 73 41 67 67 29 7b 0a 20 20 69 6e 74   *pIsAgg){.  int
2f20: 20 6e 45 72 72 20 3d 20 30 3b 0a 20 20 69 66 28   nErr = 0;.  if(
2f30: 20 70 45 78 70 72 3d 3d 30 20 29 20 72 65 74 75   pExpr==0 ) retu
2f40: 72 6e 20 30 3b 0a 20 20 73 77 69 74 63 68 28 20  rn 0;.  switch( 
2f50: 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20  pExpr->op ){.   
2f60: 20 63 61 73 65 20 54 4b 5f 46 55 4e 43 54 49 4f   case TK_FUNCTIO
2f70: 4e 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 69  N: {.      int i
2f80: 64 20 3d 20 73 71 6c 69 74 65 46 75 6e 63 49 64  d = sqliteFuncId
2f90: 28 26 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 29 3b  (&pExpr->token);
2fa0: 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 70  .      int n = p
2fb0: 45 78 70 72 2d 3e 70 4c 69 73 74 20 3f 20 70 45  Expr->pList ? pE
2fc0: 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70  xpr->pList->nExp
2fd0: 72 20 3a 20 30 3b 0a 20 20 20 20 20 20 69 6e 74  r : 0;.      int
2fe0: 20 6e 6f 5f 73 75 63 68 5f 66 75 6e 63 20 3d 20   no_such_func = 
2ff0: 30 3b 0a 20 20 20 20 20 20 69 6e 74 20 74 6f 6f  0;.      int too
3000: 5f 6d 61 6e 79 5f 61 72 67 73 20 3d 20 30 3b 0a  _many_args = 0;.
3010: 20 20 20 20 20 20 69 6e 74 20 74 6f 6f 5f 66 65        int too_fe
3020: 77 5f 61 72 67 73 20 3d 20 30 3b 0a 20 20 20 20  w_args = 0;.    
3030: 20 20 69 6e 74 20 69 73 5f 61 67 67 20 3d 20 30    int is_agg = 0
3040: 3b 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20  ;.      int i;. 
3050: 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c       pExpr->iCol
3060: 75 6d 6e 20 3d 20 69 64 3b 0a 20 20 20 20 20 20  umn = id;.      
3070: 73 77 69 74 63 68 28 20 69 64 20 29 7b 0a 20 20  switch( id ){.  
3080: 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f 55 6e        case FN_Un
3090: 6b 6e 6f 77 6e 3a 20 7b 20 0a 20 20 20 20 20 20  known: { .      
30a0: 20 20 20 20 6e 6f 5f 73 75 63 68 5f 66 75 6e 63      no_such_func
30b0: 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20   = 1;.          
30c0: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d  break;.        }
30d0: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 46 4e  .        case FN
30e0: 5f 43 6f 75 6e 74 3a 20 7b 20 0a 20 20 20 20 20  _Count: { .     
30f0: 20 20 20 20 20 6e 6f 5f 73 75 63 68 5f 66 75 6e       no_such_fun
3100: 63 20 3d 20 21 61 6c 6c 6f 77 41 67 67 3b 0a 20  c = !allowAgg;. 
3110: 20 20 20 20 20 20 20 20 20 74 6f 6f 5f 6d 61 6e           too_man
3120: 79 5f 61 72 67 73 20 3d 20 6e 3e 31 3b 0a 20 20  y_args = n>1;.  
3130: 20 20 20 20 20 20 20 20 69 73 5f 61 67 67 20 3d          is_agg =
3140: 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72   1;.          br
3150: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  eak;.        }. 
3160: 20 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f 4d         case FN_M
3170: 61 78 3a 0a 20 20 20 20 20 20 20 20 63 61 73 65  ax:.        case
3180: 20 46 4e 5f 4d 69 6e 3a 20 7b 0a 20 20 20 20 20   FN_Min: {.     
3190: 20 20 20 20 20 74 6f 6f 5f 66 65 77 5f 61 72 67       too_few_arg
31a0: 73 20 3d 20 61 6c 6c 6f 77 41 67 67 20 3f 20 6e  s = allowAgg ? n
31b0: 3c 31 20 3a 20 6e 3c 32 3b 0a 20 20 20 20 20 20  <1 : n<2;.      
31c0: 20 20 20 20 69 73 5f 61 67 67 20 3d 20 6e 3d 3d      is_agg = n==
31d0: 31 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72 65  1;.          bre
31e0: 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ak;.        }.  
31f0: 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f 41 76        case FN_Av
3200: 67 3a 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  g:.        case 
3210: 46 4e 5f 53 75 6d 3a 20 7b 0a 20 20 20 20 20 20  FN_Sum: {.      
3220: 20 20 20 20 6e 6f 5f 73 75 63 68 5f 66 75 6e 63      no_such_func
3230: 20 3d 20 21 61 6c 6c 6f 77 41 67 67 3b 0a 20 20   = !allowAgg;.  
3240: 20 20 20 20 20 20 20 20 74 6f 6f 5f 6d 61 6e 79          too_many
3250: 5f 61 72 67 73 20 3d 20 6e 3e 31 3b 0a 20 20 20  _args = n>1;.   
3260: 20 20 20 20 20 20 20 74 6f 6f 5f 66 65 77 5f 61         too_few_a
3270: 72 67 73 20 3d 20 6e 3c 31 3b 0a 20 20 20 20 20  rgs = n<1;.     
3280: 20 20 20 20 20 69 73 5f 61 67 67 20 3d 20 31 3b       is_agg = 1;
3290: 0a 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b  .          break
32a0: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
32b0: 20 20 20 20 63 61 73 65 20 46 4e 5f 4c 65 6e 67      case FN_Leng
32c0: 74 68 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20  th: {.          
32d0: 74 6f 6f 5f 66 65 77 5f 61 72 67 73 20 3d 20 6e  too_few_args = n
32e0: 3c 31 3b 0a 20 20 20 20 20 20 20 20 20 20 74 6f  <1;.          to
32f0: 6f 5f 6d 61 6e 79 5f 61 72 67 73 20 3d 20 6e 3e  o_many_args = n>
3300: 31 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72 65  1;.          bre
3310: 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ak;.        }.  
3320: 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f 53 75        case FN_Su
3330: 62 73 74 72 3a 20 7b 0a 20 20 20 20 20 20 20 20  bstr: {.        
3340: 20 20 74 6f 6f 5f 66 65 77 5f 61 72 67 73 20 3d    too_few_args =
3350: 20 6e 3c 33 3b 0a 20 20 20 20 20 20 20 20 20 20   n<3;.          
3360: 74 6f 6f 5f 6d 61 6e 79 5f 61 72 67 73 20 3d 20  too_many_args = 
3370: 6e 3e 33 3b 0a 20 20 20 20 20 20 20 20 20 20 62  n>3;.          b
3380: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a  reak;.        }.
3390: 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 22          /* The "
33a0: 66 63 6e 74 28 2a 29 22 20 66 75 6e 63 74 69 6f  fcnt(*)" functio
33b0: 6e 20 61 6c 77 61 79 73 20 72 65 74 75 72 6e 73  n always returns
33c0: 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 66   the number of f
33d0: 65 74 63 68 0a 20 20 20 20 20 20 20 20 2a 2a 20  etch.        ** 
33e0: 6f 70 65 72 61 74 69 6f 6e 73 20 74 68 61 74 20  operations that 
33f0: 68 61 76 65 20 6f 63 63 75 72 72 65 64 20 73 6f  have occurred so
3400: 20 66 61 72 20 77 68 69 6c 65 20 70 72 6f 63 65   far while proce
3410: 73 73 69 6e 67 20 74 68 65 0a 20 20 20 20 20 20  ssing the.      
3420: 20 20 2a 2a 20 53 51 4c 20 73 74 61 74 65 6d 65    ** SQL stateme
3430: 6e 74 2e 20 20 54 68 69 73 20 69 6e 66 6f 72 6d  nt.  This inform
3440: 61 74 69 6f 6e 20 63 61 6e 20 62 65 20 75 73 65  ation can be use
3450: 64 20 62 79 20 74 65 73 74 20 70 72 6f 63 65 64  d by test proced
3460: 75 72 65 73 0a 20 20 20 20 20 20 20 20 2a 2a 20  ures.        ** 
3470: 74 6f 20 76 65 72 69 66 79 20 74 68 61 74 20 69  to verify that i
3480: 6e 64 69 63 65 73 20 61 72 65 20 62 65 69 6e 67  ndices are being
3490: 20 75 73 65 64 20 70 72 6f 70 65 72 6c 79 20 74   used properly t
34a0: 6f 20 6d 69 6e 69 6d 69 7a 65 0a 20 20 20 20 20  o minimize.     
34b0: 20 20 20 2a 2a 20 73 65 61 72 63 68 69 6e 67 2e     ** searching.
34c0: 20 20 41 6c 6c 20 61 72 67 75 6d 65 6e 74 73 20    All arguments 
34d0: 74 6f 20 66 63 6e 74 28 29 20 61 72 65 20 69 67  to fcnt() are ig
34e0: 6e 6f 72 65 64 2e 20 20 66 63 6e 74 28 29 20 68  nored.  fcnt() h
34f0: 61 73 0a 20 20 20 20 20 20 20 20 2a 2a 20 6e 6f  as.        ** no
3500: 20 75 73 65 20 28 6f 74 68 65 72 20 74 68 61 6e   use (other than
3510: 20 74 65 73 74 69 6e 67 29 20 74 68 61 74 20 77   testing) that w
3520: 65 20 61 72 65 20 61 77 61 72 65 20 6f 66 2e 0a  e are aware of..
3530: 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20          */.     
3540: 20 20 20 63 61 73 65 20 46 4e 5f 46 63 6e 74 3a     case FN_Fcnt:
3550: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 6e 20 3d   {.          n =
3560: 20 30 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72   0;.          br
3570: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  eak;.        }. 
3580: 20 20 20 20 20 0a 20 20 20 20 20 20 20 20 64 65       .        de
3590: 66 61 75 6c 74 3a 20 62 72 65 61 6b 3b 0a 20 20  fault: break;.  
35a0: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
35b0: 6e 6f 5f 73 75 63 68 5f 66 75 6e 63 20 29 7b 0a  no_such_func ){.
35c0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 53 65          sqliteSe
35d0: 74 4e 53 74 72 69 6e 67 28 26 70 50 61 72 73 65  tNString(&pParse
35e0: 2d 3e 7a 45 72 72 4d 73 67 2c 20 22 6e 6f 20 73  ->zErrMsg, "no s
35f0: 75 63 68 20 66 75 6e 63 74 69 6f 6e 3a 20 22 2c  uch function: ",
3600: 20 2d 31 2c 0a 20 20 20 20 20 20 20 20 20 20 20   -1,.           
3610: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20  pExpr->token.z, 
3620: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20  pExpr->token.n, 
3630: 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72  0);.        pPar
3640: 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20 20  se->nErr++;.    
3650: 20 20 20 20 6e 45 72 72 2b 2b 3b 0a 20 20 20 20      nErr++;.    
3660: 20 20 7d 65 6c 73 65 20 69 66 28 20 74 6f 6f 5f    }else if( too_
3670: 6d 61 6e 79 5f 61 72 67 73 20 29 7b 0a 20 20 20  many_args ){.   
3680: 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53       sqliteSetNS
3690: 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a  tring(&pParse->z
36a0: 45 72 72 4d 73 67 2c 20 22 74 6f 6f 20 6d 61 6e  ErrMsg, "too man
36b0: 79 20 61 72 67 75 6d 65 6e 74 73 20 74 6f 20 66  y arguments to f
36c0: 75 6e 63 74 69 6f 6e 20 22 2c 2d 31 2c 0a 20 20  unction ",-1,.  
36d0: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
36e0: 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e  token.z, pExpr->
36f0: 74 6f 6b 65 6e 2e 6e 2c 20 22 28 29 22 2c 20 32  token.n, "()", 2
3700: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50  , 0);.        pP
3710: 61 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20  arse->nErr++;.  
3720: 20 20 20 20 20 20 6e 45 72 72 2b 2b 3b 0a 20 20        nErr++;.  
3730: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 74 6f      }else if( to
3740: 6f 5f 66 65 77 5f 61 72 67 73 20 29 7b 0a 20 20  o_few_args ){.  
3750: 20 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e        sqliteSetN
3760: 53 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e  String(&pParse->
3770: 7a 45 72 72 4d 73 67 2c 20 22 74 6f 6f 20 66 65  zErrMsg, "too fe
3780: 77 20 61 72 67 75 6d 65 6e 74 73 20 74 6f 20 66  w arguments to f
3790: 75 6e 63 74 69 6f 6e 20 22 2c 2d 31 2c 0a 20 20  unction ",-1,.  
37a0: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
37b0: 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e  token.z, pExpr->
37c0: 74 6f 6b 65 6e 2e 6e 2c 20 22 28 29 22 2c 20 32  token.n, "()", 2
37d0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50  , 0);.        pP
37e0: 61 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20  arse->nErr++;.  
37f0: 20 20 20 20 20 20 6e 45 72 72 2b 2b 3b 0a 20 20        nErr++;.  
3800: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
3810: 69 73 5f 61 67 67 20 29 20 70 45 78 70 72 2d 3e  is_agg ) pExpr->
3820: 6f 70 20 3d 20 54 4b 5f 41 47 47 5f 46 55 4e 43  op = TK_AGG_FUNC
3830: 54 49 4f 4e 3b 0a 20 20 20 20 20 20 69 66 28 20  TION;.      if( 
3840: 69 73 5f 61 67 67 20 26 26 20 70 49 73 41 67 67  is_agg && pIsAgg
3850: 20 29 20 2a 70 49 73 41 67 67 20 3d 20 31 3b 0a   ) *pIsAgg = 1;.
3860: 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 6e        for(i=0; n
3870: 45 72 72 3d 3d 30 20 26 26 20 69 3c 6e 3b 20 69  Err==0 && i<n; i
3880: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 6e 45 72  ++){.        nEr
3890: 72 20 3d 20 73 71 6c 69 74 65 45 78 70 72 43 68  r = sqliteExprCh
38a0: 65 63 6b 28 70 50 61 72 73 65 2c 20 70 45 78 70  eck(pParse, pExp
38b0: 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70  r->pList->a[i].p
38c0: 45 78 70 72 2c 0a 20 20 20 20 20 20 20 20 20 20  Expr,.          
38d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
38e0: 20 20 20 20 20 61 6c 6c 6f 77 41 67 67 20 26 26       allowAgg &&
38f0: 20 21 69 73 5f 61 67 67 2c 20 70 49 73 41 67 67   !is_agg, pIsAgg
3900: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
3910: 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b 0a  .    default: {.
3920: 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72 2d        if( pExpr-
3930: 3e 70 4c 65 66 74 20 29 7b 0a 20 20 20 20 20 20  >pLeft ){.      
3940: 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74 65 45    nErr = sqliteE
3950: 78 70 72 43 68 65 63 6b 28 70 50 61 72 73 65 2c  xprCheck(pParse,
3960: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 2c 20 61   pExpr->pLeft, a
3970: 6c 6c 6f 77 41 67 67 2c 20 70 49 73 41 67 67 29  llowAgg, pIsAgg)
3980: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
3990: 69 66 28 20 6e 45 72 72 3d 3d 30 20 26 26 20 70  if( nErr==0 && p
39a0: 45 78 70 72 2d 3e 70 52 69 67 68 74 20 29 7b 0a  Expr->pRight ){.
39b0: 20 20 20 20 20 20 20 20 6e 45 72 72 20 3d 20 73          nErr = s
39c0: 71 6c 69 74 65 45 78 70 72 43 68 65 63 6b 28 70  qliteExprCheck(p
39d0: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 52  Parse, pExpr->pR
39e0: 69 67 68 74 2c 20 61 6c 6c 6f 77 41 67 67 2c 20  ight, allowAgg, 
39f0: 70 49 73 41 67 67 29 3b 0a 20 20 20 20 20 20 7d  pIsAgg);.      }
3a00: 0a 20 20 20 20 20 20 69 66 28 20 6e 45 72 72 3d  .      if( nErr=
3a10: 3d 30 20 26 26 20 70 45 78 70 72 2d 3e 70 4c 69  =0 && pExpr->pLi
3a20: 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e  st ){.        in
3a30: 74 20 6e 20 3d 20 70 45 78 70 72 2d 3e 70 4c 69  t n = pExpr->pLi
3a40: 73 74 2d 3e 6e 45 78 70 72 3b 0a 20 20 20 20 20  st->nExpr;.     
3a50: 20 20 20 69 6e 74 20 69 3b 0a 20 20 20 20 20 20     int i;.      
3a60: 20 20 66 6f 72 28 69 3d 30 3b 20 6e 45 72 72 3d    for(i=0; nErr=
3a70: 3d 30 20 26 26 20 69 3c 6e 3b 20 69 2b 2b 29 7b  =0 && i<n; i++){
3a80: 0a 20 20 20 20 20 20 20 20 20 20 45 78 70 72 20  .          Expr 
3a90: 2a 70 45 32 20 3d 20 70 45 78 70 72 2d 3e 70 4c  *pE2 = pExpr->pL
3aa0: 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 3b  ist->a[i].pExpr;
3ab0: 0a 20 20 20 20 20 20 20 20 20 20 6e 45 72 72 20  .          nErr 
3ac0: 3d 20 73 71 6c 69 74 65 45 78 70 72 43 68 65 63  = sqliteExprChec
3ad0: 6b 28 70 50 61 72 73 65 2c 20 70 45 32 2c 20 61  k(pParse, pE2, a
3ae0: 6c 6c 6f 77 41 67 67 2c 20 70 49 73 41 67 67 29  llowAgg, pIsAgg)
3af0: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
3b00: 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b    }.      break;
3b10: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74  .    }.  }.  ret
3b20: 75 72 6e 20 6e 45 72 72 3b 0a 7d 0a 0a 2f 2a 0a  urn nErr;.}../*.
3b30: 2a 2a 20 47 65 6e 65 72 61 74 65 20 63 6f 64 65  ** Generate code
3b40: 20 69 6e 74 6f 20 74 68 65 20 63 75 72 72 65 6e   into the curren
3b50: 74 20 56 64 62 65 20 74 6f 20 65 76 61 6c 75 61  t Vdbe to evalua
3b60: 74 65 20 74 68 65 20 67 69 76 65 6e 0a 2a 2a 20  te the given.** 
3b70: 65 78 70 72 65 73 73 69 6f 6e 20 61 6e 64 20 6c  expression and l
3b80: 65 61 76 65 20 74 68 65 20 72 65 73 75 6c 74 20  eave the result 
3b90: 6f 6e 20 74 68 65 20 74 6f 70 20 6f 66 20 73 74  on the top of st
3ba0: 61 63 6b 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  ack..*/.void sql
3bb0: 69 74 65 45 78 70 72 43 6f 64 65 28 50 61 72 73  iteExprCode(Pars
3bc0: 65 20 2a 70 50 61 72 73 65 2c 20 45 78 70 72 20  e *pParse, Expr 
3bd0: 2a 70 45 78 70 72 29 7b 0a 20 20 56 64 62 65 20  *pExpr){.  Vdbe 
3be0: 2a 76 20 3d 20 70 50 61 72 73 65 2d 3e 70 56 64  *v = pParse->pVd
3bf0: 62 65 3b 0a 20 20 69 6e 74 20 6f 70 3b 0a 20 20  be;.  int op;.  
3c00: 69 66 28 20 76 3d 3d 30 20 7c 7c 20 70 45 78 70  if( v==0 || pExp
3c10: 72 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20  r==0 ) return;. 
3c20: 20 73 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e   switch( pExpr->
3c30: 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20 54  op ){.    case T
3c40: 4b 5f 50 4c 55 53 3a 20 20 20 20 20 6f 70 20 3d  K_PLUS:     op =
3c50: 20 4f 50 5f 41 64 64 3b 20 20 20 20 20 20 62 72   OP_Add;      br
3c60: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
3c70: 5f 4d 49 4e 55 53 3a 20 20 20 20 6f 70 20 3d 20  _MINUS:    op = 
3c80: 4f 50 5f 53 75 62 74 72 61 63 74 3b 20 62 72 65  OP_Subtract; bre
3c90: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  ak;.    case TK_
3ca0: 53 54 41 52 3a 20 20 20 20 20 6f 70 20 3d 20 4f  STAR:     op = O
3cb0: 50 5f 4d 75 6c 74 69 70 6c 79 3b 20 62 72 65 61  P_Multiply; brea
3cc0: 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 53  k;.    case TK_S
3cd0: 4c 41 53 48 3a 20 20 20 20 6f 70 20 3d 20 4f 50  LASH:    op = OP
3ce0: 5f 44 69 76 69 64 65 3b 20 20 20 62 72 65 61 6b  _Divide;   break
3cf0: 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 41 4e  ;.    case TK_AN
3d00: 44 3a 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f  D:      op = OP_
3d10: 41 6e 64 3b 20 20 20 20 20 20 62 72 65 61 6b 3b  And;      break;
3d20: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4f 52 3a  .    case TK_OR:
3d30: 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4f         op = OP_O
3d40: 72 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  r;       break;.
3d50: 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 54 3a 20      case TK_LT: 
3d60: 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4c 74        op = OP_Lt
3d70: 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;       break;. 
3d80: 20 20 20 63 61 73 65 20 54 4b 5f 4c 45 3a 20 20     case TK_LE:  
3d90: 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4c 65 3b       op = OP_Le;
3da0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
3db0: 20 20 63 61 73 65 20 54 4b 5f 47 54 3a 20 20 20    case TK_GT:   
3dc0: 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 74 3b 20      op = OP_Gt; 
3dd0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
3de0: 20 63 61 73 65 20 54 4b 5f 47 45 3a 20 20 20 20   case TK_GE:    
3df0: 20 20 20 6f 70 20 3d 20 4f 50 5f 47 65 3b 20 20     op = OP_Ge;  
3e00: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
3e10: 63 61 73 65 20 54 4b 5f 4e 45 3a 20 20 20 20 20  case TK_NE:     
3e20: 20 20 6f 70 20 3d 20 4f 50 5f 4e 65 3b 20 20 20    op = OP_Ne;   
3e30: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
3e40: 61 73 65 20 54 4b 5f 45 51 3a 20 20 20 20 20 20  ase TK_EQ:      
3e50: 20 6f 70 20 3d 20 4f 50 5f 45 71 3b 20 20 20 20   op = OP_Eq;    
3e60: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
3e70: 73 65 20 54 4b 5f 4c 49 4b 45 3a 20 20 20 20 20  se TK_LIKE:     
3e80: 6f 70 20 3d 20 4f 50 5f 4c 69 6b 65 3b 20 20 20  op = OP_Like;   
3e90: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
3ea0: 65 20 54 4b 5f 47 4c 4f 42 3a 20 20 20 20 20 6f  e TK_GLOB:     o
3eb0: 70 20 3d 20 4f 50 5f 47 6c 6f 62 3b 20 20 20 20  p = OP_Glob;    
3ec0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
3ed0: 20 54 4b 5f 49 53 4e 55 4c 4c 3a 20 20 20 6f 70   TK_ISNULL:   op
3ee0: 20 3d 20 4f 50 5f 49 73 4e 75 6c 6c 3b 20 20 20   = OP_IsNull;   
3ef0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
3f00: 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a 20 20 6f 70 20  TK_NOTNULL:  op 
3f10: 3d 20 4f 50 5f 4e 6f 74 4e 75 6c 6c 3b 20 20 62  = OP_NotNull;  b
3f20: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
3f30: 4b 5f 4e 4f 54 3a 20 20 20 20 20 20 6f 70 20 3d  K_NOT:      op =
3f40: 20 4f 50 5f 4e 6f 74 3b 20 20 20 20 20 20 62 72   OP_Not;      br
3f50: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
3f60: 5f 55 4d 49 4e 55 53 3a 20 20 20 6f 70 20 3d 20  _UMINUS:   op = 
3f70: 4f 50 5f 4e 65 67 61 74 69 76 65 3b 20 62 72 65  OP_Negative; bre
3f80: 61 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a  ak;.    default:
3f90: 20 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20 73 77   break;.  }.  sw
3fa0: 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70 20  itch( pExpr->op 
3fb0: 29 7b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 43  ){.    case TK_C
3fc0: 4f 4c 55 4d 4e 3a 20 7b 0a 20 20 20 20 20 20 69  OLUMN: {.      i
3fd0: 66 28 20 70 50 61 72 73 65 2d 3e 75 73 65 41 67  f( pParse->useAg
3fe0: 67 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  g ){.        sql
3ff0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
4000: 4f 50 5f 41 67 67 47 65 74 2c 20 30 2c 20 70 45  OP_AggGet, 0, pE
4010: 78 70 72 2d 3e 69 41 67 67 2c 20 30 2c 20 30 29  xpr->iAgg, 0, 0)
4020: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66  ;.      }else if
4030: 28 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e  ( pExpr->iColumn
4040: 3e 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 73  >=0 ){.        s
4050: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
4060: 2c 20 4f 50 5f 46 69 65 6c 64 2c 20 70 45 78 70  , OP_Field, pExp
4070: 72 2d 3e 69 54 61 62 6c 65 2c 20 70 45 78 70 72  r->iTable, pExpr
4080: 2d 3e 69 43 6f 6c 75 6d 6e 2c 20 30 2c 20 30 29  ->iColumn, 0, 0)
4090: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20  ;.      }else{. 
40a0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
40b0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4b 65 79  eAddOp(v, OP_Key
40c0: 2c 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 2c  , pExpr->iTable,
40d0: 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20   0, 0, 0);.     
40e0: 20 7d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a   }.      break;.
40f0: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
4100: 4b 5f 49 4e 54 45 47 45 52 3a 20 7b 0a 20 20 20  K_INTEGER: {.   
4110: 20 20 20 69 6e 74 20 69 20 3d 20 61 74 6f 69 28     int i = atoi(
4120: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 29 3b  pExpr->token.z);
4130: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
4140: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74  eAddOp(v, OP_Int
4150: 65 67 65 72 2c 20 69 2c 20 30 2c 20 30 2c 20 30  eger, i, 0, 0, 0
4160: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
4170: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
4180: 4b 5f 46 4c 4f 41 54 3a 20 7b 0a 20 20 20 20 20  K_FLOAT: {.     
4190: 20 69 6e 74 20 61 64 64 72 20 3d 20 73 71 6c 69   int addr = sqli
41a0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
41b0: 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30 2c 20  P_String, 0, 0, 
41c0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
41d0: 69 74 65 56 64 62 65 43 68 61 6e 67 65 50 33 28  iteVdbeChangeP3(
41e0: 76 2c 20 61 64 64 72 2c 20 70 45 78 70 72 2d 3e  v, addr, pExpr->
41f0: 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e  token.z, pExpr->
4200: 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20 20 20  token.n);.      
4210: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20  break;.    }.   
4220: 20 63 61 73 65 20 54 4b 5f 53 54 52 49 4e 47 3a   case TK_STRING:
4230: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 61 64 64   {.      int add
4240: 72 20 3d 20 73 71 6c 69 74 65 56 64 62 65 41 64  r = sqliteVdbeAd
4250: 64 4f 70 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67  dOp(v, OP_String
4260: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20  , 0, 0, 0, 0);. 
4270: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 43       sqliteVdbeC
4280: 68 61 6e 67 65 50 33 28 76 2c 20 61 64 64 72 2c  hangeP3(v, addr,
4290: 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c   pExpr->token.z,
42a0: 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 29   pExpr->token.n)
42b0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64  ;.      sqliteVd
42c0: 62 65 44 65 71 75 6f 74 65 50 33 28 76 2c 20 61  beDequoteP3(v, a
42d0: 64 64 72 29 3b 0a 20 20 20 20 20 20 62 72 65 61  ddr);.      brea
42e0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
42f0: 65 20 54 4b 5f 4e 55 4c 4c 3a 20 7b 0a 20 20 20  e TK_NULL: {.   
4300: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
4310: 4f 70 28 76 2c 20 4f 50 5f 4e 75 6c 6c 2c 20 30  Op(v, OP_Null, 0
4320: 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  , 0, 0, 0);.    
4330: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20    break;.    }. 
4340: 20 20 20 63 61 73 65 20 54 4b 5f 41 4e 44 3a 0a     case TK_AND:.
4350: 20 20 20 20 63 61 73 65 20 54 4b 5f 4f 52 3a 0a      case TK_OR:.
4360: 20 20 20 20 63 61 73 65 20 54 4b 5f 50 4c 55 53      case TK_PLUS
4370: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 53 54  :.    case TK_ST
4380: 41 52 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  AR:.    case TK_
4390: 4d 49 4e 55 53 3a 0a 20 20 20 20 63 61 73 65 20  MINUS:.    case 
43a0: 54 4b 5f 53 4c 41 53 48 3a 20 7b 0a 20 20 20 20  TK_SLASH: {.    
43b0: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
43c0: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
43d0: 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71  pLeft);.      sq
43e0: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
43f0: 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 52 69 67  rse, pExpr->pRig
4400: 68 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  ht);.      sqlit
4410: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f 70  eVdbeAddOp(v, op
4420: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20  , 0, 0, 0, 0);. 
4430: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
4440: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 43 4f  }.    case TK_CO
4450: 4e 43 41 54 3a 20 7b 0a 20 20 20 20 20 20 73 71  NCAT: {.      sq
4460: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
4470: 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66  rse, pExpr->pLef
4480: 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  t);.      sqlite
4490: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
44a0: 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 3b   pExpr->pRight);
44b0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
44c0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 43 6f 6e  eAddOp(v, OP_Con
44d0: 63 61 74 2c 20 32 2c 20 30 2c 20 30 2c 20 30 29  cat, 2, 0, 0, 0)
44e0: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
44f0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
4500: 5f 4c 54 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _LT:.    case TK
4510: 5f 4c 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _LE:.    case TK
4520: 5f 47 54 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _GT:.    case TK
4530: 5f 47 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _GE:.    case TK
4540: 5f 4e 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _NE:.    case TK
4550: 5f 45 51 3a 20 0a 20 20 20 20 63 61 73 65 20 54  _EQ: .    case T
4560: 4b 5f 4c 49 4b 45 3a 20 0a 20 20 20 20 63 61 73  K_LIKE: .    cas
4570: 65 20 54 4b 5f 47 4c 4f 42 3a 20 7b 0a 20 20 20  e TK_GLOB: {.   
4580: 20 20 20 69 6e 74 20 64 65 73 74 3b 0a 20 20 20     int dest;.   
4590: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
45a0: 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72  Op(v, OP_Integer
45b0: 2c 20 31 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20  , 1, 0, 0, 0);. 
45c0: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
45d0: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
45e0: 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20  r->pLeft);.     
45f0: 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28   sqliteExprCode(
4600: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
4610: 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20 64 65  Right);.      de
4620: 73 74 20 3d 20 73 71 6c 69 74 65 56 64 62 65 43  st = sqliteVdbeC
4630: 75 72 72 65 6e 74 41 64 64 72 28 76 29 20 2b 20  urrentAddr(v) + 
4640: 32 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  2;.      sqliteV
4650: 64 62 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20  dbeAddOp(v, op, 
4660: 30 2c 20 64 65 73 74 2c 20 30 2c 20 30 29 3b 0a  0, dest, 0, 0);.
4670: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
4680: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 41 64 64 49  AddOp(v, OP_AddI
4690: 6d 6d 2c 20 2d 31 2c 20 30 2c 20 30 2c 20 30 29  mm, -1, 0, 0, 0)
46a0: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
46b0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
46c0: 5f 55 4d 49 4e 55 53 3a 20 7b 0a 20 20 20 20 20  _UMINUS: {.     
46d0: 20 61 73 73 65 72 74 28 20 70 45 78 70 72 2d 3e   assert( pExpr->
46e0: 70 4c 65 66 74 20 29 3b 0a 20 20 20 20 20 20 69  pLeft );.      i
46f0: 66 28 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 2d  f( pExpr->pLeft-
4700: 3e 6f 70 3d 3d 54 4b 5f 49 4e 54 45 47 45 52 20  >op==TK_INTEGER 
4710: 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69  ){.        int i
4720: 20 3d 20 61 74 6f 69 28 70 45 78 70 72 2d 3e 70   = atoi(pExpr->p
4730: 4c 65 66 74 2d 3e 74 6f 6b 65 6e 2e 7a 29 3b 0a  Left->token.z);.
4740: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64          sqliteVd
4750: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e  beAddOp(v, OP_In
4760: 74 65 67 65 72 2c 20 2d 69 2c 20 30 2c 20 30 2c  teger, -i, 0, 0,
4770: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 62 72 65   0);.        bre
4780: 61 6b 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20  ak;.      }else 
4790: 69 66 28 20 70 45 78 70 72 2d 3e 70 4c 65 66 74  if( pExpr->pLeft
47a0: 2d 3e 6f 70 3d 3d 54 4b 5f 46 4c 4f 41 54 20 29  ->op==TK_FLOAT )
47b0: 7b 0a 20 20 20 20 20 20 20 20 54 6f 6b 65 6e 20  {.        Token 
47c0: 2a 70 20 3d 20 26 70 45 78 70 72 2d 3e 70 4c 65  *p = &pExpr->pLe
47d0: 66 74 2d 3e 74 6f 6b 65 6e 3b 0a 20 20 20 20 20  ft->token;.     
47e0: 20 20 20 63 68 61 72 20 2a 7a 20 3d 20 73 71 6c     char *z = sql
47f0: 69 74 65 4d 61 6c 6c 6f 63 28 20 70 2d 3e 6e 20  iteMalloc( p->n 
4800: 2b 20 32 20 29 3b 0a 20 20 20 20 20 20 20 20 73  + 2 );.        s
4810: 70 72 69 6e 74 66 28 7a 2c 20 22 2d 25 2e 2a 73  printf(z, "-%.*s
4820: 22 2c 20 70 2d 3e 6e 2c 20 70 2d 3e 7a 29 3b 0a  ", p->n, p->z);.
4830: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64          sqliteVd
4840: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 74  beAddOp(v, OP_St
4850: 72 69 6e 67 2c 20 30 2c 20 30 2c 20 7a 2c 20 30  ring, 0, 0, z, 0
4860: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
4870: 65 46 72 65 65 28 7a 29 3b 0a 20 20 20 20 20 20  eFree(z);.      
4880: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d    break;.      }
4890: 0a 20 20 20 20 20 20 2f 2a 20 46 61 6c 6c 20 74  .      /* Fall t
48a0: 68 72 6f 75 67 68 20 69 6e 74 6f 20 54 4b 5f 4e  hrough into TK_N
48b0: 4f 54 20 2a 2f 0a 20 20 20 20 7d 0a 20 20 20 20  OT */.    }.    
48c0: 63 61 73 65 20 54 4b 5f 4e 4f 54 3a 20 7b 0a 20  case TK_NOT: {. 
48d0: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
48e0: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
48f0: 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20  r->pLeft);.     
4900: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
4910: 28 76 2c 20 6f 70 2c 20 30 2c 20 30 2c 20 30 2c  (v, op, 0, 0, 0,
4920: 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b   0);.      break
4930: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
4940: 20 54 4b 5f 49 53 4e 55 4c 4c 3a 0a 20 20 20 20   TK_ISNULL:.    
4950: 63 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a  case TK_NOTNULL:
4960: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 64 65 73   {.      int des
4970: 74 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56  t;.      sqliteV
4980: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49  dbeAddOp(v, OP_I
4990: 6e 74 65 67 65 72 2c 20 31 2c 20 30 2c 20 30 2c  nteger, 1, 0, 0,
49a0: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
49b0: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
49c0: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
49d0: 0a 20 20 20 20 20 20 64 65 73 74 20 3d 20 73 71  .      dest = sq
49e0: 6c 69 74 65 56 64 62 65 43 75 72 72 65 6e 74 41  liteVdbeCurrentA
49f0: 64 64 72 28 76 29 20 2b 20 32 3b 0a 20 20 20 20  ddr(v) + 2;.    
4a00: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
4a10: 70 28 76 2c 20 6f 70 2c 20 30 2c 20 64 65 73 74  p(v, op, 0, dest
4a20: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73  , 0, 0);.      s
4a30: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
4a40: 2c 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 2d 31 2c  , OP_AddImm, -1,
4a50: 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20   0, 0, 0);.     
4a60: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
4a70: 20 20 63 61 73 65 20 54 4b 5f 41 47 47 5f 46 55    case TK_AGG_FU
4a80: 4e 43 54 49 4f 4e 3a 20 7b 0a 20 20 20 20 20 20  NCTION: {.      
4a90: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
4aa0: 76 2c 20 4f 50 5f 41 67 67 47 65 74 2c 20 30 2c  v, OP_AggGet, 0,
4ab0: 20 70 45 78 70 72 2d 3e 69 41 67 67 2c 20 30 2c   pExpr->iAgg, 0,
4ac0: 20 30 29 3b 0a 20 20 20 20 20 20 69 66 28 20 70   0);.      if( p
4ad0: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 3d 3d 46  Expr->iColumn==F
4ae0: 4e 5f 41 76 67 20 29 7b 0a 20 20 20 20 20 20 20  N_Avg ){.       
4af0: 20 61 73 73 65 72 74 28 20 70 50 61 72 73 65 2d   assert( pParse-
4b00: 3e 69 41 67 67 43 6f 75 6e 74 3e 3d 30 20 26 26  >iAggCount>=0 &&
4b10: 20 70 50 61 72 73 65 2d 3e 69 41 67 67 43 6f 75   pParse->iAggCou
4b20: 6e 74 3c 70 50 61 72 73 65 2d 3e 6e 41 67 67 20  nt<pParse->nAgg 
4b30: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
4b40: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
4b50: 5f 41 67 67 47 65 74 2c 20 30 2c 20 70 50 61 72  _AggGet, 0, pPar
4b60: 73 65 2d 3e 69 41 67 67 43 6f 75 6e 74 2c 20 30  se->iAggCount, 0
4b70: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73 71  , 0);.        sq
4b80: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
4b90: 20 4f 50 5f 44 69 76 69 64 65 2c 20 30 2c 20 30   OP_Divide, 0, 0
4ba0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d  , 0, 0);.      }
4bb0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
4bc0: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
4bd0: 46 55 4e 43 54 49 4f 4e 3a 20 7b 0a 20 20 20 20  FUNCTION: {.    
4be0: 20 20 69 6e 74 20 69 64 20 3d 20 70 45 78 70 72    int id = pExpr
4bf0: 2d 3e 69 43 6f 6c 75 6d 6e 3b 0a 20 20 20 20 20  ->iColumn;.     
4c00: 20 69 6e 74 20 6f 70 3b 0a 20 20 20 20 20 20 69   int op;.      i
4c10: 6e 74 20 69 3b 0a 20 20 20 20 20 20 45 78 70 72  nt i;.      Expr
4c20: 4c 69 73 74 20 2a 70 4c 69 73 74 20 3d 20 70 45  List *pList = pE
4c30: 78 70 72 2d 3e 70 4c 69 73 74 3b 0a 20 20 20 20  xpr->pList;.    
4c40: 20 20 73 77 69 74 63 68 28 20 69 64 20 29 7b 0a    switch( id ){.
4c50: 20 20 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f          case FN_
4c60: 46 63 6e 74 3a 20 7b 0a 20 20 20 20 20 20 20 20  Fcnt: {.        
4c70: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
4c80: 70 28 76 2c 20 4f 50 5f 46 63 6e 74 2c 20 30 2c  p(v, OP_Fcnt, 0,
4c90: 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20   0, 0, 0);.     
4ca0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
4cb0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 63 61      }.        ca
4cc0: 73 65 20 46 4e 5f 4d 69 6e 3a 20 0a 20 20 20 20  se FN_Min: .    
4cd0: 20 20 20 20 63 61 73 65 20 46 4e 5f 4d 61 78 3a      case FN_Max:
4ce0: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 6f 70 20   {.          op 
4cf0: 3d 20 69 64 3d 3d 46 4e 5f 4d 69 6e 20 3f 20 4f  = id==FN_Min ? O
4d00: 50 5f 4d 69 6e 20 3a 20 4f 50 5f 4d 61 78 3b 0a  P_Min : OP_Max;.
4d10: 20 20 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d            for(i=
4d20: 30 3b 20 69 3c 70 4c 69 73 74 2d 3e 6e 45 78 70  0; i<pList->nExp
4d30: 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20  r; i++){.       
4d40: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
4d50: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 4c 69 73  ode(pParse, pLis
4d60: 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 29 3b 0a  t->a[i].pExpr);.
4d70: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28 20              if( 
4d80: 69 3e 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  i>0 ){.         
4d90: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
4da0: 64 64 4f 70 28 76 2c 20 6f 70 2c 20 30 2c 20 30  ddOp(v, op, 0, 0
4db0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  , 0, 0);.       
4dc0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
4dd0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 62 72 65   }.          bre
4de0: 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ak;.        }.  
4df0: 20 20 20 20 20 20 63 61 73 65 20 46 4e 5f 4c 65        case FN_Le
4e00: 6e 67 74 68 3a 20 7b 0a 20 20 20 20 20 20 20 20  ngth: {.        
4e10: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
4e20: 28 70 50 61 72 73 65 2c 20 70 4c 69 73 74 2d 3e  (pParse, pList->
4e30: 61 5b 30 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20  a[0].pExpr);.   
4e40: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
4e50: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 74 72  eAddOp(v, OP_Str
4e60: 6c 65 6e 2c 20 30 2c 20 30 2c 20 30 2c 20 30 29  len, 0, 0, 0, 0)
4e70: 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72 65 61  ;.          brea
4e80: 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  k;.        }.   
4e90: 20 20 20 20 20 63 61 73 65 20 46 4e 5f 53 75 62       case FN_Sub
4ea0: 73 74 72 3a 20 7b 0a 20 20 20 20 20 20 20 20 20  str: {.         
4eb0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 4c 69 73   for(i=0; i<pLis
4ec0: 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a  t->nExpr; i++){.
4ed0: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
4ee0: 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73  teExprCode(pPars
4ef0: 65 2c 20 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70  e, pList->a[i].p
4f00: 45 78 70 72 29 3b 0a 20 20 20 20 20 20 20 20 20  Expr);.         
4f10: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c   }.          sql
4f20: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
4f30: 4f 50 5f 53 75 62 73 74 72 2c 20 30 2c 20 30 2c  OP_Substr, 0, 0,
4f40: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   0, 0);.        
4f50: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20    break;.       
4f60: 20 7d 0a 20 20 20 20 20 20 20 20 64 65 66 61 75   }.        defau
4f70: 6c 74 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20  lt: {.          
4f80: 2f 2a 20 43 61 6e 27 74 20 68 61 70 70 65 6e 21  /* Can't happen!
4f90: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 62 72   */.          br
4fa0: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  eak;.        }. 
4fb0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65       }.      bre
4fc0: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61  ak;.    }.    ca
4fd0: 73 65 20 54 4b 5f 53 45 4c 45 43 54 3a 20 7b 0a  se TK_SELECT: {.
4fe0: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
4ff0: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4d 65 6d 4c  AddOp(v, OP_MemL
5000: 6f 61 64 2c 20 70 45 78 70 72 2d 3e 69 43 6f 6c  oad, pExpr->iCol
5010: 75 6d 6e 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20  umn, 0, 0, 0);. 
5020: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
5030: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 4e  }.    case TK_IN
5040: 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 61 64  : {.      int ad
5050: 64 72 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  dr;.      sqlite
5060: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
5070: 49 6e 74 65 67 65 72 2c 20 31 2c 20 30 2c 20 30  Integer, 1, 0, 0
5080: 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  , 0);.      sqli
5090: 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73  teExprCode(pPars
50a0: 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29  e, pExpr->pLeft)
50b0: 3b 0a 20 20 20 20 20 20 61 64 64 72 20 3d 20 73  ;.      addr = s
50c0: 71 6c 69 74 65 56 64 62 65 43 75 72 72 65 6e 74  qliteVdbeCurrent
50d0: 41 64 64 72 28 76 29 3b 0a 20 20 20 20 20 20 69  Addr(v);.      i
50e0: 66 28 20 70 45 78 70 72 2d 3e 70 53 65 6c 65 63  f( pExpr->pSelec
50f0: 74 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  t ){.        sql
5100: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
5110: 4f 50 5f 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d  OP_Found, pExpr-
5120: 3e 69 54 61 62 6c 65 2c 20 61 64 64 72 2b 32 2c  >iTable, addr+2,
5130: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d 65   0, 0);.      }e
5140: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  lse{.        sql
5150: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
5160: 4f 50 5f 53 65 74 46 6f 75 6e 64 2c 20 70 45 78  OP_SetFound, pEx
5170: 70 72 2d 3e 69 54 61 62 6c 65 2c 20 61 64 64 72  pr->iTable, addr
5180: 2b 32 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20  +2, 0, 0);.     
5190: 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56   }.      sqliteV
51a0: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 41  dbeAddOp(v, OP_A
51b0: 64 64 49 6d 6d 2c 20 2d 31 2c 20 30 2c 20 30 2c  ddImm, -1, 0, 0,
51c0: 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b   0);.      break
51d0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
51e0: 20 54 4b 5f 42 45 54 57 45 45 4e 3a 20 7b 0a 20   TK_BETWEEN: {. 
51f0: 20 20 20 20 20 69 6e 74 20 6c 62 6c 20 3d 20 73       int lbl = s
5200: 71 6c 69 74 65 56 64 62 65 4d 61 6b 65 4c 61 62  qliteVdbeMakeLab
5210: 65 6c 28 76 29 3b 0a 20 20 20 20 20 20 73 71 6c  el(v);.      sql
5220: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
5230: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 30 2c 20 30  OP_Integer, 0, 0
5240: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73  , 0, 0);.      s
5250: 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73 65  qliteExprIfFalse
5260: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2c 20  (pParse, pExpr, 
5270: 6c 62 6c 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  lbl);.      sqli
5280: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
5290: 50 5f 41 64 64 49 6d 6d 2c 20 31 2c 20 30 2c 20  P_AddImm, 1, 0, 
52a0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
52b0: 69 74 65 56 64 62 65 52 65 73 6f 6c 76 65 4c 61  iteVdbeResolveLa
52c0: 62 65 6c 28 76 2c 20 6c 62 6c 29 3b 0a 20 20 20  bel(v, lbl);.   
52d0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
52e0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 3b 0a 7d 0a    }.  return;.}.
52f0: 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20  ./*.** Generate 
5300: 63 6f 64 65 20 66 6f 72 20 61 20 62 6f 6f 6c 65  code for a boole
5310: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 73 75  an expression su
5320: 63 68 20 74 68 61 74 20 61 20 6a 75 6d 70 20 69  ch that a jump i
5330: 73 20 6d 61 64 65 0a 2a 2a 20 74 6f 20 74 68 65  s made.** to the
5340: 20 6c 61 62 65 6c 20 22 64 65 73 74 22 20 69 66   label "dest" if
5350: 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20   the expression 
5360: 69 73 20 74 72 75 65 20 62 75 74 20 65 78 65 63  is true but exec
5370: 75 74 69 6f 6e 0a 2a 2a 20 63 6f 6e 74 69 6e 75  ution.** continu
5380: 65 73 20 73 74 72 61 69 67 68 74 20 74 68 72 75  es straight thru
5390: 20 69 66 20 74 68 65 20 65 78 70 72 65 73 73 69   if the expressi
53a0: 6f 6e 20 69 73 20 66 61 6c 73 65 2e 0a 2a 2f 0a  on is false..*/.
53b0: 76 6f 69 64 20 73 71 6c 69 74 65 45 78 70 72 49  void sqliteExprI
53c0: 66 54 72 75 65 28 50 61 72 73 65 20 2a 70 50 61  fTrue(Parse *pPa
53d0: 72 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70 72  rse, Expr *pExpr
53e0: 2c 20 69 6e 74 20 64 65 73 74 29 7b 0a 20 20 56  , int dest){.  V
53f0: 64 62 65 20 2a 76 20 3d 20 70 50 61 72 73 65 2d  dbe *v = pParse-
5400: 3e 70 56 64 62 65 3b 0a 20 20 69 6e 74 20 6f 70  >pVdbe;.  int op
5410: 20 3d 20 30 3b 0a 20 20 69 66 28 20 76 3d 3d 30   = 0;.  if( v==0
5420: 20 7c 7c 20 70 45 78 70 72 3d 3d 30 20 29 20 72   || pExpr==0 ) r
5430: 65 74 75 72 6e 3b 0a 20 20 73 77 69 74 63 68 28  eturn;.  switch(
5440: 20 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20 20   pExpr->op ){.  
5450: 20 20 63 61 73 65 20 54 4b 5f 4c 54 3a 20 20 20    case TK_LT:   
5460: 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4c 74 3b 20      op = OP_Lt; 
5470: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
5480: 20 63 61 73 65 20 54 4b 5f 4c 45 3a 20 20 20 20   case TK_LE:    
5490: 20 20 20 6f 70 20 3d 20 4f 50 5f 4c 65 3b 20 20     op = OP_Le;  
54a0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
54b0: 63 61 73 65 20 54 4b 5f 47 54 3a 20 20 20 20 20  case TK_GT:     
54c0: 20 20 6f 70 20 3d 20 4f 50 5f 47 74 3b 20 20 20    op = OP_Gt;   
54d0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
54e0: 61 73 65 20 54 4b 5f 47 45 3a 20 20 20 20 20 20  ase TK_GE:      
54f0: 20 6f 70 20 3d 20 4f 50 5f 47 65 3b 20 20 20 20   op = OP_Ge;    
5500: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
5510: 73 65 20 54 4b 5f 4e 45 3a 20 20 20 20 20 20 20  se TK_NE:       
5520: 6f 70 20 3d 20 4f 50 5f 4e 65 3b 20 20 20 20 20  op = OP_Ne;     
5530: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
5540: 65 20 54 4b 5f 45 51 3a 20 20 20 20 20 20 20 6f  e TK_EQ:       o
5550: 70 20 3d 20 4f 50 5f 45 71 3b 20 20 20 20 20 20  p = OP_Eq;      
5560: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
5570: 20 54 4b 5f 4c 49 4b 45 3a 20 20 20 20 20 6f 70   TK_LIKE:     op
5580: 20 3d 20 4f 50 5f 4c 69 6b 65 3b 20 20 20 20 20   = OP_Like;     
5590: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
55a0: 54 4b 5f 47 4c 4f 42 3a 20 20 20 20 20 6f 70 20  TK_GLOB:     op 
55b0: 3d 20 4f 50 5f 47 6c 6f 62 3b 20 20 20 20 20 62  = OP_Glob;     b
55c0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
55d0: 4b 5f 49 53 4e 55 4c 4c 3a 20 20 20 6f 70 20 3d  K_ISNULL:   op =
55e0: 20 4f 50 5f 49 73 4e 75 6c 6c 3b 20 20 20 62 72   OP_IsNull;   br
55f0: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
5600: 5f 4e 4f 54 4e 55 4c 4c 3a 20 20 6f 70 20 3d 20  _NOTNULL:  op = 
5610: 4f 50 5f 4e 6f 74 4e 75 6c 6c 3b 20 20 62 72 65  OP_NotNull;  bre
5620: 61 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a  ak;.    default:
5630: 20 20 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20 73    break;.  }.  s
5640: 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70  witch( pExpr->op
5650: 20 29 7b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f   ){.    case TK_
5660: 41 4e 44 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74  AND: {.      int
5670: 20 64 32 20 3d 20 73 71 6c 69 74 65 56 64 62 65   d2 = sqliteVdbe
5680: 4d 61 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20 20  MakeLabel(v);.  
5690: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 49 66      sqliteExprIf
56a0: 46 61 6c 73 65 28 70 50 61 72 73 65 2c 20 70 45  False(pParse, pE
56b0: 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64 32 29 3b  xpr->pLeft, d2);
56c0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
56d0: 72 49 66 54 72 75 65 28 70 50 61 72 73 65 2c 20  rIfTrue(pParse, 
56e0: 70 45 78 70 72 2d 3e 70 52 69 67 68 74 2c 20 64  pExpr->pRight, d
56f0: 65 73 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  est);.      sqli
5700: 74 65 56 64 62 65 52 65 73 6f 6c 76 65 4c 61 62  teVdbeResolveLab
5710: 65 6c 28 76 2c 20 64 32 29 3b 0a 20 20 20 20 20  el(v, d2);.     
5720: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
5730: 20 20 63 61 73 65 20 54 4b 5f 4f 52 3a 20 7b 0a    case TK_OR: {.
5740: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
5750: 49 66 54 72 75 65 28 70 50 61 72 73 65 2c 20 70  IfTrue(pParse, p
5760: 45 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64 65 73  Expr->pLeft, des
5770: 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  t);.      sqlite
5780: 45 78 70 72 49 66 54 72 75 65 28 70 50 61 72 73  ExprIfTrue(pPars
5790: 65 2c 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74  e, pExpr->pRight
57a0: 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20 20 62  , dest);.      b
57b0: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  reak;.    }.    
57c0: 63 61 73 65 20 54 4b 5f 4e 4f 54 3a 20 7b 0a 20  case TK_NOT: {. 
57d0: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 49       sqliteExprI
57e0: 66 46 61 6c 73 65 28 70 50 61 72 73 65 2c 20 70  fFalse(pParse, p
57f0: 45 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64 65 73  Expr->pLeft, des
5800: 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  t);.      break;
5810: 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20  .    }.    case 
5820: 54 4b 5f 4c 54 3a 0a 20 20 20 20 63 61 73 65 20  TK_LT:.    case 
5830: 54 4b 5f 4c 45 3a 0a 20 20 20 20 63 61 73 65 20  TK_LE:.    case 
5840: 54 4b 5f 47 54 3a 0a 20 20 20 20 63 61 73 65 20  TK_GT:.    case 
5850: 54 4b 5f 47 45 3a 0a 20 20 20 20 63 61 73 65 20  TK_GE:.    case 
5860: 54 4b 5f 4e 45 3a 0a 20 20 20 20 63 61 73 65 20  TK_NE:.    case 
5870: 54 4b 5f 45 51 3a 0a 20 20 20 20 63 61 73 65 20  TK_EQ:.    case 
5880: 54 4b 5f 4c 49 4b 45 3a 0a 20 20 20 20 63 61 73  TK_LIKE:.    cas
5890: 65 20 54 4b 5f 47 4c 4f 42 3a 20 7b 0a 20 20 20  e TK_GLOB: {.   
58a0: 20 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64     sqliteExprCod
58b0: 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  e(pParse, pExpr-
58c0: 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73  >pLeft);.      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 52 69  arse, pExpr->pRi
58f0: 67 68 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  ght);.      sqli
5900: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f  teVdbeAddOp(v, o
5910: 70 2c 20 30 2c 20 64 65 73 74 2c 20 30 2c 20 30  p, 0, dest, 0, 0
5920: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
5930: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54      }.    case T
5940: 4b 5f 49 53 4e 55 4c 4c 3a 0a 20 20 20 20 63 61  K_ISNULL:.    ca
5950: 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a 20 7b  se TK_NOTNULL: {
5960: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
5970: 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45  rCode(pParse, pE
5980: 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20  xpr->pLeft);.   
5990: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
59a0: 4f 70 28 76 2c 20 6f 70 2c 20 30 2c 20 64 65 73  Op(v, op, 0, des
59b0: 74 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  t, 0, 0);.      
59c0: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20  break;.    }.   
59d0: 20 63 61 73 65 20 54 4b 5f 49 4e 3a 20 7b 0a 20   case TK_IN: {. 
59e0: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
59f0: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
5a00: 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20  r->pLeft);.     
5a10: 20 69 66 28 20 70 45 78 70 72 2d 3e 70 53 65 6c   if( pExpr->pSel
5a20: 65 63 74 20 29 7b 0a 20 20 20 20 20 20 20 20 73  ect ){.        s
5a30: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
5a40: 2c 20 4f 50 5f 46 6f 75 6e 64 2c 20 70 45 78 70  , OP_Found, pExp
5a50: 72 2d 3e 69 54 61 62 6c 65 2c 20 64 65 73 74 2c  r->iTable, dest,
5a60: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d 65   0, 0);.      }e
5a70: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  lse{.        sql
5a80: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
5a90: 4f 50 5f 53 65 74 46 6f 75 6e 64 2c 20 70 45 78  OP_SetFound, pEx
5aa0: 70 72 2d 3e 69 54 61 62 6c 65 2c 20 64 65 73 74  pr->iTable, dest
5ab0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d  , 0, 0);.      }
5ac0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
5ad0: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
5ae0: 42 45 54 57 45 45 4e 3a 20 7b 0a 20 20 20 20 20  BETWEEN: {.     
5af0: 20 69 6e 74 20 6c 62 6c 20 3d 20 73 71 6c 69 74   int lbl = sqlit
5b00: 65 56 64 62 65 4d 61 6b 65 4c 61 62 65 6c 28 76  eVdbeMakeLabel(v
5b10: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45  );.      sqliteE
5b20: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
5b30: 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20  pExpr->pLeft);. 
5b40: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
5b50: 64 64 4f 70 28 76 2c 20 4f 50 5f 44 75 70 2c 20  ddOp(v, OP_Dup, 
5b60: 30 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20  0, 0, 0, 0);.   
5b70: 20 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64     sqliteExprCod
5b80: 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  e(pParse, pExpr-
5b90: 3e 70 4c 69 73 74 2d 3e 61 5b 30 5d 2e 70 45 78  >pList->a[0].pEx
5ba0: 70 72 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  pr);.      sqlit
5bb0: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
5bc0: 5f 4c 74 2c 20 30 2c 20 6c 62 6c 2c 20 30 2c 20  _Lt, 0, lbl, 0, 
5bd0: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
5be0: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
5bf0: 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61   pExpr->pList->a
5c00: 5b 31 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20  [1].pExpr);.    
5c10: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
5c20: 70 28 76 2c 20 4f 50 5f 4c 65 2c 20 30 2c 20 64  p(v, OP_Le, 0, d
5c30: 65 73 74 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  est, 0, 0);.    
5c40: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
5c50: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
5c60: 20 30 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20   0, 0, 0, 0);.  
5c70: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
5c80: 64 4f 70 28 76 2c 20 4f 50 5f 50 6f 70 2c 20 31  dOp(v, OP_Pop, 1
5c90: 2c 20 30 2c 20 30 2c 20 6c 62 6c 29 3b 0a 20 20  , 0, 0, lbl);.  
5ca0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
5cb0: 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b 0a  .    default: {.
5cc0: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
5cd0: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78  Code(pParse, pEx
5ce0: 70 72 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  pr);.      sqlit
5cf0: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
5d00: 5f 49 66 2c 20 30 2c 20 64 65 73 74 2c 20 30 2c  _If, 0, dest, 0,
5d10: 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b   0);.      break
5d20: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f  ;.    }.  }.}../
5d30: 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20 63 6f  *.** Generate co
5d40: 64 65 20 66 6f 72 20 61 20 62 6f 6f 6c 65 61 6e  de for a boolean
5d50: 20 65 78 70 72 65 73 73 69 6f 6e 20 73 75 63 68   expression such
5d60: 20 74 68 61 74 20 61 20 6a 75 6d 70 20 69 73 20   that a jump is 
5d70: 6d 61 64 65 0a 2a 2a 20 74 6f 20 74 68 65 20 6c  made.** to the l
5d80: 61 62 65 6c 20 22 64 65 73 74 22 20 69 66 20 74  abel "dest" if t
5d90: 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69 73  he expression is
5da0: 20 66 61 6c 73 65 20 62 75 74 20 65 78 65 63 75   false but execu
5db0: 74 69 6f 6e 0a 2a 2a 20 63 6f 6e 74 69 6e 75 65  tion.** continue
5dc0: 73 20 73 74 72 61 69 67 68 74 20 74 68 72 75 20  s straight thru 
5dd0: 69 66 20 74 68 65 20 65 78 70 72 65 73 73 69 6f  if the expressio
5de0: 6e 20 69 73 20 74 72 75 65 2e 0a 2a 2f 0a 76 6f  n is true..*/.vo
5df0: 69 64 20 73 71 6c 69 74 65 45 78 70 72 49 66 46  id sqliteExprIfF
5e00: 61 6c 73 65 28 50 61 72 73 65 20 2a 70 50 61 72  alse(Parse *pPar
5e10: 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70 72 2c  se, Expr *pExpr,
5e20: 20 69 6e 74 20 64 65 73 74 29 7b 0a 20 20 56 64   int dest){.  Vd
5e30: 62 65 20 2a 76 20 3d 20 70 50 61 72 73 65 2d 3e  be *v = pParse->
5e40: 70 56 64 62 65 3b 0a 20 20 69 6e 74 20 6f 70 20  pVdbe;.  int op 
5e50: 3d 20 30 3b 0a 20 20 69 66 28 20 76 3d 3d 30 20  = 0;.  if( v==0 
5e60: 7c 7c 20 70 45 78 70 72 3d 3d 30 20 29 20 72 65  || pExpr==0 ) re
5e70: 74 75 72 6e 3b 0a 20 20 73 77 69 74 63 68 28 20  turn;.  switch( 
5e80: 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20  pExpr->op ){.   
5e90: 20 63 61 73 65 20 54 4b 5f 4c 54 3a 20 20 20 20   case TK_LT:    
5ea0: 20 20 20 6f 70 20 3d 20 4f 50 5f 47 65 3b 20 20     op = OP_Ge;  
5eb0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
5ec0: 63 61 73 65 20 54 4b 5f 4c 45 3a 20 20 20 20 20  case TK_LE:     
5ed0: 20 20 6f 70 20 3d 20 4f 50 5f 47 74 3b 20 20 20    op = OP_Gt;   
5ee0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
5ef0: 61 73 65 20 54 4b 5f 47 54 3a 20 20 20 20 20 20  ase TK_GT:      
5f00: 20 6f 70 20 3d 20 4f 50 5f 4c 65 3b 20 20 20 20   op = OP_Le;    
5f10: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
5f20: 73 65 20 54 4b 5f 47 45 3a 20 20 20 20 20 20 20  se TK_GE:       
5f30: 6f 70 20 3d 20 4f 50 5f 4c 74 3b 20 20 20 20 20  op = OP_Lt;     
5f40: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
5f50: 65 20 54 4b 5f 4e 45 3a 20 20 20 20 20 20 20 6f  e TK_NE:       o
5f60: 70 20 3d 20 4f 50 5f 45 71 3b 20 20 20 20 20 20  p = OP_Eq;      
5f70: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
5f80: 20 54 4b 5f 45 51 3a 20 20 20 20 20 20 20 6f 70   TK_EQ:       op
5f90: 20 3d 20 4f 50 5f 4e 65 3b 20 20 20 20 20 20 20   = OP_Ne;       
5fa0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
5fb0: 54 4b 5f 4c 49 4b 45 3a 20 20 20 20 20 6f 70 20  TK_LIKE:     op 
5fc0: 3d 20 4f 50 5f 4c 69 6b 65 3b 20 20 20 20 20 62  = OP_Like;     b
5fd0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
5fe0: 4b 5f 47 4c 4f 42 3a 20 20 20 20 20 6f 70 20 3d  K_GLOB:     op =
5ff0: 20 4f 50 5f 47 6c 6f 62 3b 20 20 20 20 20 62 72   OP_Glob;     br
6000: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
6010: 5f 49 53 4e 55 4c 4c 3a 20 20 20 6f 70 20 3d 20  _ISNULL:   op = 
6020: 4f 50 5f 4e 6f 74 4e 75 6c 6c 3b 20 20 62 72 65  OP_NotNull;  bre
6030: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  ak;.    case TK_
6040: 4e 4f 54 4e 55 4c 4c 3a 20 20 6f 70 20 3d 20 4f  NOTNULL:  op = O
6050: 50 5f 49 73 4e 75 6c 6c 3b 20 20 20 62 72 65 61  P_IsNull;   brea
6060: 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20  k;.    default: 
6070: 20 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20 73 77   break;.  }.  sw
6080: 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70 20  itch( pExpr->op 
6090: 29 7b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 41  ){.    case TK_A
60a0: 4e 44 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69  ND: {.      sqli
60b0: 74 65 45 78 70 72 49 66 46 61 6c 73 65 28 70 50  teExprIfFalse(pP
60c0: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65  arse, pExpr->pLe
60d0: 66 74 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20  ft, dest);.     
60e0: 20 73 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c   sqliteExprIfFal
60f0: 73 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  se(pParse, pExpr
6100: 2d 3e 70 52 69 67 68 74 2c 20 64 65 73 74 29 3b  ->pRight, dest);
6110: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
6120: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
6130: 4f 52 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20  OR: {.      int 
6140: 64 32 20 3d 20 73 71 6c 69 74 65 56 64 62 65 4d  d2 = sqliteVdbeM
6150: 61 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20 20 20  akeLabel(v);.   
6160: 20 20 20 73 71 6c 69 74 65 45 78 70 72 49 66 54     sqliteExprIfT
6170: 72 75 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  rue(pParse, pExp
6180: 72 2d 3e 70 4c 65 66 74 2c 20 64 32 29 3b 0a 20  r->pLeft, d2);. 
6190: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 49       sqliteExprI
61a0: 66 46 61 6c 73 65 28 70 50 61 72 73 65 2c 20 70  fFalse(pParse, p
61b0: 45 78 70 72 2d 3e 70 52 69 67 68 74 2c 20 64 65  Expr->pRight, de
61c0: 73 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  st);.      sqlit
61d0: 65 56 64 62 65 52 65 73 6f 6c 76 65 4c 61 62 65  eVdbeResolveLabe
61e0: 6c 28 76 2c 20 64 32 29 3b 0a 20 20 20 20 20 20  l(v, d2);.      
61f0: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20  break;.    }.   
6200: 20 63 61 73 65 20 54 4b 5f 4e 4f 54 3a 20 7b 0a   case TK_NOT: {.
6210: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
6220: 49 66 54 72 75 65 28 70 50 61 72 73 65 2c 20 70  IfTrue(pParse, p
6230: 45 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64 65 73  Expr->pLeft, des
6240: 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  t);.      break;
6250: 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20  .    }.    case 
6260: 54 4b 5f 4c 54 3a 0a 20 20 20 20 63 61 73 65 20  TK_LT:.    case 
6270: 54 4b 5f 4c 45 3a 0a 20 20 20 20 63 61 73 65 20  TK_LE:.    case 
6280: 54 4b 5f 47 54 3a 0a 20 20 20 20 63 61 73 65 20  TK_GT:.    case 
6290: 54 4b 5f 47 45 3a 0a 20 20 20 20 63 61 73 65 20  TK_GE:.    case 
62a0: 54 4b 5f 4e 45 3a 0a 20 20 20 20 63 61 73 65 20  TK_NE:.    case 
62b0: 54 4b 5f 45 51 3a 20 7b 0a 20 20 20 20 20 20 73  TK_EQ: {.      s
62c0: 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50  qliteExprCode(pP
62d0: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65  arse, pExpr->pLe
62e0: 66 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  ft);.      sqlit
62f0: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
6300: 2c 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29  , pExpr->pRight)
6310: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64  ;.      sqliteVd
6320: 62 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20 30  beAddOp(v, op, 0
6330: 2c 20 64 65 73 74 2c 20 30 2c 20 30 29 3b 0a 20  , dest, 0, 0);. 
6340: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
6350: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 49  }.    case TK_LI
6360: 4b 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  KE:.    case TK_
6370: 47 4c 4f 42 3a 20 7b 0a 20 20 20 20 20 20 73 71  GLOB: {.      sq
6380: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
6390: 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66  rse, pExpr->pLef
63a0: 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  t);.      sqlite
63b0: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
63c0: 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 3b   pExpr->pRight);
63d0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
63e0: 65 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20 31 2c  eAddOp(v, op, 1,
63f0: 20 64 65 73 74 2c 20 30 2c 20 30 29 3b 0a 20 20   dest, 0, 0);.  
6400: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
6410: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 53 4e  .    case TK_ISN
6420: 55 4c 4c 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  ULL:.    case TK
6430: 5f 4e 4f 54 4e 55 4c 4c 3a 20 7b 0a 20 20 20 20  _NOTNULL: {.    
6440: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
6450: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
6460: 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71  pLeft);.      sq
6470: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
6480: 20 6f 70 2c 20 30 2c 20 64 65 73 74 2c 20 30 2c   op, 0, dest, 0,
6490: 20 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b   0);.      break
64a0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
64b0: 20 54 4b 5f 49 4e 3a 20 7b 0a 20 20 20 20 20 20   TK_IN: {.      
64c0: 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70  sqliteExprCode(p
64d0: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c  Parse, pExpr->pL
64e0: 65 66 74 29 3b 0a 20 20 20 20 20 20 69 66 28 20  eft);.      if( 
64f0: 70 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 20 29  pExpr->pSelect )
6500: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
6510: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6520: 4e 6f 74 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d  NotFound, pExpr-
6530: 3e 69 54 61 62 6c 65 2c 20 64 65 73 74 2c 20 30  >iTable, dest, 0
6540: 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73  , 0);.      }els
6550: 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  e{.        sqlit
6560: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
6570: 5f 53 65 74 4e 6f 74 46 6f 75 6e 64 2c 20 70 45  _SetNotFound, pE
6580: 78 70 72 2d 3e 69 54 61 62 6c 65 2c 20 64 65 73  xpr->iTable, des
6590: 74 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  t, 0, 0);.      
65a0: 7d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  }.      break;. 
65b0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
65c0: 5f 42 45 54 57 45 45 4e 3a 20 7b 0a 20 20 20 20  _BETWEEN: {.    
65d0: 20 20 69 6e 74 20 61 64 64 72 3b 0a 20 20 20 20    int addr;.    
65e0: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
65f0: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
6600: 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71  pLeft);.      sq
6610: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
6620: 20 4f 50 5f 44 75 70 2c 20 30 2c 20 30 2c 20 30   OP_Dup, 0, 0, 0
6630: 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  , 0);.      sqli
6640: 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73  teExprCode(pPars
6650: 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d  e, pExpr->pList-
6660: 3e 61 5b 30 5d 2e 70 45 78 70 72 29 3b 0a 20 20  >a[0].pExpr);.  
6670: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
6680: 65 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72  eVdbeCurrentAddr
6690: 28 76 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  (v);.      sqlit
66a0: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
66b0: 5f 47 65 2c 20 30 2c 20 61 64 64 72 2b 33 2c 20  _Ge, 0, addr+3, 
66c0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
66d0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
66e0: 4f 50 5f 50 6f 70 2c 20 31 2c 20 30 2c 20 30 2c  OP_Pop, 1, 0, 0,
66f0: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
6700: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
6710: 5f 47 6f 74 6f 2c 20 30 2c 20 64 65 73 74 2c 20  _Goto, 0, dest, 
6720: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
6730: 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61 72  iteExprCode(pPar
6740: 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69 73 74  se, pExpr->pList
6750: 2d 3e 61 5b 31 5d 2e 70 45 78 70 72 29 3b 0a 20  ->a[1].pExpr);. 
6760: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
6770: 64 64 4f 70 28 76 2c 20 4f 50 5f 47 74 2c 20 30  ddOp(v, OP_Gt, 0
6780: 2c 20 64 65 73 74 2c 20 30 2c 20 30 29 3b 0a 20  , dest, 0, 0);. 
6790: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
67a0: 7d 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b  }.    default: {
67b0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
67c0: 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45  rCode(pParse, pE
67d0: 78 70 72 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  xpr);.      sqli
67e0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
67f0: 50 5f 4e 6f 74 2c 20 30 2c 20 30 2c 20 30 2c 20  P_Not, 0, 0, 0, 
6800: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
6810: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6820: 49 66 2c 20 30 2c 20 64 65 73 74 2c 20 30 2c 20  If, 0, dest, 0, 
6830: 30 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  0);.      break;
6840: 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a  .    }.  }.}../*
6850: 0a 2a 2a 20 44 6f 20 61 20 64 65 65 70 20 63 6f  .** Do a deep co
6860: 6d 70 61 72 69 73 6f 6e 20 6f 66 20 74 77 6f 20  mparison of two 
6870: 65 78 70 72 65 73 73 69 6f 6e 20 74 72 65 65 73  expression trees
6880: 2e 20 20 52 65 74 75 72 6e 20 54 52 55 45 20 28  .  Return TRUE (
6890: 6e 6f 6e 2d 7a 65 72 6f 29 0a 2a 2a 20 69 66 20  non-zero).** if 
68a0: 74 68 65 79 20 61 72 65 20 69 64 65 6e 74 69 63  they are identic
68b0: 61 6c 20 61 6e 64 20 72 65 74 75 72 6e 20 46 41  al and return FA
68c0: 4c 53 45 20 69 66 20 74 68 65 79 20 64 69 66 66  LSE if they diff
68d0: 65 72 20 69 6e 20 61 6e 79 20 77 61 79 2e 0a 2a  er in any way..*
68e0: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 45 78 70 72  /.int sqliteExpr
68f0: 43 6f 6d 70 61 72 65 28 45 78 70 72 20 2a 70 41  Compare(Expr *pA
6900: 2c 20 45 78 70 72 20 2a 70 42 29 7b 0a 20 20 69  , Expr *pB){.  i
6910: 6e 74 20 69 3b 0a 20 20 69 66 28 20 70 41 3d 3d  nt i;.  if( pA==
6920: 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  0 ){.    return 
6930: 70 42 3d 3d 30 3b 0a 20 20 7d 65 6c 73 65 20 69  pB==0;.  }else i
6940: 66 28 20 70 42 3d 3d 30 20 29 7b 0a 20 20 20 20  f( pB==0 ){.    
6950: 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20 20  return 0;.  }.  
6960: 69 66 28 20 70 41 2d 3e 6f 70 21 3d 70 42 2d 3e  if( pA->op!=pB->
6970: 6f 70 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  op ) return 0;. 
6980: 20 69 66 28 20 21 73 71 6c 69 74 65 45 78 70 72   if( !sqliteExpr
6990: 43 6f 6d 70 61 72 65 28 70 41 2d 3e 70 4c 65 66  Compare(pA->pLef
69a0: 74 2c 20 70 42 2d 3e 70 4c 65 66 74 29 20 29 20  t, pB->pLeft) ) 
69b0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 69 66 28 20  return 0;.  if( 
69c0: 21 73 71 6c 69 74 65 45 78 70 72 43 6f 6d 70 61  !sqliteExprCompa
69d0: 72 65 28 70 41 2d 3e 70 52 69 67 68 74 2c 20 70  re(pA->pRight, p
69e0: 42 2d 3e 70 52 69 67 68 74 29 20 29 20 72 65 74  B->pRight) ) ret
69f0: 75 72 6e 20 30 3b 0a 20 20 69 66 28 20 70 41 2d  urn 0;.  if( pA-
6a00: 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20 20 69 66  >pList ){.    if
6a10: 28 20 70 42 2d 3e 70 4c 69 73 74 3d 3d 30 20 29  ( pB->pList==0 )
6a20: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 69   return 0;.    i
6a30: 66 28 20 70 41 2d 3e 70 4c 69 73 74 2d 3e 6e 45  f( pA->pList->nE
6a40: 78 70 72 21 3d 70 42 2d 3e 70 4c 69 73 74 2d 3e  xpr!=pB->pList->
6a50: 6e 45 78 70 72 20 29 20 72 65 74 75 72 6e 20 30  nExpr ) return 0
6a60: 3b 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69  ;.    for(i=0; i
6a70: 3c 70 41 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70  <pA->pList->nExp
6a80: 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 69  r; i++){.      i
6a90: 66 28 20 21 73 71 6c 69 74 65 45 78 70 72 43 6f  f( !sqliteExprCo
6aa0: 6d 70 61 72 65 28 70 41 2d 3e 70 4c 69 73 74 2d  mpare(pA->pList-
6ab0: 3e 61 5b 69 5d 2e 70 45 78 70 72 2c 20 70 42 2d  >a[i].pExpr, pB-
6ac0: 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78  >pList->a[i].pEx
6ad0: 70 72 29 20 29 7b 0a 20 20 20 20 20 20 20 20 72  pr) ){.        r
6ae0: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20 7d  eturn 0;.      }
6af0: 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 20 69  .    }.  }else i
6b00: 66 28 20 70 42 2d 3e 70 4c 69 73 74 20 29 7b 0a  f( pB->pList ){.
6b10: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20      return 0;.  
6b20: 7d 0a 20 20 69 66 28 20 70 41 2d 3e 70 53 65 6c  }.  if( pA->pSel
6b30: 65 63 74 20 7c 7c 20 70 42 2d 3e 70 53 65 6c 65  ect || pB->pSele
6b40: 63 74 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  ct ) return 0;. 
6b50: 20 69 66 28 20 70 41 2d 3e 74 6f 6b 65 6e 2e 7a   if( pA->token.z
6b60: 20 29 7b 0a 20 20 20 20 69 66 28 20 70 42 2d 3e   ){.    if( pB->
6b70: 74 6f 6b 65 6e 2e 7a 3d 3d 30 20 29 20 72 65 74  token.z==0 ) ret
6b80: 75 72 6e 20 30 3b 0a 20 20 20 20 69 66 28 20 70  urn 0;.    if( p
6b90: 42 2d 3e 74 6f 6b 65 6e 2e 6e 21 3d 70 41 2d 3e  B->token.n!=pA->
6ba0: 74 6f 6b 65 6e 2e 6e 20 29 20 72 65 74 75 72 6e  token.n ) return
6bb0: 20 30 3b 0a 20 20 20 20 69 66 28 20 73 71 6c 69   0;.    if( sqli
6bc0: 74 65 53 74 72 4e 49 43 6d 70 28 70 41 2d 3e 74  teStrNICmp(pA->t
6bd0: 6f 6b 65 6e 2e 7a 2c 20 70 42 2d 3e 74 6f 6b 65  oken.z, pB->toke
6be0: 6e 2e 7a 2c 20 70 41 2d 3e 74 6f 6b 65 6e 2e 6e  n.z, pA->token.n
6bf0: 29 21 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b  )!=0 ) return 0;
6c00: 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 31 3b  .  }.  return 1;
6c10: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 64 64 20 61 20  .}../*.** Add a 
6c20: 6e 65 77 20 65 6c 65 6d 65 6e 74 20 74 6f 20 74  new element to t
6c30: 68 65 20 70 50 61 72 73 65 2d 3e 61 41 67 67 5b  he pParse->aAgg[
6c40: 5d 20 61 72 72 61 79 20 61 6e 64 20 72 65 74 75  ] array and retu
6c50: 72 6e 20 69 74 73 20 69 6e 64 65 78 2e 0a 2a 2f  rn its index..*/
6c60: 0a 73 74 61 74 69 63 20 69 6e 74 20 61 70 70 65  .static int appe
6c70: 6e 64 41 67 67 49 6e 66 6f 28 50 61 72 73 65 20  ndAggInfo(Parse 
6c80: 2a 70 50 61 72 73 65 29 7b 0a 20 20 69 66 28 20  *pParse){.  if( 
6c90: 28 70 50 61 72 73 65 2d 3e 6e 41 67 67 20 26 20  (pParse->nAgg & 
6ca0: 30 78 37 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69  0x7)==0 ){.    i
6cb0: 6e 74 20 61 6d 74 20 3d 20 70 50 61 72 73 65 2d  nt amt = pParse-
6cc0: 3e 6e 41 67 67 20 2b 20 38 3b 0a 20 20 20 20 70  >nAgg + 8;.    p
6cd0: 50 61 72 73 65 2d 3e 61 41 67 67 20 3d 20 73 71  Parse->aAgg = sq
6ce0: 6c 69 74 65 52 65 61 6c 6c 6f 63 28 70 50 61 72  liteRealloc(pPar
6cf0: 73 65 2d 3e 61 41 67 67 2c 20 61 6d 74 2a 73 69  se->aAgg, amt*si
6d00: 7a 65 6f 66 28 70 50 61 72 73 65 2d 3e 61 41 67  zeof(pParse->aAg
6d10: 67 5b 30 5d 29 29 3b 0a 20 20 20 20 69 66 28 20  g[0]));.    if( 
6d20: 70 50 61 72 73 65 2d 3e 61 41 67 67 3d 3d 30 20  pParse->aAgg==0 
6d30: 29 7b 0a 20 20 20 20 20 20 70 50 61 72 73 65 2d  ){.      pParse-
6d40: 3e 6e 41 67 67 20 3d 20 30 3b 0a 20 20 20 20 20  >nAgg = 0;.     
6d50: 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 20 20   return -1;.    
6d60: 7d 0a 20 20 7d 0a 20 20 6d 65 6d 73 65 74 28 26  }.  }.  memset(&
6d70: 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 70 50 61  pParse->aAgg[pPa
6d80: 72 73 65 2d 3e 6e 41 67 67 5d 2c 20 30 2c 20 73  rse->nAgg], 0, s
6d90: 69 7a 65 6f 66 28 70 50 61 72 73 65 2d 3e 61 41  izeof(pParse->aA
6da0: 67 67 5b 30 5d 29 29 3b 0a 20 20 72 65 74 75 72  gg[0]));.  retur
6db0: 6e 20 70 50 61 72 73 65 2d 3e 6e 41 67 67 2b 2b  n pParse->nAgg++
6dc0: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 6e 61 6c 79  ;.}../*.** Analy
6dd0: 7a 65 20 74 68 65 20 67 69 76 65 6e 20 65 78 70  ze the given exp
6de0: 72 65 73 73 69 6f 6e 20 6c 6f 6f 6b 69 6e 67 20  ression looking 
6df0: 66 6f 72 20 61 67 67 72 65 67 61 74 65 20 66 75  for aggregate fu
6e00: 6e 63 74 69 6f 6e 73 20 61 6e 64 0a 2a 2a 20 66  nctions and.** f
6e10: 6f 72 20 76 61 72 69 61 62 6c 65 73 20 74 68 61  or variables tha
6e20: 74 20 6e 65 65 64 20 74 6f 20 62 65 20 61 64 64  t need to be add
6e30: 65 64 20 74 6f 20 74 68 65 20 70 50 61 72 73 65  ed to the pParse
6e40: 2d 3e 61 41 67 67 5b 5d 20 61 72 72 61 79 2e 0a  ->aAgg[] array..
6e50: 2a 2a 20 4d 61 6b 65 20 61 64 64 69 74 69 6f 6e  ** Make addition
6e60: 61 6c 20 65 6e 74 72 69 65 73 20 74 6f 20 74 68  al entries to th
6e70: 65 20 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 5d  e pParse->aAgg[]
6e80: 20 61 72 72 61 79 20 61 73 20 6e 65 63 65 73 73   array as necess
6e90: 61 72 79 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  ary..**.** This 
6ea0: 72 6f 75 74 69 6e 65 20 73 68 6f 75 6c 64 20 6f  routine should o
6eb0: 6e 6c 79 20 62 65 20 63 61 6c 6c 65 64 20 61 66  nly be called af
6ec0: 74 65 72 20 74 68 65 20 65 78 70 72 65 73 73 69  ter the expressi
6ed0: 6f 6e 20 68 61 73 20 62 65 65 6e 0a 2a 2a 20 61  on has been.** a
6ee0: 6e 61 6c 79 7a 65 64 20 62 79 20 73 71 6c 69 74  nalyzed by sqlit
6ef0: 65 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73 28  eExprResolveIds(
6f00: 29 20 61 6e 64 20 73 71 6c 69 74 65 45 78 70 72  ) and sqliteExpr
6f10: 43 68 65 63 6b 28 29 2e 0a 2a 2a 0a 2a 2a 20 49  Check()..**.** I
6f20: 66 20 65 72 72 6f 72 73 20 61 72 65 20 73 65 65  f errors are see
6f30: 6e 2c 20 6c 65 61 76 65 20 61 6e 20 65 72 72 6f  n, leave an erro
6f40: 72 20 6d 65 73 73 61 67 65 20 69 6e 20 7a 45 72  r message in zEr
6f50: 72 4d 73 67 20 61 6e 64 20 72 65 74 75 72 6e 0a  rMsg and return.
6f60: 2a 2a 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  ** the number of
6f70: 20 65 72 72 6f 72 73 2e 0a 2a 2f 0a 69 6e 74 20   errors..*/.int 
6f80: 73 71 6c 69 74 65 45 78 70 72 41 6e 61 6c 79 7a  sqliteExprAnalyz
6f90: 65 41 67 67 72 65 67 61 74 65 73 28 50 61 72 73  eAggregates(Pars
6fa0: 65 20 2a 70 50 61 72 73 65 2c 20 45 78 70 72 20  e *pParse, Expr 
6fb0: 2a 70 45 78 70 72 29 7b 0a 20 20 69 6e 74 20 69  *pExpr){.  int i
6fc0: 3b 0a 20 20 41 67 67 45 78 70 72 20 2a 61 41 67  ;.  AggExpr *aAg
6fd0: 67 3b 0a 20 20 69 6e 74 20 6e 45 72 72 20 3d 20  g;.  int nErr = 
6fe0: 30 3b 0a 0a 20 20 69 66 28 20 70 45 78 70 72 3d  0;..  if( pExpr=
6ff0: 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  =0 ) return 0;. 
7000: 20 73 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e   switch( pExpr->
7010: 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20 54  op ){.    case T
7020: 4b 5f 43 4f 4c 55 4d 4e 3a 20 7b 0a 20 20 20 20  K_COLUMN: {.    
7030: 20 20 61 41 67 67 20 3d 20 70 50 61 72 73 65 2d    aAgg = pParse-
7040: 3e 61 41 67 67 3b 0a 20 20 20 20 20 20 66 6f 72  >aAgg;.      for
7050: 28 69 3d 30 3b 20 69 3c 70 50 61 72 73 65 2d 3e  (i=0; i<pParse->
7060: 6e 41 67 67 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  nAgg; i++){.    
7070: 20 20 20 20 69 66 28 20 61 41 67 67 5b 69 5d 2e      if( aAgg[i].
7080: 69 73 41 67 67 20 29 20 63 6f 6e 74 69 6e 75 65  isAgg ) continue
7090: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 61 41  ;.        if( aA
70a0: 67 67 5b 69 5d 2e 70 45 78 70 72 2d 3e 69 54 61  gg[i].pExpr->iTa
70b0: 62 6c 65 3d 3d 70 45 78 70 72 2d 3e 69 54 61 62  ble==pExpr->iTab
70c0: 6c 65 0a 20 20 20 20 20 20 20 20 20 26 26 20 61  le.         && a
70d0: 41 67 67 5b 69 5d 2e 70 45 78 70 72 2d 3e 69 43  Agg[i].pExpr->iC
70e0: 6f 6c 75 6d 6e 3d 3d 70 45 78 70 72 2d 3e 69 43  olumn==pExpr->iC
70f0: 6f 6c 75 6d 6e 20 29 7b 0a 20 20 20 20 20 20 20  olumn ){.       
7100: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
7110: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20    }.      }.    
7120: 20 20 69 66 28 20 69 3e 3d 70 50 61 72 73 65 2d    if( i>=pParse-
7130: 3e 6e 41 67 67 20 29 7b 0a 20 20 20 20 20 20 20  >nAgg ){.       
7140: 20 69 20 3d 20 61 70 70 65 6e 64 41 67 67 49 6e   i = appendAggIn
7150: 66 6f 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20  fo(pParse);.    
7160: 20 20 20 20 69 66 28 20 69 3c 30 20 29 20 72 65      if( i<0 ) re
7170: 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20  turn 1;.        
7180: 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 69 5d 2e  pParse->aAgg[i].
7190: 69 73 41 67 67 20 3d 20 30 3b 0a 20 20 20 20 20  isAgg = 0;.     
71a0: 20 20 20 70 50 61 72 73 65 2d 3e 61 41 67 67 5b     pParse->aAgg[
71b0: 69 5d 2e 70 45 78 70 72 20 3d 20 70 45 78 70 72  i].pExpr = pExpr
71c0: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
71d0: 70 45 78 70 72 2d 3e 69 41 67 67 20 3d 20 69 3b  pExpr->iAgg = i;
71e0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
71f0: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
7200: 41 47 47 5f 46 55 4e 43 54 49 4f 4e 3a 20 7b 0a  AGG_FUNCTION: {.
7210: 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72 2d        if( pExpr-
7220: 3e 69 43 6f 6c 75 6d 6e 3d 3d 46 4e 5f 43 6f 75  >iColumn==FN_Cou
7230: 6e 74 20 7c 7c 20 70 45 78 70 72 2d 3e 69 43 6f  nt || pExpr->iCo
7240: 6c 75 6d 6e 3d 3d 46 4e 5f 41 76 67 20 29 7b 0a  lumn==FN_Avg ){.
7250: 20 20 20 20 20 20 20 20 69 66 28 20 70 50 61 72          if( pPar
7260: 73 65 2d 3e 69 41 67 67 43 6f 75 6e 74 3e 3d 30  se->iAggCount>=0
7270: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69 20   ){.          i 
7280: 3d 20 70 50 61 72 73 65 2d 3e 69 41 67 67 43 6f  = pParse->iAggCo
7290: 75 6e 74 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c  unt;.        }el
72a0: 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 69 20  se{.          i 
72b0: 3d 20 61 70 70 65 6e 64 41 67 67 49 6e 66 6f 28  = appendAggInfo(
72c0: 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20 20  pParse);.       
72d0: 20 20 20 69 66 28 20 69 3c 30 20 29 20 72 65 74     if( i<0 ) ret
72e0: 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 20 20 20  urn 1;.         
72f0: 20 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 69 5d   pParse->aAgg[i]
7300: 2e 69 73 41 67 67 20 3d 20 31 3b 0a 20 20 20 20  .isAgg = 1;.    
7310: 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 61 41        pParse->aA
7320: 67 67 5b 69 5d 2e 70 45 78 70 72 20 3d 20 30 3b  gg[i].pExpr = 0;
7330: 0a 20 20 20 20 20 20 20 20 20 20 70 50 61 72 73  .          pPars
7340: 65 2d 3e 69 41 67 67 43 6f 75 6e 74 20 3d 20 69  e->iAggCount = i
7350: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
7360: 20 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 69      if( pExpr->i
7370: 43 6f 6c 75 6d 6e 3d 3d 46 4e 5f 43 6f 75 6e 74  Column==FN_Count
7380: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 70 45   ){.          pE
7390: 78 70 72 2d 3e 69 41 67 67 20 3d 20 69 3b 0a 20  xpr->iAgg = i;. 
73a0: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
73b0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
73c0: 7d 0a 20 20 20 20 20 20 61 41 67 67 20 3d 20 70  }.      aAgg = p
73d0: 50 61 72 73 65 2d 3e 61 41 67 67 3b 0a 20 20 20  Parse->aAgg;.   
73e0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 50     for(i=0; i<pP
73f0: 61 72 73 65 2d 3e 6e 41 67 67 3b 20 69 2b 2b 29  arse->nAgg; i++)
7400: 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 21 61  {.        if( !a
7410: 41 67 67 5b 69 5d 2e 69 73 41 67 67 20 29 20 63  Agg[i].isAgg ) c
7420: 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20  ontinue;.       
7430: 20 69 66 28 20 73 71 6c 69 74 65 45 78 70 72 43   if( sqliteExprC
7440: 6f 6d 70 61 72 65 28 61 41 67 67 5b 69 5d 2e 70  ompare(aAgg[i].p
7450: 45 78 70 72 2c 20 70 45 78 70 72 29 20 29 7b 0a  Expr, pExpr) ){.
7460: 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b            break;
7470: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
7480: 20 7d 0a 20 20 20 20 20 20 69 66 28 20 69 3e 3d   }.      if( i>=
7490: 70 50 61 72 73 65 2d 3e 6e 41 67 67 20 29 7b 0a  pParse->nAgg ){.
74a0: 20 20 20 20 20 20 20 20 69 20 3d 20 61 70 70 65          i = appe
74b0: 6e 64 41 67 67 49 6e 66 6f 28 70 50 61 72 73 65  ndAggInfo(pParse
74c0: 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 69  );.        if( i
74d0: 3c 30 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20  <0 ) return 1;. 
74e0: 20 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 61         pParse->a
74f0: 41 67 67 5b 69 5d 2e 69 73 41 67 67 20 3d 20 31  Agg[i].isAgg = 1
7500: 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72 73 65  ;.        pParse
7510: 2d 3e 61 41 67 67 5b 69 5d 2e 70 45 78 70 72 20  ->aAgg[i].pExpr 
7520: 3d 20 70 45 78 70 72 3b 0a 20 20 20 20 20 20 7d  = pExpr;.      }
7530: 0a 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 41  .      pExpr->iA
7540: 67 67 20 3d 20 69 3b 0a 20 20 20 20 20 20 62 72  gg = i;.      br
7550: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 64  eak;.    }.    d
7560: 65 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20  efault: {.      
7570: 69 66 28 20 70 45 78 70 72 2d 3e 70 4c 65 66 74  if( pExpr->pLeft
7580: 20 29 7b 0a 20 20 20 20 20 20 20 20 6e 45 72 72   ){.        nErr
7590: 20 3d 20 73 71 6c 69 74 65 45 78 70 72 41 6e 61   = sqliteExprAna
75a0: 6c 79 7a 65 41 67 67 72 65 67 61 74 65 73 28 70  lyzeAggregates(p
75b0: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c  Parse, pExpr->pL
75c0: 65 66 74 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  eft);.      }.  
75d0: 20 20 20 20 69 66 28 20 6e 45 72 72 3d 3d 30 20      if( nErr==0 
75e0: 26 26 20 70 45 78 70 72 2d 3e 70 52 69 67 68 74  && pExpr->pRight
75f0: 20 29 7b 0a 20 20 20 20 20 20 20 20 6e 45 72 72   ){.        nErr
7600: 20 3d 20 73 71 6c 69 74 65 45 78 70 72 41 6e 61   = sqliteExprAna
7610: 6c 79 7a 65 41 67 67 72 65 67 61 74 65 73 28 70  lyzeAggregates(p
7620: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 52  Parse, pExpr->pR
7630: 69 67 68 74 29 3b 0a 20 20 20 20 20 20 7d 0a 20  ight);.      }. 
7640: 20 20 20 20 20 69 66 28 20 6e 45 72 72 3d 3d 30       if( nErr==0
7650: 20 26 26 20 70 45 78 70 72 2d 3e 70 4c 69 73 74   && pExpr->pList
7660: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20   ){.        int 
7670: 6e 20 3d 20 70 45 78 70 72 2d 3e 70 4c 69 73 74  n = pExpr->pList
7680: 2d 3e 6e 45 78 70 72 3b 0a 20 20 20 20 20 20 20  ->nExpr;.       
7690: 20 69 6e 74 20 69 3b 0a 20 20 20 20 20 20 20 20   int i;.        
76a0: 66 6f 72 28 69 3d 30 3b 20 6e 45 72 72 3d 3d 30  for(i=0; nErr==0
76b0: 20 26 26 20 69 3c 6e 3b 20 69 2b 2b 29 7b 0a 20   && i<n; i++){. 
76c0: 20 20 20 20 20 20 20 20 20 6e 45 72 72 20 3d 20           nErr = 
76d0: 73 71 6c 69 74 65 45 78 70 72 41 6e 61 6c 79 7a  sqliteExprAnalyz
76e0: 65 41 67 67 72 65 67 61 74 65 73 28 70 50 61 72  eAggregates(pPar
76f0: 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69 73 74  se, pExpr->pList
7700: 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 29 3b 0a 20  ->a[i].pExpr);. 
7710: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
7720: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
7730: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
7740: 20 6e 45 72 72 3b 0a 7d 0a                        nErr;.}.