/ Hex Artifact Content
Login

Artifact d2e226650738931c047c2562326ed05882af2330:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you give..**.***
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66  ******.** This f
0180: 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 53 51 4c  ile contains SQL
0190: 69 74 65 27 73 20 67 72 61 6d 6d 61 72 20 66 6f  ite's grammar fo
01a0: 72 20 53 51 4c 2e 20 20 50 72 6f 63 65 73 73 20  r SQL.  Process 
01b0: 74 68 69 73 20 66 69 6c 65 0a 2a 2a 20 75 73 69  this file.** usi
01c0: 6e 67 20 74 68 65 20 6c 65 6d 6f 6e 20 70 61 72  ng the lemon par
01d0: 73 65 72 20 67 65 6e 65 72 61 74 6f 72 20 74 6f  ser generator to
01e0: 20 67 65 6e 65 72 61 74 65 20 43 20 63 6f 64 65   generate C code
01f0: 20 74 68 61 74 20 72 75 6e 73 0a 2a 2a 20 74 68   that runs.** th
0200: 65 20 70 61 72 73 65 72 2e 20 20 4c 65 6d 6f 6e  e parser.  Lemon
0210: 20 77 69 6c 6c 20 61 6c 73 6f 20 67 65 6e 65 72   will also gener
0220: 61 74 65 20 61 20 68 65 61 64 65 72 20 66 69 6c  ate a header fil
0230: 65 20 63 6f 6e 74 61 69 6e 69 6e 67 0a 2a 2a 20  e containing.** 
0240: 6e 75 6d 65 72 69 63 20 63 6f 64 65 73 20 66 6f  numeric codes fo
0250: 72 20 61 6c 6c 20 6f 66 20 74 68 65 20 74 6f 6b  r all of the tok
0260: 65 6e 73 2e 0a 2a 2a 0a 2a 2a 20 40 28 23 29 20  ens..**.** @(#) 
0270: 24 49 64 3a 20 70 61 72 73 65 2e 79 2c 76 20 31  $Id: parse.y,v 1
0280: 2e 31 31 34 20 32 30 30 34 2f 30 35 2f 31 38 20  .114 2004/05/18 
0290: 31 30 3a 30 36 3a 32 35 20 64 61 6e 69 65 6c 6b  10:06:25 danielk
02a0: 31 39 37 37 20 45 78 70 20 24 0a 2a 2f 0a 25 74  1977 Exp $.*/.%t
02b0: 6f 6b 65 6e 5f 70 72 65 66 69 78 20 54 4b 5f 0a  oken_prefix TK_.
02c0: 25 74 6f 6b 65 6e 5f 74 79 70 65 20 7b 54 6f 6b  %token_type {Tok
02d0: 65 6e 7d 0a 25 64 65 66 61 75 6c 74 5f 74 79 70  en}.%default_typ
02e0: 65 20 7b 54 6f 6b 65 6e 7d 0a 25 65 78 74 72 61  e {Token}.%extra
02f0: 5f 61 72 67 75 6d 65 6e 74 20 7b 50 61 72 73 65  _argument {Parse
0300: 20 2a 70 50 61 72 73 65 7d 0a 25 73 79 6e 74 61   *pParse}.%synta
0310: 78 5f 65 72 72 6f 72 20 7b 0a 20 20 69 66 28 20  x_error {.  if( 
0320: 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 3d  pParse->zErrMsg=
0330: 3d 30 20 29 7b 0a 20 20 20 20 69 66 28 20 54 4f  =0 ){.    if( TO
0340: 4b 45 4e 2e 7a 5b 30 5d 20 29 7b 0a 20 20 20 20  KEN.z[0] ){.    
0350: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73    sqlite3ErrorMs
0360: 67 28 70 50 61 72 73 65 2c 20 22 6e 65 61 72 20  g(pParse, "near 
0370: 5c 22 25 54 5c 22 3a 20 73 79 6e 74 61 78 20 65  \"%T\": syntax e
0380: 72 72 6f 72 22 2c 20 26 54 4f 4b 45 4e 29 3b 0a  rror", &TOKEN);.
0390: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
03a0: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67   sqlite3ErrorMsg
03b0: 28 70 50 61 72 73 65 2c 20 22 69 6e 63 6f 6d 70  (pParse, "incomp
03c0: 6c 65 74 65 20 53 51 4c 20 73 74 61 74 65 6d 65  lete SQL stateme
03d0: 6e 74 22 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  nt");.    }.  }.
03e0: 7d 0a 25 6e 61 6d 65 20 73 71 6c 69 74 65 33 50  }.%name sqlite3P
03f0: 61 72 73 65 72 0a 25 69 6e 63 6c 75 64 65 20 7b  arser.%include {
0400: 0a 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74  .#include "sqlit
0410: 65 49 6e 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65  eInt.h".#include
0420: 20 22 70 61 72 73 65 2e 68 22 0a 0a 2f 2a 0a 2a   "parse.h"../*.*
0430: 2a 20 41 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66  * An instance of
0440: 20 74 68 69 73 20 73 74 72 75 63 74 75 72 65 20   this structure 
0450: 68 6f 6c 64 73 20 69 6e 66 6f 72 6d 61 74 69 6f  holds informatio
0460: 6e 20 61 62 6f 75 74 20 74 68 65 0a 2a 2a 20 4c  n about the.** L
0470: 49 4d 49 54 20 63 6c 61 75 73 65 20 6f 66 20 61  IMIT clause of a
0480: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
0490: 74 2e 0a 2a 2f 0a 73 74 72 75 63 74 20 4c 69 6d  t..*/.struct Lim
04a0: 69 74 56 61 6c 20 7b 0a 20 20 69 6e 74 20 6c 69  itVal {.  int li
04b0: 6d 69 74 3b 20 20 20 20 2f 2a 20 54 68 65 20 4c  mit;    /* The L
04c0: 49 4d 49 54 20 76 61 6c 75 65 2e 20 20 2d 31 20  IMIT value.  -1 
04d0: 69 66 20 74 68 65 72 65 20 69 73 20 6e 6f 20 6c  if there is no l
04e0: 69 6d 69 74 20 2a 2f 0a 20 20 69 6e 74 20 6f 66  imit */.  int of
04f0: 66 73 65 74 3b 20 20 20 2f 2a 20 54 68 65 20 4f  fset;   /* The O
0500: 46 46 53 45 54 2e 20 20 30 20 69 66 20 74 68 65  FFSET.  0 if the
0510: 72 65 20 69 73 20 6e 6f 6e 65 20 2a 2f 0a 7d 3b  re is none */.};
0520: 0a 0a 2f 2a 0a 2a 2a 20 41 6e 20 69 6e 73 74 61  ../*.** An insta
0530: 6e 63 65 20 6f 66 20 74 68 65 20 66 6f 6c 6c 6f  nce of the follo
0540: 77 69 6e 67 20 73 74 72 75 63 74 75 72 65 20 64  wing structure d
0550: 65 73 63 72 69 62 65 73 20 74 68 65 20 65 76 65  escribes the eve
0560: 6e 74 20 6f 66 20 61 0a 2a 2a 20 54 52 49 47 47  nt of a.** TRIGG
0570: 45 52 2e 20 20 22 61 22 20 69 73 20 74 68 65 20  ER.  "a" is the 
0580: 65 76 65 6e 74 20 74 79 70 65 2c 20 6f 6e 65 20  event type, one 
0590: 6f 66 20 54 4b 5f 55 50 44 41 54 45 2c 20 54 4b  of TK_UPDATE, TK
05a0: 5f 49 4e 53 45 52 54 2c 0a 2a 2a 20 54 4b 5f 44  _INSERT,.** TK_D
05b0: 45 4c 45 54 45 2c 20 6f 72 20 54 4b 5f 49 4e 53  ELETE, or TK_INS
05c0: 54 45 41 44 2e 20 20 49 66 20 74 68 65 20 65 76  TEAD.  If the ev
05d0: 65 6e 74 20 69 73 20 6f 66 20 74 68 65 20 66 6f  ent is of the fo
05e0: 72 6d 0a 2a 2a 0a 2a 2a 20 20 20 20 20 20 55 50  rm.**.**      UP
05f0: 44 41 54 45 20 4f 4e 20 28 61 2c 62 2c 63 29 0a  DATE ON (a,b,c).
0600: 2a 2a 0a 2a 2a 20 54 68 65 6e 20 74 68 65 20 22  **.** Then the "
0610: 62 22 20 49 64 4c 69 73 74 20 72 65 63 6f 72 64  b" IdList record
0620: 73 20 74 68 65 20 6c 69 73 74 20 22 61 2c 62 2c  s the list "a,b,
0630: 63 22 2e 0a 2a 2f 0a 73 74 72 75 63 74 20 54 72  c"..*/.struct Tr
0640: 69 67 45 76 65 6e 74 20 7b 20 69 6e 74 20 61 3b  igEvent { int a;
0650: 20 49 64 4c 69 73 74 20 2a 20 62 3b 20 7d 3b 0a   IdList * b; };.
0660: 0a 7d 20 2f 2f 20 65 6e 64 20 25 69 6e 63 6c 75  .} // end %inclu
0670: 64 65 0a 0a 2f 2f 20 54 68 65 73 65 20 61 72 65  de..// These are
0680: 20 65 78 74 72 61 20 74 6f 6b 65 6e 73 20 75 73   extra tokens us
0690: 65 64 20 62 79 20 74 68 65 20 6c 65 78 65 72 20  ed by the lexer 
06a0: 62 75 74 20 6e 65 76 65 72 20 73 65 65 6e 20 62  but never seen b
06b0: 79 20 74 68 65 0a 2f 2f 20 70 61 72 73 65 72 2e  y the.// parser.
06c0: 20 20 57 65 20 70 75 74 20 74 68 65 6d 20 69 6e    We put them in
06d0: 20 61 20 72 75 6c 65 20 73 6f 20 74 68 61 74 20   a rule so that 
06e0: 74 68 65 20 70 61 72 73 65 72 20 67 65 6e 65 72  the parser gener
06f0: 61 74 6f 72 20 77 69 6c 6c 0a 2f 2f 20 61 64 64  ator will.// add
0700: 20 74 68 65 6d 20 74 6f 20 74 68 65 20 70 61 72   them to the par
0710: 73 65 2e 68 20 6f 75 74 70 75 74 20 66 69 6c 65  se.h output file
0720: 2e 0a 2f 2f 0a 25 6e 6f 6e 61 73 73 6f 63 20 45  ..//.%nonassoc E
0730: 4e 44 5f 4f 46 5f 46 49 4c 45 20 49 4c 4c 45 47  ND_OF_FILE ILLEG
0740: 41 4c 20 53 50 41 43 45 20 55 4e 43 4c 4f 53 45  AL SPACE UNCLOSE
0750: 44 5f 53 54 52 49 4e 47 20 43 4f 4d 4d 45 4e 54  D_STRING COMMENT
0760: 20 46 55 4e 43 54 49 4f 4e 0a 20 20 20 20 20 20   FUNCTION.      
0770: 20 20 20 20 43 4f 4c 55 4d 4e 20 41 47 47 5f 46      COLUMN AGG_F
0780: 55 4e 43 54 49 4f 4e 2e 0a 0a 2f 2f 20 49 6e 70  UNCTION...// Inp
0790: 75 74 20 69 73 20 61 20 73 69 6e 67 6c 65 20 53  ut is a single S
07a0: 51 4c 20 63 6f 6d 6d 61 6e 64 0a 69 6e 70 75 74  QL command.input
07b0: 20 3a 3a 3d 20 63 6d 64 6c 69 73 74 2e 0a 63 6d   ::= cmdlist..cm
07c0: 64 6c 69 73 74 20 3a 3a 3d 20 63 6d 64 6c 69 73  dlist ::= cmdlis
07d0: 74 20 65 63 6d 64 2e 0a 63 6d 64 6c 69 73 74 20  t ecmd..cmdlist 
07e0: 3a 3a 3d 20 65 63 6d 64 2e 0a 65 63 6d 64 20 3a  ::= ecmd..ecmd :
07f0: 3a 3d 20 65 78 70 6c 61 69 6e 20 63 6d 64 78 20  := explain cmdx 
0800: 53 45 4d 49 2e 0a 65 63 6d 64 20 3a 3a 3d 20 53  SEMI..ecmd ::= S
0810: 45 4d 49 2e 0a 63 6d 64 78 20 3a 3a 3d 20 63 6d  EMI..cmdx ::= cm
0820: 64 2e 20 20 20 20 20 20 20 20 20 20 20 7b 20 73  d.           { s
0830: 71 6c 69 74 65 33 45 78 65 63 28 70 50 61 72 73  qlite3Exec(pPars
0840: 65 29 3b 20 7d 0a 65 78 70 6c 61 69 6e 20 3a 3a  e); }.explain ::
0850: 3d 20 45 58 50 4c 41 49 4e 2e 20 20 20 20 7b 20  = EXPLAIN.    { 
0860: 73 71 6c 69 74 65 33 42 65 67 69 6e 50 61 72 73  sqlite3BeginPars
0870: 65 28 70 50 61 72 73 65 2c 20 31 29 3b 20 7d 0a  e(pParse, 1); }.
0880: 65 78 70 6c 61 69 6e 20 3a 3a 3d 20 2e 20 20 20  explain ::= .   
0890: 20 20 20 20 20 20 20 20 7b 20 73 71 6c 69 74 65          { sqlite
08a0: 33 42 65 67 69 6e 50 61 72 73 65 28 70 50 61 72  3BeginParse(pPar
08b0: 73 65 2c 20 30 29 3b 20 7d 0a 0a 2f 2f 2f 2f 2f  se, 0); }../////
08c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08d0: 20 42 65 67 69 6e 20 61 6e 64 20 65 6e 64 20 74   Begin and end t
08e0: 72 61 6e 73 61 63 74 69 6f 6e 73 2e 20 2f 2f 2f  ransactions. ///
08f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0900: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 0a 63 6d  /////////.//..cm
0910: 64 20 3a 3a 3d 20 42 45 47 49 4e 20 74 72 61 6e  d ::= BEGIN tran
0920: 73 5f 6f 70 74 20 6f 6e 63 6f 6e 66 28 52 29 2e  s_opt onconf(R).
0930: 20 20 7b 73 71 6c 69 74 65 33 42 65 67 69 6e 54    {sqlite3BeginT
0940: 72 61 6e 73 61 63 74 69 6f 6e 28 70 50 61 72 73  ransaction(pPars
0950: 65 2c 52 29 3b 7d 0a 74 72 61 6e 73 5f 6f 70 74  e,R);}.trans_opt
0960: 20 3a 3a 3d 20 2e 0a 74 72 61 6e 73 5f 6f 70 74   ::= ..trans_opt
0970: 20 3a 3a 3d 20 54 52 41 4e 53 41 43 54 49 4f 4e   ::= TRANSACTION
0980: 2e 0a 74 72 61 6e 73 5f 6f 70 74 20 3a 3a 3d 20  ..trans_opt ::= 
0990: 54 52 41 4e 53 41 43 54 49 4f 4e 20 6e 6d 2e 0a  TRANSACTION nm..
09a0: 63 6d 64 20 3a 3a 3d 20 43 4f 4d 4d 49 54 20 74  cmd ::= COMMIT t
09b0: 72 61 6e 73 5f 6f 70 74 2e 20 20 20 20 20 20 7b  rans_opt.      {
09c0: 73 71 6c 69 74 65 33 43 6f 6d 6d 69 74 54 72 61  sqlite3CommitTra
09d0: 6e 73 61 63 74 69 6f 6e 28 70 50 61 72 73 65 29  nsaction(pParse)
09e0: 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 45 4e 44 20 74  ;}.cmd ::= END t
09f0: 72 61 6e 73 5f 6f 70 74 2e 20 20 20 20 20 20 20  rans_opt.       
0a00: 20 20 7b 73 71 6c 69 74 65 33 43 6f 6d 6d 69 74    {sqlite3Commit
0a10: 54 72 61 6e 73 61 63 74 69 6f 6e 28 70 50 61 72  Transaction(pPar
0a20: 73 65 29 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 52 4f  se);}.cmd ::= RO
0a30: 4c 4c 42 41 43 4b 20 74 72 61 6e 73 5f 6f 70 74  LLBACK trans_opt
0a40: 2e 20 20 20 20 7b 73 71 6c 69 74 65 33 52 6f 6c  .    {sqlite3Rol
0a50: 6c 62 61 63 6b 54 72 61 6e 73 61 63 74 69 6f 6e  lbackTransaction
0a60: 28 70 50 61 72 73 65 29 3b 7d 0a 0a 2f 2f 2f 2f  (pParse);}..////
0a70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a80: 2f 20 54 68 65 20 43 52 45 41 54 45 20 54 41 42  / The CREATE TAB
0a90: 4c 45 20 73 74 61 74 65 6d 65 6e 74 20 2f 2f 2f  LE statement ///
0aa0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ab0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64  /////////.//.cmd
0ac0: 20 3a 3a 3d 20 63 72 65 61 74 65 5f 74 61 62 6c   ::= create_tabl
0ad0: 65 20 63 72 65 61 74 65 5f 74 61 62 6c 65 5f 61  e create_table_a
0ae0: 72 67 73 2e 0a 63 72 65 61 74 65 5f 74 61 62 6c  rgs..create_tabl
0af0: 65 20 3a 3a 3d 20 43 52 45 41 54 45 28 58 29 20  e ::= CREATE(X) 
0b00: 74 65 6d 70 28 54 29 20 54 41 42 4c 45 20 6e 6d  temp(T) TABLE nm
0b10: 28 59 29 2e 20 7b 0a 20 20 20 73 71 6c 69 74 65  (Y). {.   sqlite
0b20: 33 53 74 61 72 74 54 61 62 6c 65 28 70 50 61 72  3StartTable(pPar
0b30: 73 65 2c 26 58 2c 26 59 2c 54 2c 30 29 3b 0a 7d  se,&X,&Y,T,0);.}
0b40: 0a 25 74 79 70 65 20 74 65 6d 70 20 7b 69 6e 74  .%type temp {int
0b50: 7d 0a 74 65 6d 70 28 41 29 20 3a 3a 3d 20 54 45  }.temp(A) ::= TE
0b60: 4d 50 2e 20 20 7b 41 20 3d 20 31 3b 7d 0a 74 65  MP.  {A = 1;}.te
0b70: 6d 70 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20  mp(A) ::= .     
0b80: 20 7b 41 20 3d 20 30 3b 7d 0a 63 72 65 61 74 65   {A = 0;}.create
0b90: 5f 74 61 62 6c 65 5f 61 72 67 73 20 3a 3a 3d 20  _table_args ::= 
0ba0: 4c 50 20 63 6f 6c 75 6d 6e 6c 69 73 74 20 63 6f  LP columnlist co
0bb0: 6e 73 6c 69 73 74 5f 6f 70 74 20 52 50 28 58 29  nslist_opt RP(X)
0bc0: 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33 45 6e 64  . {.  sqlite3End
0bd0: 54 61 62 6c 65 28 70 50 61 72 73 65 2c 26 58 2c  Table(pParse,&X,
0be0: 30 29 3b 0a 7d 0a 63 72 65 61 74 65 5f 74 61 62  0);.}.create_tab
0bf0: 6c 65 5f 61 72 67 73 20 3a 3a 3d 20 41 53 20 73  le_args ::= AS s
0c00: 65 6c 65 63 74 28 53 29 2e 20 7b 0a 20 20 73 71  elect(S). {.  sq
0c10: 6c 69 74 65 33 45 6e 64 54 61 62 6c 65 28 70 50  lite3EndTable(pP
0c20: 61 72 73 65 2c 30 2c 53 29 3b 0a 20 20 73 71 6c  arse,0,S);.  sql
0c30: 69 74 65 33 53 65 6c 65 63 74 44 65 6c 65 74 65  ite3SelectDelete
0c40: 28 53 29 3b 0a 7d 0a 63 6f 6c 75 6d 6e 6c 69 73  (S);.}.columnlis
0c50: 74 20 3a 3a 3d 20 63 6f 6c 75 6d 6e 6c 69 73 74  t ::= columnlist
0c60: 20 43 4f 4d 4d 41 20 63 6f 6c 75 6d 6e 2e 0a 63   COMMA column..c
0c70: 6f 6c 75 6d 6e 6c 69 73 74 20 3a 3a 3d 20 63 6f  olumnlist ::= co
0c80: 6c 75 6d 6e 2e 0a 0a 2f 2f 20 41 62 6f 75 74 20  lumn...// About 
0c90: 74 68 65 20 6f 6e 6c 79 20 69 6e 66 6f 72 6d 61  the only informa
0ca0: 74 69 6f 6e 20 75 73 65 64 20 66 6f 72 20 61 20  tion used for a 
0cb0: 63 6f 6c 75 6d 6e 20 69 73 20 74 68 65 20 6e 61  column is the na
0cc0: 6d 65 20 6f 66 20 74 68 65 0a 2f 2f 20 63 6f 6c  me of the.// col
0cd0: 75 6d 6e 2e 20 20 54 68 65 20 74 79 70 65 20 69  umn.  The type i
0ce0: 73 20 61 6c 77 61 79 73 20 6a 75 73 74 20 22 74  s always just "t
0cf0: 65 78 74 22 2e 20 20 42 75 74 20 74 68 65 20 63  ext".  But the c
0d00: 6f 64 65 20 77 69 6c 6c 20 61 63 63 65 70 74 0a  ode will accept.
0d10: 2f 2f 20 61 6e 20 65 6c 61 62 6f 72 61 74 65 20  // an elaborate 
0d20: 74 79 70 65 6e 61 6d 65 2e 20 20 50 65 72 68 61  typename.  Perha
0d30: 70 73 20 73 6f 6d 65 64 61 79 20 77 65 27 6c 6c  ps someday we'll
0d40: 20 64 6f 20 73 6f 6d 65 74 68 69 6e 67 20 77 69   do something wi
0d50: 74 68 20 69 74 2e 0a 2f 2f 0a 63 6f 6c 75 6d 6e  th it..//.column
0d60: 20 3a 3a 3d 20 63 6f 6c 75 6d 6e 69 64 20 74 79   ::= columnid ty
0d70: 70 65 20 63 61 72 67 6c 69 73 74 2e 20 0a 63 6f  pe carglist. .co
0d80: 6c 75 6d 6e 69 64 20 3a 3a 3d 20 6e 6d 28 58 29  lumnid ::= nm(X)
0d90: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0da0: 20 7b 73 71 6c 69 74 65 33 41 64 64 43 6f 6c 75   {sqlite3AddColu
0db0: 6d 6e 28 70 50 61 72 73 65 2c 26 58 29 3b 7d 0a  mn(pParse,&X);}.
0dc0: 0a 2f 2f 20 41 6e 20 49 44 45 4e 54 49 46 49 45  .// An IDENTIFIE
0dd0: 52 20 63 61 6e 20 62 65 20 61 20 67 65 6e 65 72  R can be a gener
0de0: 69 63 20 69 64 65 6e 74 69 66 69 65 72 2c 20 6f  ic identifier, o
0df0: 72 20 6f 6e 65 20 6f 66 20 73 65 76 65 72 61 6c  r one of several
0e00: 0a 2f 2f 20 6b 65 79 77 6f 72 64 73 2e 20 20 41  .// keywords.  A
0e10: 6e 79 20 6e 6f 6e 2d 73 74 61 6e 64 61 72 64 20  ny non-standard 
0e20: 6b 65 79 77 6f 72 64 20 63 61 6e 20 61 6c 73 6f  keyword can also
0e30: 20 62 65 20 61 6e 20 69 64 65 6e 74 69 66 69 65   be an identifie
0e40: 72 2e 0a 2f 2f 0a 25 74 79 70 65 20 69 64 20 7b  r..//.%type id {
0e50: 54 6f 6b 65 6e 7d 0a 69 64 28 41 29 20 3a 3a 3d  Token}.id(A) ::=
0e60: 20 49 44 28 58 29 2e 20 20 20 20 20 20 20 20 20   ID(X).         
0e70: 7b 41 20 3d 20 58 3b 7d 0a 0a 2f 2f 20 54 68 65  {A = X;}..// The
0e80: 20 66 6f 6c 6c 6f 77 69 6e 67 20 64 69 72 65 63   following direc
0e90: 74 69 76 65 20 63 61 75 73 65 73 20 74 6f 6b 65  tive causes toke
0ea0: 6e 73 20 41 42 4f 52 54 2c 20 41 46 54 45 52 2c  ns ABORT, AFTER,
0eb0: 20 41 53 43 2c 20 65 74 63 2e 20 74 6f 0a 2f 2f   ASC, etc. to.//
0ec0: 20 66 61 6c 6c 62 61 63 6b 20 74 6f 20 49 44 20   fallback to ID 
0ed0: 69 66 20 74 68 65 79 20 77 69 6c 6c 20 6e 6f 74  if they will not
0ee0: 20 70 61 72 73 65 20 61 73 20 74 68 65 69 72 20   parse as their 
0ef0: 6f 72 69 67 69 6e 61 6c 20 76 61 6c 75 65 2e 0a  original value..
0f00: 2f 2f 20 54 68 69 73 20 6f 62 76 69 61 74 65 73  // This obviates
0f10: 20 74 68 65 20 6e 65 65 64 20 66 6f 72 20 74 68   the need for th
0f20: 65 20 22 69 64 22 20 6e 6f 6e 74 65 72 6d 69 6e  e "id" nontermin
0f30: 61 6c 2e 0a 2f 2f 0a 25 66 61 6c 6c 62 61 63 6b  al..//.%fallback
0f40: 20 49 44 0a 20 20 41 42 4f 52 54 20 41 46 54 45   ID.  ABORT AFTE
0f50: 52 20 41 53 43 20 41 54 54 41 43 48 20 42 45 46  R ASC ATTACH BEF
0f60: 4f 52 45 20 42 45 47 49 4e 20 43 41 53 43 41 44  ORE BEGIN CASCAD
0f70: 45 20 43 4c 55 53 54 45 52 20 43 4f 4e 46 4c 49  E CLUSTER CONFLI
0f80: 43 54 0a 20 20 43 4f 50 59 20 44 41 54 41 42 41  CT.  COPY DATABA
0f90: 53 45 20 44 45 46 45 52 52 45 44 20 44 45 4c 49  SE DEFERRED DELI
0fa0: 4d 49 54 45 52 53 20 44 45 53 43 20 44 45 54 41  MITERS DESC DETA
0fb0: 43 48 20 45 41 43 48 20 45 4e 44 20 45 58 50 4c  CH EACH END EXPL
0fc0: 41 49 4e 20 46 41 49 4c 20 46 4f 52 0a 20 20 47  AIN FAIL FOR.  G
0fd0: 4c 4f 42 20 49 47 4e 4f 52 45 20 49 4d 4d 45 44  LOB IGNORE IMMED
0fe0: 49 41 54 45 20 49 4e 49 54 49 41 4c 4c 59 20 49  IATE INITIALLY I
0ff0: 4e 53 54 45 41 44 20 4c 49 4b 45 20 4d 41 54 43  NSTEAD LIKE MATC
1000: 48 20 4b 45 59 0a 20 20 4f 46 20 4f 46 46 53 45  H KEY.  OF OFFSE
1010: 54 20 50 52 41 47 4d 41 20 52 41 49 53 45 20 52  T PRAGMA RAISE R
1020: 45 50 4c 41 43 45 20 52 45 53 54 52 49 43 54 20  EPLACE RESTRICT 
1030: 52 4f 57 20 53 54 41 54 45 4d 45 4e 54 0a 20 20  ROW STATEMENT.  
1040: 54 45 4d 50 20 54 52 49 47 47 45 52 20 56 41 43  TEMP TRIGGER VAC
1050: 55 55 4d 20 56 49 45 57 2e 0a 0a 2f 2f 20 44 65  UUM VIEW...// De
1060: 66 69 6e 65 20 6f 70 65 72 61 74 6f 72 20 70 72  fine operator pr
1070: 65 63 65 64 65 6e 63 65 20 65 61 72 6c 79 20 73  ecedence early s
1080: 6f 20 74 68 61 74 20 74 68 69 73 20 69 73 20 74  o that this is t
1090: 68 65 20 66 69 72 73 74 20 6f 63 63 75 72 61 6e  he first occuran
10a0: 63 65 0a 2f 2f 20 6f 66 20 74 68 65 20 6f 70 65  ce.// of the ope
10b0: 72 61 74 6f 72 20 74 6f 6b 65 6e 73 20 69 6e 20  rator tokens in 
10c0: 74 68 65 20 67 72 61 6d 6d 65 72 2e 20 20 4b 65  the grammer.  Ke
10d0: 65 70 69 6e 67 20 74 68 65 20 6f 70 65 72 61 74  eping the operat
10e0: 6f 72 73 20 74 6f 67 65 74 68 65 72 0a 2f 2f 20  ors together.// 
10f0: 63 61 75 73 65 73 20 74 68 65 6d 20 74 6f 20 62  causes them to b
1100: 65 20 61 73 73 69 67 6e 65 64 20 69 6e 74 65 67  e assigned integ
1110: 65 72 20 76 61 6c 75 65 73 20 74 68 61 74 20 61  er values that a
1120: 72 65 20 63 6c 6f 73 65 20 74 6f 67 65 74 68 65  re close togethe
1130: 72 2c 0a 2f 2f 20 77 68 69 63 68 20 6b 65 65 70  r,.// which keep
1140: 73 20 70 61 72 73 65 72 20 74 61 62 6c 65 73 20  s parser tables 
1150: 73 6d 61 6c 6c 65 72 2e 0a 2f 2f 0a 25 6c 65 66  smaller..//.%lef
1160: 74 20 4f 52 2e 0a 25 6c 65 66 74 20 41 4e 44 2e  t OR..%left AND.
1170: 0a 25 72 69 67 68 74 20 4e 4f 54 2e 0a 25 6c 65  .%right NOT..%le
1180: 66 74 20 45 51 20 4e 45 20 49 53 4e 55 4c 4c 20  ft EQ NE ISNULL 
1190: 4e 4f 54 4e 55 4c 4c 20 49 53 20 4c 49 4b 45 20  NOTNULL IS LIKE 
11a0: 47 4c 4f 42 20 42 45 54 57 45 45 4e 20 49 4e 2e  GLOB BETWEEN IN.
11b0: 0a 25 6c 65 66 74 20 47 54 20 47 45 20 4c 54 20  .%left GT GE LT 
11c0: 4c 45 2e 0a 25 6c 65 66 74 20 42 49 54 41 4e 44  LE..%left BITAND
11d0: 20 42 49 54 4f 52 20 4c 53 48 49 46 54 20 52 53   BITOR LSHIFT RS
11e0: 48 49 46 54 2e 0a 25 6c 65 66 74 20 50 4c 55 53  HIFT..%left PLUS
11f0: 20 4d 49 4e 55 53 2e 0a 25 6c 65 66 74 20 53 54   MINUS..%left ST
1200: 41 52 20 53 4c 41 53 48 20 52 45 4d 2e 0a 25 6c  AR SLASH REM..%l
1210: 65 66 74 20 43 4f 4e 43 41 54 2e 0a 25 72 69 67  eft CONCAT..%rig
1220: 68 74 20 55 4d 49 4e 55 53 20 55 50 4c 55 53 20  ht UMINUS UPLUS 
1230: 42 49 54 4e 4f 54 2e 0a 0a 2f 2f 20 41 6e 64 20  BITNOT...// And 
1240: 22 69 64 73 22 20 69 73 20 61 6e 20 69 64 65 6e  "ids" is an iden
1250: 74 69 66 65 72 2d 6f 72 2d 73 74 72 69 6e 67 2e  tifer-or-string.
1260: 0a 2f 2f 0a 25 74 79 70 65 20 69 64 73 20 7b 54  .//.%type ids {T
1270: 6f 6b 65 6e 7d 0a 69 64 73 28 41 29 20 3a 3a 3d  oken}.ids(A) ::=
1280: 20 49 44 28 58 29 2e 20 20 20 20 20 20 20 20 7b   ID(X).        {
1290: 41 20 3d 20 58 3b 7d 0a 69 64 73 28 41 29 20 3a  A = X;}.ids(A) :
12a0: 3a 3d 20 53 54 52 49 4e 47 28 58 29 2e 20 20 20  := STRING(X).   
12b0: 20 7b 41 20 3d 20 58 3b 7d 0a 0a 2f 2f 20 54 68   {A = X;}..// Th
12c0: 65 20 6e 61 6d 65 20 6f 66 20 61 20 63 6f 6c 75  e name of a colu
12d0: 6d 6e 20 6f 72 20 74 61 62 6c 65 20 63 61 6e 20  mn or table can 
12e0: 62 65 20 61 6e 79 20 6f 66 20 74 68 65 20 66 6f  be any of the fo
12f0: 6c 6c 6f 77 69 6e 67 3a 0a 2f 2f 0a 25 74 79 70  llowing:.//.%typ
1300: 65 20 6e 6d 20 7b 54 6f 6b 65 6e 7d 0a 6e 6d 28  e nm {Token}.nm(
1310: 41 29 20 3a 3a 3d 20 49 44 28 58 29 2e 20 20 20  A) ::= ID(X).   
1320: 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 6e        {A = X;}.n
1330: 6d 28 41 29 20 3a 3a 3d 20 53 54 52 49 4e 47 28  m(A) ::= STRING(
1340: 58 29 2e 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d  X).     {A = X;}
1350: 0a 6e 6d 28 41 29 20 3a 3a 3d 20 4a 4f 49 4e 5f  .nm(A) ::= JOIN_
1360: 4b 57 28 58 29 2e 20 20 20 20 7b 41 20 3d 20 58  KW(X).    {A = X
1370: 3b 7d 0a 0a 74 79 70 65 20 3a 3a 3d 20 2e 0a 74  ;}..type ::= ..t
1380: 79 70 65 20 3a 3a 3d 20 74 79 70 65 6e 61 6d 65  ype ::= typename
1390: 28 58 29 2e 20 20 20 20 20 20 20 20 20 20 20 20  (X).            
13a0: 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33          {sqlite3
13b0: 41 64 64 43 6f 6c 75 6d 6e 54 79 70 65 28 70 50  AddColumnType(pP
13c0: 61 72 73 65 2c 26 58 2c 26 58 29 3b 7d 0a 74 79  arse,&X,&X);}.ty
13d0: 70 65 20 3a 3a 3d 20 74 79 70 65 6e 61 6d 65 28  pe ::= typename(
13e0: 58 29 20 4c 50 20 73 69 67 6e 65 64 20 52 50 28  X) LP signed RP(
13f0: 59 29 2e 20 20 20 20 7b 73 71 6c 69 74 65 33 41  Y).    {sqlite3A
1400: 64 64 43 6f 6c 75 6d 6e 54 79 70 65 28 70 50 61  ddColumnType(pPa
1410: 72 73 65 2c 26 58 2c 26 59 29 3b 7d 0a 74 79 70  rse,&X,&Y);}.typ
1420: 65 20 3a 3a 3d 20 74 79 70 65 6e 61 6d 65 28 58  e ::= typename(X
1430: 29 20 4c 50 20 73 69 67 6e 65 64 20 43 4f 4d 4d  ) LP signed COMM
1440: 41 20 73 69 67 6e 65 64 20 52 50 28 59 29 2e 0a  A signed RP(Y)..
1450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1460: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1470: 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65           {sqlite
1480: 33 41 64 64 43 6f 6c 75 6d 6e 54 79 70 65 28 70  3AddColumnType(p
1490: 50 61 72 73 65 2c 26 58 2c 26 59 29 3b 7d 0a 25  Parse,&X,&Y);}.%
14a0: 74 79 70 65 20 74 79 70 65 6e 61 6d 65 20 7b 54  type typename {T
14b0: 6f 6b 65 6e 7d 0a 74 79 70 65 6e 61 6d 65 28 41  oken}.typename(A
14c0: 29 20 3a 3a 3d 20 69 64 73 28 58 29 2e 20 20 20  ) ::= ids(X).   
14d0: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d          {A = X;}
14e0: 0a 74 79 70 65 6e 61 6d 65 28 41 29 20 3a 3a 3d  .typename(A) ::=
14f0: 20 74 79 70 65 6e 61 6d 65 28 58 29 20 69 64 73   typename(X) ids
1500: 2e 20 20 7b 41 20 3d 20 58 3b 7d 0a 25 74 79 70  .  {A = X;}.%typ
1510: 65 20 73 69 67 6e 65 64 20 7b 69 6e 74 7d 0a 73  e signed {int}.s
1520: 69 67 6e 65 64 28 41 29 20 3a 3a 3d 20 49 4e 54  igned(A) ::= INT
1530: 45 47 45 52 28 58 29 2e 20 20 20 20 20 20 20 20  EGER(X).        
1540: 20 7b 20 41 20 3d 20 61 74 6f 69 28 58 2e 7a 29   { A = atoi(X.z)
1550: 3b 20 7d 0a 73 69 67 6e 65 64 28 41 29 20 3a 3a  ; }.signed(A) ::
1560: 3d 20 50 4c 55 53 20 49 4e 54 45 47 45 52 28 58  = PLUS INTEGER(X
1570: 29 2e 20 20 20 20 7b 20 41 20 3d 20 61 74 6f 69  ).    { A = atoi
1580: 28 58 2e 7a 29 3b 20 7d 0a 73 69 67 6e 65 64 28  (X.z); }.signed(
1590: 41 29 20 3a 3a 3d 20 4d 49 4e 55 53 20 49 4e 54  A) ::= MINUS INT
15a0: 45 47 45 52 28 58 29 2e 20 20 20 7b 20 41 20 3d  EGER(X).   { A =
15b0: 20 2d 61 74 6f 69 28 58 2e 7a 29 3b 20 7d 0a 63   -atoi(X.z); }.c
15c0: 61 72 67 6c 69 73 74 20 3a 3a 3d 20 63 61 72 67  arglist ::= carg
15d0: 6c 69 73 74 20 63 61 72 67 2e 0a 63 61 72 67 6c  list carg..cargl
15e0: 69 73 74 20 3a 3a 3d 20 2e 0a 63 61 72 67 20 3a  ist ::= ..carg :
15f0: 3a 3d 20 43 4f 4e 53 54 52 41 49 4e 54 20 6e 6d  := CONSTRAINT nm
1600: 20 63 63 6f 6e 73 2e 0a 63 61 72 67 20 3a 3a 3d   ccons..carg ::=
1610: 20 63 63 6f 6e 73 2e 0a 63 61 72 67 20 3a 3a 3d   ccons..carg ::=
1620: 20 44 45 46 41 55 4c 54 20 53 54 52 49 4e 47 28   DEFAULT STRING(
1630: 58 29 2e 20 20 20 20 20 20 20 20 20 20 7b 73 71  X).          {sq
1640: 6c 69 74 65 33 41 64 64 44 65 66 61 75 6c 74 56  lite3AddDefaultV
1650: 61 6c 75 65 28 70 50 61 72 73 65 2c 26 58 2c 30  alue(pParse,&X,0
1660: 29 3b 7d 0a 63 61 72 67 20 3a 3a 3d 20 44 45 46  );}.carg ::= DEF
1670: 41 55 4c 54 20 49 44 28 58 29 2e 20 20 20 20 20  AULT ID(X).     
1680: 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65           {sqlite
1690: 33 41 64 64 44 65 66 61 75 6c 74 56 61 6c 75 65  3AddDefaultValue
16a0: 28 70 50 61 72 73 65 2c 26 58 2c 30 29 3b 7d 0a  (pParse,&X,0);}.
16b0: 63 61 72 67 20 3a 3a 3d 20 44 45 46 41 55 4c 54  carg ::= DEFAULT
16c0: 20 49 4e 54 45 47 45 52 28 58 29 2e 20 20 20 20   INTEGER(X).    
16d0: 20 20 20 20 20 7b 73 71 6c 69 74 65 33 41 64 64       {sqlite3Add
16e0: 44 65 66 61 75 6c 74 56 61 6c 75 65 28 70 50 61  DefaultValue(pPa
16f0: 72 73 65 2c 26 58 2c 30 29 3b 7d 0a 63 61 72 67  rse,&X,0);}.carg
1700: 20 3a 3a 3d 20 44 45 46 41 55 4c 54 20 50 4c 55   ::= DEFAULT PLU
1710: 53 20 49 4e 54 45 47 45 52 28 58 29 2e 20 20 20  S INTEGER(X).   
1720: 20 7b 73 71 6c 69 74 65 33 41 64 64 44 65 66 61   {sqlite3AddDefa
1730: 75 6c 74 56 61 6c 75 65 28 70 50 61 72 73 65 2c  ultValue(pParse,
1740: 26 58 2c 30 29 3b 7d 0a 63 61 72 67 20 3a 3a 3d  &X,0);}.carg ::=
1750: 20 44 45 46 41 55 4c 54 20 4d 49 4e 55 53 20 49   DEFAULT MINUS I
1760: 4e 54 45 47 45 52 28 58 29 2e 20 20 20 7b 73 71  NTEGER(X).   {sq
1770: 6c 69 74 65 33 41 64 64 44 65 66 61 75 6c 74 56  lite3AddDefaultV
1780: 61 6c 75 65 28 70 50 61 72 73 65 2c 26 58 2c 31  alue(pParse,&X,1
1790: 29 3b 7d 0a 63 61 72 67 20 3a 3a 3d 20 44 45 46  );}.carg ::= DEF
17a0: 41 55 4c 54 20 46 4c 4f 41 54 28 58 29 2e 20 20  AULT FLOAT(X).  
17b0: 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65           {sqlite
17c0: 33 41 64 64 44 65 66 61 75 6c 74 56 61 6c 75 65  3AddDefaultValue
17d0: 28 70 50 61 72 73 65 2c 26 58 2c 30 29 3b 7d 0a  (pParse,&X,0);}.
17e0: 63 61 72 67 20 3a 3a 3d 20 44 45 46 41 55 4c 54  carg ::= DEFAULT
17f0: 20 50 4c 55 53 20 46 4c 4f 41 54 28 58 29 2e 20   PLUS FLOAT(X). 
1800: 20 20 20 20 20 7b 73 71 6c 69 74 65 33 41 64 64       {sqlite3Add
1810: 44 65 66 61 75 6c 74 56 61 6c 75 65 28 70 50 61  DefaultValue(pPa
1820: 72 73 65 2c 26 58 2c 30 29 3b 7d 0a 63 61 72 67  rse,&X,0);}.carg
1830: 20 3a 3a 3d 20 44 45 46 41 55 4c 54 20 4d 49 4e   ::= DEFAULT MIN
1840: 55 53 20 46 4c 4f 41 54 28 58 29 2e 20 20 20 20  US FLOAT(X).    
1850: 20 7b 73 71 6c 69 74 65 33 41 64 64 44 65 66 61   {sqlite3AddDefa
1860: 75 6c 74 56 61 6c 75 65 28 70 50 61 72 73 65 2c  ultValue(pParse,
1870: 26 58 2c 31 29 3b 7d 0a 63 61 72 67 20 3a 3a 3d  &X,1);}.carg ::=
1880: 20 44 45 46 41 55 4c 54 20 4e 55 4c 4c 2e 20 0a   DEFAULT NULL. .
1890: 0a 2f 2f 20 49 6e 20 61 64 64 69 74 69 6f 6e 20  .// In addition 
18a0: 74 6f 20 74 68 65 20 74 79 70 65 20 6e 61 6d 65  to the type name
18b0: 2c 20 77 65 20 61 6c 73 6f 20 63 61 72 65 20 61  , we also care a
18c0: 62 6f 75 74 20 74 68 65 20 70 72 69 6d 61 72 79  bout the primary
18d0: 20 6b 65 79 20 61 6e 64 0a 2f 2f 20 55 4e 49 51   key and.// UNIQ
18e0: 55 45 20 63 6f 6e 73 74 72 61 69 6e 74 73 2e 0a  UE constraints..
18f0: 2f 2f 0a 63 63 6f 6e 73 20 3a 3a 3d 20 4e 55 4c  //.ccons ::= NUL
1900: 4c 20 6f 6e 63 6f 6e 66 2e 0a 63 63 6f 6e 73 20  L onconf..ccons 
1910: 3a 3a 3d 20 4e 4f 54 20 4e 55 4c 4c 20 6f 6e 63  ::= NOT NULL onc
1920: 6f 6e 66 28 52 29 2e 20 20 20 20 20 20 20 20 20  onf(R).         
1930: 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33 41 64        {sqlite3Ad
1940: 64 4e 6f 74 4e 75 6c 6c 28 70 50 61 72 73 65 2c  dNotNull(pParse,
1950: 20 52 29 3b 7d 0a 63 63 6f 6e 73 20 3a 3a 3d 20   R);}.ccons ::= 
1960: 50 52 49 4d 41 52 59 20 4b 45 59 20 73 6f 72 74  PRIMARY KEY sort
1970: 6f 72 64 65 72 20 6f 6e 63 6f 6e 66 28 52 29 2e  order onconf(R).
1980: 20 20 7b 73 71 6c 69 74 65 33 41 64 64 50 72 69    {sqlite3AddPri
1990: 6d 61 72 79 4b 65 79 28 70 50 61 72 73 65 2c 30  maryKey(pParse,0
19a0: 2c 52 29 3b 7d 0a 63 63 6f 6e 73 20 3a 3a 3d 20  ,R);}.ccons ::= 
19b0: 55 4e 49 51 55 45 20 6f 6e 63 6f 6e 66 28 52 29  UNIQUE onconf(R)
19c0: 2e 20 20 20 20 20 20 20 20 20 20 20 7b 73 71 6c  .           {sql
19d0: 69 74 65 33 43 72 65 61 74 65 49 6e 64 65 78 28  ite3CreateIndex(
19e0: 70 50 61 72 73 65 2c 30 2c 30 2c 30 2c 52 2c 30  pParse,0,0,0,R,0
19f0: 2c 30 29 3b 7d 0a 63 63 6f 6e 73 20 3a 3a 3d 20  ,0);}.ccons ::= 
1a00: 43 48 45 43 4b 20 4c 50 20 65 78 70 72 20 52 50  CHECK LP expr RP
1a10: 20 6f 6e 63 6f 6e 66 2e 0a 63 63 6f 6e 73 20 3a   onconf..ccons :
1a20: 3a 3d 20 52 45 46 45 52 45 4e 43 45 53 20 6e 6d  := REFERENCES nm
1a30: 28 54 29 20 69 64 78 6c 69 73 74 5f 6f 70 74 28  (T) idxlist_opt(
1a40: 54 41 29 20 72 65 66 61 72 67 73 28 52 29 2e 0a  TA) refargs(R)..
1a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a70: 7b 73 71 6c 69 74 65 33 43 72 65 61 74 65 46 6f  {sqlite3CreateFo
1a80: 72 65 69 67 6e 4b 65 79 28 70 50 61 72 73 65 2c  reignKey(pParse,
1a90: 30 2c 26 54 2c 54 41 2c 52 29 3b 7d 0a 63 63 6f  0,&T,TA,R);}.cco
1aa0: 6e 73 20 3a 3a 3d 20 64 65 66 65 72 5f 73 75 62  ns ::= defer_sub
1ab0: 63 6c 61 75 73 65 28 44 29 2e 20 20 20 7b 73 71  clause(D).   {sq
1ac0: 6c 69 74 65 33 44 65 66 65 72 46 6f 72 65 69 67  lite3DeferForeig
1ad0: 6e 4b 65 79 28 70 50 61 72 73 65 2c 44 29 3b 7d  nKey(pParse,D);}
1ae0: 0a 63 63 6f 6e 73 20 3a 3a 3d 20 43 4f 4c 4c 41  .ccons ::= COLLA
1af0: 54 45 20 69 64 28 43 29 2e 20 20 7b 0a 20 20 20  TE id(C).  {.   
1b00: 73 71 6c 69 74 65 33 41 64 64 43 6f 6c 6c 61 74  sqlite3AddCollat
1b10: 65 54 79 70 65 28 70 50 61 72 73 65 2c 20 73 71  eType(pParse, sq
1b20: 6c 69 74 65 33 43 6f 6c 6c 61 74 65 54 79 70 65  lite3CollateType
1b30: 28 43 2e 7a 2c 20 43 2e 6e 29 29 3b 0a 7d 0a 0a  (C.z, C.n));.}..
1b40: 2f 2f 20 54 68 65 20 6e 65 78 74 20 67 72 6f 75  // The next grou
1b50: 70 20 6f 66 20 72 75 6c 65 73 20 70 61 72 73 65  p of rules parse
1b60: 73 20 74 68 65 20 61 72 67 75 6d 65 6e 74 73 20  s the arguments 
1b70: 74 6f 20 61 20 52 45 46 45 52 45 4e 43 45 53 20  to a REFERENCES 
1b80: 63 6c 61 75 73 65 0a 2f 2f 20 74 68 61 74 20 64  clause.// that d
1b90: 65 74 65 72 6d 69 6e 65 20 69 66 20 74 68 65 20  etermine if the 
1ba0: 72 65 66 65 72 65 6e 74 69 61 6c 20 69 6e 74 65  referential inte
1bb0: 67 72 69 74 79 20 63 68 65 63 6b 69 6e 67 20 69  grity checking i
1bc0: 73 20 64 65 66 65 72 72 65 64 20 6f 72 0a 2f 2f  s deferred or.//
1bd0: 20 6f 72 20 69 6d 6d 65 64 69 61 74 65 20 61 6e   or immediate an
1be0: 64 20 77 68 69 63 68 20 64 65 74 65 72 6d 69 6e  d which determin
1bf0: 65 20 77 68 61 74 20 61 63 74 69 6f 6e 20 74 6f  e what action to
1c00: 20 74 61 6b 65 20 69 66 20 61 20 72 65 66 2d 69   take if a ref-i
1c10: 6e 74 65 67 0a 2f 2f 20 63 68 65 63 6b 20 66 61  nteg.// check fa
1c20: 69 6c 73 2e 0a 2f 2f 0a 25 74 79 70 65 20 72 65  ils..//.%type re
1c30: 66 61 72 67 73 20 7b 69 6e 74 7d 0a 72 65 66 61  fargs {int}.refa
1c40: 72 67 73 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20  rgs(A) ::= .    
1c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1c60: 20 7b 20 41 20 3d 20 4f 45 5f 52 65 73 74 72 69   { A = OE_Restri
1c70: 63 74 20 2a 20 30 78 30 31 30 31 30 31 3b 20 7d  ct * 0x010101; }
1c80: 0a 72 65 66 61 72 67 73 28 41 29 20 3a 3a 3d 20  .refargs(A) ::= 
1c90: 72 65 66 61 72 67 73 28 58 29 20 72 65 66 61 72  refargs(X) refar
1ca0: 67 28 59 29 2e 20 7b 20 41 20 3d 20 28 58 20 26  g(Y). { A = (X &
1cb0: 20 59 2e 6d 61 73 6b 29 20 7c 20 59 2e 76 61 6c   Y.mask) | Y.val
1cc0: 75 65 3b 20 7d 0a 25 74 79 70 65 20 72 65 66 61  ue; }.%type refa
1cd0: 72 67 20 7b 73 74 72 75 63 74 20 7b 69 6e 74 20  rg {struct {int 
1ce0: 76 61 6c 75 65 3b 20 69 6e 74 20 6d 61 73 6b 3b  value; int mask;
1cf0: 7d 7d 0a 72 65 66 61 72 67 28 41 29 20 3a 3a 3d  }}.refarg(A) ::=
1d00: 20 4d 41 54 43 48 20 6e 6d 2e 20 20 20 20 20 20   MATCH nm.      
1d10: 20 20 20 20 20 20 20 20 7b 20 41 2e 76 61 6c 75          { A.valu
1d20: 65 20 3d 20 30 3b 20 20 20 20 20 41 2e 6d 61 73  e = 0;     A.mas
1d30: 6b 20 3d 20 30 78 30 30 30 30 30 30 3b 20 7d 0a  k = 0x000000; }.
1d40: 72 65 66 61 72 67 28 41 29 20 3a 3a 3d 20 4f 4e  refarg(A) ::= ON
1d50: 20 44 45 4c 45 54 45 20 72 65 66 61 63 74 28 58   DELETE refact(X
1d60: 29 2e 20 20 20 7b 20 41 2e 76 61 6c 75 65 20 3d  ).   { A.value =
1d70: 20 58 3b 20 20 20 20 20 41 2e 6d 61 73 6b 20 3d   X;     A.mask =
1d80: 20 30 78 30 30 30 30 66 66 3b 20 7d 0a 72 65 66   0x0000ff; }.ref
1d90: 61 72 67 28 41 29 20 3a 3a 3d 20 4f 4e 20 55 50  arg(A) ::= ON UP
1da0: 44 41 54 45 20 72 65 66 61 63 74 28 58 29 2e 20  DATE refact(X). 
1db0: 20 20 7b 20 41 2e 76 61 6c 75 65 20 3d 20 58 3c    { A.value = X<
1dc0: 3c 38 3b 20 20 41 2e 6d 61 73 6b 20 3d 20 30 78  <8;  A.mask = 0x
1dd0: 30 30 66 66 30 30 3b 20 7d 0a 72 65 66 61 72 67  00ff00; }.refarg
1de0: 28 41 29 20 3a 3a 3d 20 4f 4e 20 49 4e 53 45 52  (A) ::= ON INSER
1df0: 54 20 72 65 66 61 63 74 28 58 29 2e 20 20 20 7b  T refact(X).   {
1e00: 20 41 2e 76 61 6c 75 65 20 3d 20 58 3c 3c 31 36   A.value = X<<16
1e10: 3b 20 41 2e 6d 61 73 6b 20 3d 20 30 78 66 66 30  ; A.mask = 0xff0
1e20: 30 30 30 3b 20 7d 0a 25 74 79 70 65 20 72 65 66  000; }.%type ref
1e30: 61 63 74 20 7b 69 6e 74 7d 0a 72 65 66 61 63 74  act {int}.refact
1e40: 28 41 29 20 3a 3a 3d 20 53 45 54 20 4e 55 4c 4c  (A) ::= SET NULL
1e50: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  .              {
1e60: 20 41 20 3d 20 4f 45 5f 53 65 74 4e 75 6c 6c 3b   A = OE_SetNull;
1e70: 20 7d 0a 72 65 66 61 63 74 28 41 29 20 3a 3a 3d   }.refact(A) ::=
1e80: 20 53 45 54 20 44 45 46 41 55 4c 54 2e 20 20 20   SET DEFAULT.   
1e90: 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20 4f 45          { A = OE
1ea0: 5f 53 65 74 44 66 6c 74 3b 20 7d 0a 72 65 66 61  _SetDflt; }.refa
1eb0: 63 74 28 41 29 20 3a 3a 3d 20 43 41 53 43 41 44  ct(A) ::= CASCAD
1ec0: 45 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  E.              
1ed0: 20 7b 20 41 20 3d 20 4f 45 5f 43 61 73 63 61 64   { A = OE_Cascad
1ee0: 65 3b 20 7d 0a 72 65 66 61 63 74 28 41 29 20 3a  e; }.refact(A) :
1ef0: 3a 3d 20 52 45 53 54 52 49 43 54 2e 20 20 20 20  := RESTRICT.    
1f00: 20 20 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20            { A = 
1f10: 4f 45 5f 52 65 73 74 72 69 63 74 3b 20 7d 0a 25  OE_Restrict; }.%
1f20: 74 79 70 65 20 64 65 66 65 72 5f 73 75 62 63 6c  type defer_subcl
1f30: 61 75 73 65 20 7b 69 6e 74 7d 0a 64 65 66 65 72  ause {int}.defer
1f40: 5f 73 75 62 63 6c 61 75 73 65 28 41 29 20 3a 3a  _subclause(A) ::
1f50: 3d 20 4e 4f 54 20 44 45 46 45 52 52 41 42 4c 45  = NOT DEFERRABLE
1f60: 20 69 6e 69 74 5f 64 65 66 65 72 72 65 64 5f 70   init_deferred_p
1f70: 72 65 64 5f 6f 70 74 28 58 29 2e 20 20 7b 41 20  red_opt(X).  {A 
1f80: 3d 20 58 3b 7d 0a 64 65 66 65 72 5f 73 75 62 63  = X;}.defer_subc
1f90: 6c 61 75 73 65 28 41 29 20 3a 3a 3d 20 44 45 46  lause(A) ::= DEF
1fa0: 45 52 52 41 42 4c 45 20 69 6e 69 74 5f 64 65 66  ERRABLE init_def
1fb0: 65 72 72 65 64 5f 70 72 65 64 5f 6f 70 74 28 58  erred_pred_opt(X
1fc0: 29 2e 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d  ).      {A = X;}
1fd0: 0a 25 74 79 70 65 20 69 6e 69 74 5f 64 65 66 65  .%type init_defe
1fe0: 72 72 65 64 5f 70 72 65 64 5f 6f 70 74 20 7b 69  rred_pred_opt {i
1ff0: 6e 74 7d 0a 69 6e 69 74 5f 64 65 66 65 72 72 65  nt}.init_deferre
2000: 64 5f 70 72 65 64 5f 6f 70 74 28 41 29 20 3a 3a  d_pred_opt(A) ::
2010: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
2020: 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30            {A = 0
2030: 3b 7d 0a 69 6e 69 74 5f 64 65 66 65 72 72 65 64  ;}.init_deferred
2040: 5f 70 72 65 64 5f 6f 70 74 28 41 29 20 3a 3a 3d  _pred_opt(A) ::=
2050: 20 49 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52   INITIALLY DEFER
2060: 52 45 44 2e 20 20 20 20 20 7b 41 20 3d 20 31 3b  RED.     {A = 1;
2070: 7d 0a 69 6e 69 74 5f 64 65 66 65 72 72 65 64 5f  }.init_deferred_
2080: 70 72 65 64 5f 6f 70 74 28 41 29 20 3a 3a 3d 20  pred_opt(A) ::= 
2090: 49 4e 49 54 49 41 4c 4c 59 20 49 4d 4d 45 44 49  INITIALLY IMMEDI
20a0: 41 54 45 2e 20 20 20 20 7b 41 20 3d 20 30 3b 7d  ATE.    {A = 0;}
20b0: 0a 0a 2f 2f 20 46 6f 72 20 74 68 65 20 74 69 6d  ..// For the tim
20c0: 65 20 62 65 69 6e 67 2c 20 74 68 65 20 6f 6e 6c  e being, the onl
20d0: 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 77 65 20  y constraint we 
20e0: 63 61 72 65 20 61 62 6f 75 74 20 69 73 20 74 68  care about is th
20f0: 65 20 70 72 69 6d 61 72 79 0a 2f 2f 20 6b 65 79  e primary.// key
2100: 20 61 6e 64 20 55 4e 49 51 55 45 2e 20 20 42 6f   and UNIQUE.  Bo
2110: 74 68 20 63 72 65 61 74 65 20 69 6e 64 69 63 65  th create indice
2120: 73 2e 0a 2f 2f 0a 63 6f 6e 73 6c 69 73 74 5f 6f  s..//.conslist_o
2130: 70 74 20 3a 3a 3d 20 2e 0a 63 6f 6e 73 6c 69 73  pt ::= ..conslis
2140: 74 5f 6f 70 74 20 3a 3a 3d 20 43 4f 4d 4d 41 20  t_opt ::= COMMA 
2150: 63 6f 6e 73 6c 69 73 74 2e 0a 63 6f 6e 73 6c 69  conslist..consli
2160: 73 74 20 3a 3a 3d 20 63 6f 6e 73 6c 69 73 74 20  st ::= conslist 
2170: 43 4f 4d 4d 41 20 74 63 6f 6e 73 2e 0a 63 6f 6e  COMMA tcons..con
2180: 73 6c 69 73 74 20 3a 3a 3d 20 63 6f 6e 73 6c 69  slist ::= consli
2190: 73 74 20 74 63 6f 6e 73 2e 0a 63 6f 6e 73 6c 69  st tcons..consli
21a0: 73 74 20 3a 3a 3d 20 74 63 6f 6e 73 2e 0a 74 63  st ::= tcons..tc
21b0: 6f 6e 73 20 3a 3a 3d 20 43 4f 4e 53 54 52 41 49  ons ::= CONSTRAI
21c0: 4e 54 20 6e 6d 2e 0a 74 63 6f 6e 73 20 3a 3a 3d  NT nm..tcons ::=
21d0: 20 50 52 49 4d 41 52 59 20 4b 45 59 20 4c 50 20   PRIMARY KEY LP 
21e0: 69 64 78 6c 69 73 74 28 58 29 20 52 50 20 6f 6e  idxlist(X) RP on
21f0: 63 6f 6e 66 28 52 29 2e 0a 20 20 20 20 20 20 20  conf(R)..       
2200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2220: 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33 41 64        {sqlite3Ad
2230: 64 50 72 69 6d 61 72 79 4b 65 79 28 70 50 61 72  dPrimaryKey(pPar
2240: 73 65 2c 58 2c 52 29 3b 7d 0a 74 63 6f 6e 73 20  se,X,R);}.tcons 
2250: 3a 3a 3d 20 55 4e 49 51 55 45 20 4c 50 20 69 64  ::= UNIQUE LP id
2260: 78 6c 69 73 74 28 58 29 20 52 50 20 6f 6e 63 6f  xlist(X) RP onco
2270: 6e 66 28 52 29 2e 0a 20 20 20 20 20 20 20 20 20  nf(R)..         
2280: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2290: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 73                {s
22a0: 71 6c 69 74 65 33 43 72 65 61 74 65 49 6e 64 65  qlite3CreateInde
22b0: 78 28 70 50 61 72 73 65 2c 30 2c 30 2c 58 2c 52  x(pParse,0,0,X,R
22c0: 2c 30 2c 30 29 3b 7d 0a 74 63 6f 6e 73 20 3a 3a  ,0,0);}.tcons ::
22d0: 3d 20 43 48 45 43 4b 20 65 78 70 72 20 6f 6e 63  = CHECK expr onc
22e0: 6f 6e 66 2e 0a 74 63 6f 6e 73 20 3a 3a 3d 20 46  onf..tcons ::= F
22f0: 4f 52 45 49 47 4e 20 4b 45 59 20 4c 50 20 69 64  OREIGN KEY LP id
2300: 78 6c 69 73 74 28 46 41 29 20 52 50 0a 20 20 20  xlist(FA) RP.   
2310: 20 20 20 20 20 20 20 52 45 46 45 52 45 4e 43 45         REFERENCE
2320: 53 20 6e 6d 28 54 29 20 69 64 78 6c 69 73 74 5f  S nm(T) idxlist_
2330: 6f 70 74 28 54 41 29 20 72 65 66 61 72 67 73 28  opt(TA) refargs(
2340: 52 29 20 64 65 66 65 72 5f 73 75 62 63 6c 61 75  R) defer_subclau
2350: 73 65 5f 6f 70 74 28 44 29 2e 20 7b 0a 20 20 20  se_opt(D). {.   
2360: 20 73 71 6c 69 74 65 33 43 72 65 61 74 65 46 6f   sqlite3CreateFo
2370: 72 65 69 67 6e 4b 65 79 28 70 50 61 72 73 65 2c  reignKey(pParse,
2380: 20 46 41 2c 20 26 54 2c 20 54 41 2c 20 52 29 3b   FA, &T, TA, R);
2390: 0a 20 20 20 20 73 71 6c 69 74 65 33 44 65 66 65  .    sqlite3Defe
23a0: 72 46 6f 72 65 69 67 6e 4b 65 79 28 70 50 61 72  rForeignKey(pPar
23b0: 73 65 2c 20 44 29 3b 0a 7d 0a 25 74 79 70 65 20  se, D);.}.%type 
23c0: 64 65 66 65 72 5f 73 75 62 63 6c 61 75 73 65 5f  defer_subclause_
23d0: 6f 70 74 20 7b 69 6e 74 7d 0a 64 65 66 65 72 5f  opt {int}.defer_
23e0: 73 75 62 63 6c 61 75 73 65 5f 6f 70 74 28 41 29  subclause_opt(A)
23f0: 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20   ::= .          
2400: 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30            {A = 0
2410: 3b 7d 0a 64 65 66 65 72 5f 73 75 62 63 6c 61 75  ;}.defer_subclau
2420: 73 65 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 64 65  se_opt(A) ::= de
2430: 66 65 72 5f 73 75 62 63 6c 61 75 73 65 28 58 29  fer_subclause(X)
2440: 2e 20 20 7b 41 20 3d 20 58 3b 7d 0a 0a 2f 2f 20  .  {A = X;}..// 
2450: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 69 73  The following is
2460: 20 61 20 6e 6f 6e 2d 73 74 61 6e 64 61 72 64 20   a non-standard 
2470: 65 78 74 65 6e 73 69 6f 6e 20 74 68 61 74 20 61  extension that a
2480: 6c 6c 6f 77 73 20 75 73 20 74 6f 20 64 65 63 6c  llows us to decl
2490: 61 72 65 20 74 68 65 0a 2f 2f 20 64 65 66 61 75  are the.// defau
24a0: 6c 74 20 62 65 68 61 76 69 6f 72 20 77 68 65 6e  lt behavior when
24b0: 20 74 68 65 72 65 20 69 73 20 61 20 63 6f 6e 73   there is a cons
24c0: 74 72 61 69 6e 74 20 63 6f 6e 66 6c 69 63 74 2e  traint conflict.
24d0: 0a 2f 2f 0a 25 74 79 70 65 20 6f 6e 63 6f 6e 66  .//.%type onconf
24e0: 20 7b 69 6e 74 7d 0a 25 74 79 70 65 20 6f 72 63   {int}.%type orc
24f0: 6f 6e 66 20 7b 69 6e 74 7d 0a 25 74 79 70 65 20  onf {int}.%type 
2500: 72 65 73 6f 6c 76 65 74 79 70 65 20 7b 69 6e 74  resolvetype {int
2510: 7d 0a 6f 6e 63 6f 6e 66 28 41 29 20 3a 3a 3d 20  }.onconf(A) ::= 
2520: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
2540: 20 41 20 3d 20 4f 45 5f 44 65 66 61 75 6c 74 3b   A = OE_Default;
2550: 20 7d 0a 6f 6e 63 6f 6e 66 28 41 29 20 3a 3a 3d   }.onconf(A) ::=
2560: 20 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 72 65 73   ON CONFLICT res
2570: 6f 6c 76 65 74 79 70 65 28 58 29 2e 20 20 20 20  olvetype(X).    
2580: 7b 20 41 20 3d 20 58 3b 20 7d 0a 6f 72 63 6f 6e  { A = X; }.orcon
2590: 66 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20  f(A) ::= .      
25a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
25b0: 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20 4f 45          { A = OE
25c0: 5f 44 65 66 61 75 6c 74 3b 20 7d 0a 6f 72 63 6f  _Default; }.orco
25d0: 6e 66 28 41 29 20 3a 3a 3d 20 4f 52 20 72 65 73  nf(A) ::= OR res
25e0: 6f 6c 76 65 74 79 70 65 28 58 29 2e 20 20 20 20  olvetype(X).    
25f0: 20 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20 58           { A = X
2600: 3b 20 7d 0a 72 65 73 6f 6c 76 65 74 79 70 65 28  ; }.resolvetype(
2610: 41 29 20 3a 3a 3d 20 52 4f 4c 4c 42 41 43 4b 2e  A) ::= ROLLBACK.
2620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2630: 20 7b 20 41 20 3d 20 4f 45 5f 52 6f 6c 6c 62 61   { A = OE_Rollba
2640: 63 6b 3b 20 7d 0a 72 65 73 6f 6c 76 65 74 79 70  ck; }.resolvetyp
2650: 65 28 41 29 20 3a 3a 3d 20 41 42 4f 52 54 2e 20  e(A) ::= ABORT. 
2660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2670: 20 20 20 7b 20 41 20 3d 20 4f 45 5f 41 62 6f 72     { A = OE_Abor
2680: 74 3b 20 7d 0a 72 65 73 6f 6c 76 65 74 79 70 65  t; }.resolvetype
2690: 28 41 29 20 3a 3a 3d 20 46 41 49 4c 2e 20 20 20  (A) ::= FAIL.   
26a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
26b0: 20 20 7b 20 41 20 3d 20 4f 45 5f 46 61 69 6c 3b    { A = OE_Fail;
26c0: 20 7d 0a 72 65 73 6f 6c 76 65 74 79 70 65 28 41   }.resolvetype(A
26d0: 29 20 3a 3a 3d 20 49 47 4e 4f 52 45 2e 20 20 20  ) ::= IGNORE.   
26e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
26f0: 7b 20 41 20 3d 20 4f 45 5f 49 67 6e 6f 72 65 3b  { A = OE_Ignore;
2700: 20 7d 0a 72 65 73 6f 6c 76 65 74 79 70 65 28 41   }.resolvetype(A
2710: 29 20 3a 3a 3d 20 52 45 50 4c 41 43 45 2e 20 20  ) ::= REPLACE.  
2720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2730: 7b 20 41 20 3d 20 4f 45 5f 52 65 70 6c 61 63 65  { A = OE_Replace
2740: 3b 20 7d 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ; }..///////////
2750: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20  /////////////// 
2760: 54 68 65 20 44 52 4f 50 20 54 41 42 4c 45 20 2f  The DROP TABLE /
2770: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
2780: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
2790: 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d 20  ////.//.cmd ::= 
27a0: 44 52 4f 50 20 54 41 42 4c 45 20 6e 6d 28 58 29  DROP TABLE nm(X)
27b0: 2e 20 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69  .          {sqli
27c0: 74 65 33 44 72 6f 70 54 61 62 6c 65 28 70 50 61  te3DropTable(pPa
27d0: 72 73 65 2c 26 58 2c 30 29 3b 7d 0a 0a 2f 2f 2f  rse,&X,0);}..///
27e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
27f0: 2f 2f 20 54 68 65 20 43 52 45 41 54 45 20 56 49  // The CREATE VI
2800: 45 57 20 73 74 61 74 65 6d 65 6e 74 20 2f 2f 2f  EW statement ///
2810: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
2820: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 63 6d  //////////.//.cm
2830: 64 20 3a 3a 3d 20 43 52 45 41 54 45 28 58 29 20  d ::= CREATE(X) 
2840: 74 65 6d 70 28 54 29 20 56 49 45 57 20 6e 6d 28  temp(T) VIEW nm(
2850: 59 29 20 41 53 20 73 65 6c 65 63 74 28 53 29 2e  Y) AS select(S).
2860: 20 7b 0a 20 20 73 71 6c 69 74 65 33 43 72 65 61   {.  sqlite3Crea
2870: 74 65 56 69 65 77 28 70 50 61 72 73 65 2c 20 26  teView(pParse, &
2880: 58 2c 20 26 59 2c 20 53 2c 20 54 29 3b 0a 7d 0a  X, &Y, S, T);.}.
2890: 63 6d 64 20 3a 3a 3d 20 44 52 4f 50 20 56 49 45  cmd ::= DROP VIE
28a0: 57 20 6e 6d 28 58 29 2e 20 7b 0a 20 20 73 71 6c  W nm(X). {.  sql
28b0: 69 74 65 33 44 72 6f 70 54 61 62 6c 65 28 70 50  ite3DropTable(pP
28c0: 61 72 73 65 2c 20 26 58 2c 20 31 29 3b 0a 7d 0a  arse, &X, 1);.}.
28d0: 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .///////////////
28e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20 53 45  ///////// The SE
28f0: 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 20 2f  LECT statement /
2900: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
2910: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
2920: 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d 20 73 65 6c 65  .//.cmd ::= sele
2930: 63 74 28 58 29 2e 20 20 7b 0a 20 20 73 71 6c 69  ct(X).  {.  sqli
2940: 74 65 33 53 65 6c 65 63 74 28 70 50 61 72 73 65  te3Select(pParse
2950: 2c 20 58 2c 20 53 52 54 5f 43 61 6c 6c 62 61 63  , X, SRT_Callbac
2960: 6b 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30  k, 0, 0, 0, 0, 0
2970: 29 3b 0a 20 20 73 71 6c 69 74 65 33 53 65 6c 65  );.  sqlite3Sele
2980: 63 74 44 65 6c 65 74 65 28 58 29 3b 0a 7d 0a 0a  ctDelete(X);.}..
2990: 25 74 79 70 65 20 73 65 6c 65 63 74 20 7b 53 65  %type select {Se
29a0: 6c 65 63 74 2a 7d 0a 25 64 65 73 74 72 75 63 74  lect*}.%destruct
29b0: 6f 72 20 73 65 6c 65 63 74 20 7b 73 71 6c 69 74  or select {sqlit
29c0: 65 33 53 65 6c 65 63 74 44 65 6c 65 74 65 28 24  e3SelectDelete($
29d0: 24 29 3b 7d 0a 25 74 79 70 65 20 6f 6e 65 73 65  $);}.%type onese
29e0: 6c 65 63 74 20 7b 53 65 6c 65 63 74 2a 7d 0a 25  lect {Select*}.%
29f0: 64 65 73 74 72 75 63 74 6f 72 20 6f 6e 65 73 65  destructor onese
2a00: 6c 65 63 74 20 7b 73 71 6c 69 74 65 33 53 65 6c  lect {sqlite3Sel
2a10: 65 63 74 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a  ectDelete($$);}.
2a20: 0a 73 65 6c 65 63 74 28 41 29 20 3a 3a 3d 20 6f  .select(A) ::= o
2a30: 6e 65 73 65 6c 65 63 74 28 58 29 2e 20 20 20 20  neselect(X).    
2a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2a50: 20 20 7b 41 20 3d 20 58 3b 7d 0a 73 65 6c 65 63    {A = X;}.selec
2a60: 74 28 41 29 20 3a 3a 3d 20 73 65 6c 65 63 74 28  t(A) ::= select(
2a70: 58 29 20 6d 75 6c 74 69 73 65 6c 65 63 74 5f 6f  X) multiselect_o
2a80: 70 28 59 29 20 6f 6e 65 73 65 6c 65 63 74 28 5a  p(Y) oneselect(Z
2a90: 29 2e 20 20 7b 0a 20 20 69 66 28 20 5a 20 29 7b  ).  {.  if( Z ){
2aa0: 0a 20 20 20 20 5a 2d 3e 6f 70 20 3d 20 59 3b 0a  .    Z->op = Y;.
2ab0: 20 20 20 20 5a 2d 3e 70 50 72 69 6f 72 20 3d 20      Z->pPrior = 
2ac0: 58 3b 0a 20 20 7d 0a 20 20 41 20 3d 20 5a 3b 0a  X;.  }.  A = Z;.
2ad0: 7d 0a 25 74 79 70 65 20 6d 75 6c 74 69 73 65 6c  }.%type multisel
2ae0: 65 63 74 5f 6f 70 20 7b 69 6e 74 7d 0a 6d 75 6c  ect_op {int}.mul
2af0: 74 69 73 65 6c 65 63 74 5f 6f 70 28 41 29 20 3a  tiselect_op(A) :
2b00: 3a 3d 20 55 4e 49 4f 4e 2e 20 20 20 20 20 20 7b  := UNION.      {
2b10: 41 20 3d 20 54 4b 5f 55 4e 49 4f 4e 3b 7d 0a 6d  A = TK_UNION;}.m
2b20: 75 6c 74 69 73 65 6c 65 63 74 5f 6f 70 28 41 29  ultiselect_op(A)
2b30: 20 3a 3a 3d 20 55 4e 49 4f 4e 20 41 4c 4c 2e 20   ::= UNION ALL. 
2b40: 20 7b 41 20 3d 20 54 4b 5f 41 4c 4c 3b 7d 0a 6d   {A = TK_ALL;}.m
2b50: 75 6c 74 69 73 65 6c 65 63 74 5f 6f 70 28 41 29  ultiselect_op(A)
2b60: 20 3a 3a 3d 20 49 4e 54 45 52 53 45 43 54 2e 20   ::= INTERSECT. 
2b70: 20 7b 41 20 3d 20 54 4b 5f 49 4e 54 45 52 53 45   {A = TK_INTERSE
2b80: 43 54 3b 7d 0a 6d 75 6c 74 69 73 65 6c 65 63 74  CT;}.multiselect
2b90: 5f 6f 70 28 41 29 20 3a 3a 3d 20 45 58 43 45 50  _op(A) ::= EXCEP
2ba0: 54 2e 20 20 20 20 20 7b 41 20 3d 20 54 4b 5f 45  T.     {A = TK_E
2bb0: 58 43 45 50 54 3b 7d 0a 6f 6e 65 73 65 6c 65 63  XCEPT;}.oneselec
2bc0: 74 28 41 29 20 3a 3a 3d 20 53 45 4c 45 43 54 20  t(A) ::= SELECT 
2bd0: 64 69 73 74 69 6e 63 74 28 44 29 20 73 65 6c 63  distinct(D) selc
2be0: 6f 6c 6c 69 73 74 28 57 29 20 66 72 6f 6d 28 58  ollist(W) from(X
2bf0: 29 20 77 68 65 72 65 5f 6f 70 74 28 59 29 0a 20  ) where_opt(Y). 
2c00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c10: 67 72 6f 75 70 62 79 5f 6f 70 74 28 50 29 20 68  groupby_opt(P) h
2c20: 61 76 69 6e 67 5f 6f 70 74 28 51 29 20 6f 72 64  aving_opt(Q) ord
2c30: 65 72 62 79 5f 6f 70 74 28 5a 29 20 6c 69 6d 69  erby_opt(Z) limi
2c40: 74 5f 6f 70 74 28 4c 29 2e 20 7b 0a 20 20 41 20  t_opt(L). {.  A 
2c50: 3d 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 4e  = sqlite3SelectN
2c60: 65 77 28 57 2c 58 2c 59 2c 50 2c 51 2c 5a 2c 44  ew(W,X,Y,P,Q,Z,D
2c70: 2c 4c 2e 6c 69 6d 69 74 2c 4c 2e 6f 66 66 73 65  ,L.limit,L.offse
2c80: 74 29 3b 0a 7d 0a 0a 2f 2f 20 54 68 65 20 22 64  t);.}..// The "d
2c90: 69 73 74 69 6e 63 74 22 20 6e 6f 6e 74 65 72 6d  istinct" nonterm
2ca0: 69 6e 61 6c 20 69 73 20 74 72 75 65 20 28 31 29  inal is true (1)
2cb0: 20 69 66 20 74 68 65 20 44 49 53 54 49 4e 43 54   if the DISTINCT
2cc0: 20 6b 65 79 77 6f 72 64 20 69 73 0a 2f 2f 20 70   keyword is.// p
2cd0: 72 65 73 65 6e 74 20 61 6e 64 20 66 61 6c 73 65  resent and false
2ce0: 20 28 30 29 20 69 66 20 69 74 20 69 73 20 6e 6f   (0) if it is no
2cf0: 74 2e 0a 2f 2f 0a 25 74 79 70 65 20 64 69 73 74  t..//.%type dist
2d00: 69 6e 63 74 20 7b 69 6e 74 7d 0a 64 69 73 74 69  inct {int}.disti
2d10: 6e 63 74 28 41 29 20 3a 3a 3d 20 44 49 53 54 49  nct(A) ::= DISTI
2d20: 4e 43 54 2e 20 20 20 7b 41 20 3d 20 31 3b 7d 0a  NCT.   {A = 1;}.
2d30: 64 69 73 74 69 6e 63 74 28 41 29 20 3a 3a 3d 20  distinct(A) ::= 
2d40: 41 4c 4c 2e 20 20 20 20 20 20 20 20 7b 41 20 3d  ALL.        {A =
2d50: 20 30 3b 7d 0a 64 69 73 74 69 6e 63 74 28 41 29   0;}.distinct(A)
2d60: 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20   ::= .          
2d70: 20 7b 41 20 3d 20 30 3b 7d 0a 0a 2f 2f 20 73 65   {A = 0;}..// se
2d80: 6c 63 6f 6c 6c 69 73 74 20 69 73 20 61 20 6c 69  lcollist is a li
2d90: 73 74 20 6f 66 20 65 78 70 72 65 73 73 69 6f 6e  st of expression
2da0: 73 20 74 68 61 74 20 61 72 65 20 74 6f 20 62 65  s that are to be
2db0: 63 6f 6d 65 20 74 68 65 20 72 65 74 75 72 6e 0a  come the return.
2dc0: 2f 2f 20 76 61 6c 75 65 73 20 6f 66 20 74 68 65  // values of the
2dd0: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
2de0: 74 2e 20 20 54 68 65 20 22 2a 22 20 69 6e 20 73  t.  The "*" in s
2df0: 74 61 74 65 6d 65 6e 74 73 20 6c 69 6b 65 0a 2f  tatements like./
2e00: 2f 20 22 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  / "SELECT * FROM
2e10: 20 2e 2e 2e 22 20 69 73 20 65 6e 63 6f 64 65 64   ..." is encoded
2e20: 20 61 73 20 61 20 73 70 65 63 69 61 6c 20 65 78   as a special ex
2e30: 70 72 65 73 73 69 6f 6e 20 77 69 74 68 20 61 6e  pression with an
2e40: 0a 2f 2f 20 6f 70 63 6f 64 65 20 6f 66 20 54 4b  .// opcode of TK
2e50: 5f 41 4c 4c 2e 0a 2f 2f 0a 25 74 79 70 65 20 73  _ALL..//.%type s
2e60: 65 6c 63 6f 6c 6c 69 73 74 20 7b 45 78 70 72 4c  elcollist {ExprL
2e70: 69 73 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f  ist*}.%destructo
2e80: 72 20 73 65 6c 63 6f 6c 6c 69 73 74 20 7b 73 71  r selcollist {sq
2e90: 6c 69 74 65 33 45 78 70 72 4c 69 73 74 44 65 6c  lite3ExprListDel
2ea0: 65 74 65 28 24 24 29 3b 7d 0a 25 74 79 70 65 20  ete($$);}.%type 
2eb0: 73 63 6c 70 20 7b 45 78 70 72 4c 69 73 74 2a 7d  sclp {ExprList*}
2ec0: 0a 25 64 65 73 74 72 75 63 74 6f 72 20 73 63 6c  .%destructor scl
2ed0: 70 20 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69  p {sqlite3ExprLi
2ee0: 73 74 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a 73  stDelete($$);}.s
2ef0: 63 6c 70 28 41 29 20 3a 3a 3d 20 73 65 6c 63 6f  clp(A) ::= selco
2f00: 6c 6c 69 73 74 28 58 29 20 43 4f 4d 4d 41 2e 20  llist(X) COMMA. 
2f10: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d              {A =
2f20: 20 58 3b 7d 0a 73 63 6c 70 28 41 29 20 3a 3a 3d   X;}.sclp(A) ::=
2f30: 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20   .              
2f40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f50: 20 20 7b 41 20 3d 20 30 3b 7d 0a 73 65 6c 63 6f    {A = 0;}.selco
2f60: 6c 6c 69 73 74 28 41 29 20 3a 3a 3d 20 73 63 6c  llist(A) ::= scl
2f70: 70 28 50 29 20 65 78 70 72 28 58 29 20 61 73 28  p(P) expr(X) as(
2f80: 59 29 2e 20 20 20 20 20 7b 0a 20 20 20 41 20 3d  Y).     {.   A =
2f90: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
2fa0: 41 70 70 65 6e 64 28 50 2c 58 2c 59 2e 6e 3f 26  Append(P,X,Y.n?&
2fb0: 59 3a 30 29 3b 0a 7d 0a 73 65 6c 63 6f 6c 6c 69  Y:0);.}.selcolli
2fc0: 73 74 28 41 29 20 3a 3a 3d 20 73 63 6c 70 28 50  st(A) ::= sclp(P
2fd0: 29 20 53 54 41 52 2e 20 7b 0a 20 20 41 20 3d 20  ) STAR. {.  A = 
2fe0: 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 41  sqlite3ExprListA
2ff0: 70 70 65 6e 64 28 50 2c 20 73 71 6c 69 74 65 33  ppend(P, sqlite3
3000: 45 78 70 72 28 54 4b 5f 41 4c 4c 2c 20 30 2c 20  Expr(TK_ALL, 0, 
3010: 30 2c 20 30 29 2c 20 30 29 3b 0a 7d 0a 73 65 6c  0, 0), 0);.}.sel
3020: 63 6f 6c 6c 69 73 74 28 41 29 20 3a 3a 3d 20 73  collist(A) ::= s
3030: 63 6c 70 28 50 29 20 6e 6d 28 58 29 20 44 4f 54  clp(P) nm(X) DOT
3040: 20 53 54 41 52 2e 20 7b 0a 20 20 45 78 70 72 20   STAR. {.  Expr 
3050: 2a 70 52 69 67 68 74 20 3d 20 73 71 6c 69 74 65  *pRight = sqlite
3060: 33 45 78 70 72 28 54 4b 5f 41 4c 4c 2c 20 30 2c  3Expr(TK_ALL, 0,
3070: 20 30 2c 20 30 29 3b 0a 20 20 45 78 70 72 20 2a   0, 0);.  Expr *
3080: 70 4c 65 66 74 20 3d 20 73 71 6c 69 74 65 33 45  pLeft = sqlite3E
3090: 78 70 72 28 54 4b 5f 49 44 2c 20 30 2c 20 30 2c  xpr(TK_ID, 0, 0,
30a0: 20 26 58 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69   &X);.  A = sqli
30b0: 74 65 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e  te3ExprListAppen
30c0: 64 28 50 2c 20 73 71 6c 69 74 65 33 45 78 70 72  d(P, sqlite3Expr
30d0: 28 54 4b 5f 44 4f 54 2c 20 70 4c 65 66 74 2c 20  (TK_DOT, pLeft, 
30e0: 70 52 69 67 68 74 2c 20 30 29 2c 20 30 29 3b 0a  pRight, 0), 0);.
30f0: 7d 0a 0a 2f 2f 20 41 6e 20 6f 70 74 69 6f 6e 20  }..// An option 
3100: 22 41 53 20 3c 69 64 3e 22 20 70 68 72 61 73 65  "AS <id>" phrase
3110: 20 74 68 61 74 20 63 61 6e 20 66 6f 6c 6c 6f 77   that can follow
3120: 20 6f 6e 65 20 6f 66 20 74 68 65 20 65 78 70 72   one of the expr
3130: 65 73 73 69 6f 6e 73 20 74 68 61 74 0a 2f 2f 20  essions that.// 
3140: 64 65 66 69 6e 65 20 74 68 65 20 72 65 73 75 6c  define the resul
3150: 74 20 73 65 74 2c 20 6f 72 20 6f 6e 65 20 6f 66  t set, or one of
3160: 20 74 68 65 20 74 61 62 6c 65 73 20 69 6e 20 74   the tables in t
3170: 68 65 20 46 52 4f 4d 20 63 6c 61 75 73 65 2e 0a  he FROM clause..
3180: 2f 2f 0a 25 74 79 70 65 20 61 73 20 7b 54 6f 6b  //.%type as {Tok
3190: 65 6e 7d 0a 61 73 28 58 29 20 3a 3a 3d 20 41 53  en}.as(X) ::= AS
31a0: 20 6e 6d 28 59 29 2e 20 20 20 20 7b 20 58 20 3d   nm(Y).    { X =
31b0: 20 59 3b 20 7d 0a 61 73 28 58 29 20 3a 3a 3d 20   Y; }.as(X) ::= 
31c0: 69 64 73 28 59 29 2e 20 20 20 20 20 20 7b 20 58  ids(Y).      { X
31d0: 20 3d 20 59 3b 20 7d 0a 61 73 28 58 29 20 3a 3a   = Y; }.as(X) ::
31e0: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 7b  = .            {
31f0: 20 58 2e 6e 20 3d 20 30 3b 20 7d 0a 0a 0a 25 74   X.n = 0; }...%t
3200: 79 70 65 20 73 65 6c 74 61 62 6c 69 73 74 20 7b  ype seltablist {
3210: 53 72 63 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72  SrcList*}.%destr
3220: 75 63 74 6f 72 20 73 65 6c 74 61 62 6c 69 73 74  uctor seltablist
3230: 20 7b 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74   {sqlite3SrcList
3240: 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a 25 74 79  Delete($$);}.%ty
3250: 70 65 20 73 74 6c 5f 70 72 65 66 69 78 20 7b 53  pe stl_prefix {S
3260: 72 63 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72 75  rcList*}.%destru
3270: 63 74 6f 72 20 73 74 6c 5f 70 72 65 66 69 78 20  ctor stl_prefix 
3280: 7b 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 44  {sqlite3SrcListD
3290: 65 6c 65 74 65 28 24 24 29 3b 7d 0a 25 74 79 70  elete($$);}.%typ
32a0: 65 20 66 72 6f 6d 20 7b 53 72 63 4c 69 73 74 2a  e from {SrcList*
32b0: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 66 72  }.%destructor fr
32c0: 6f 6d 20 7b 73 71 6c 69 74 65 33 53 72 63 4c 69  om {sqlite3SrcLi
32d0: 73 74 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a 0a  stDelete($$);}..
32e0: 2f 2f 20 41 20 63 6f 6d 70 6c 65 74 65 20 46 52  // A complete FR
32f0: 4f 4d 20 63 6c 61 75 73 65 2e 0a 2f 2f 0a 66 72  OM clause..//.fr
3300: 6f 6d 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20  om(A) ::= .     
3310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3320: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d              {A =
3330: 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 73 69   sqliteMalloc(si
3340: 7a 65 6f 66 28 2a 41 29 29 3b 7d 0a 66 72 6f 6d  zeof(*A));}.from
3350: 28 41 29 20 3a 3a 3d 20 46 52 4f 4d 20 73 65 6c  (A) ::= FROM sel
3360: 74 61 62 6c 69 73 74 28 58 29 2e 20 20 20 20 20  tablist(X).     
3370: 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58            {A = X
3380: 3b 7d 0a 0a 2f 2f 20 22 73 65 6c 74 61 62 6c 69  ;}..// "seltabli
3390: 73 74 22 20 69 73 20 61 20 22 53 65 6c 65 63 74  st" is a "Select
33a0: 20 54 61 62 6c 65 20 4c 69 73 74 22 20 2d 20 74   Table List" - t
33b0: 68 65 20 63 6f 6e 74 65 6e 74 20 6f 66 20 74 68  he content of th
33c0: 65 20 46 52 4f 4d 20 63 6c 61 75 73 65 0a 2f 2f  e FROM clause.//
33d0: 20 69 6e 20 61 20 53 45 4c 45 43 54 20 73 74 61   in a SELECT sta
33e0: 74 65 6d 65 6e 74 2e 20 20 22 73 74 6c 5f 70 72  tement.  "stl_pr
33f0: 65 66 69 78 22 20 69 73 20 61 20 70 72 65 66 69  efix" is a prefi
3400: 78 20 6f 66 20 74 68 69 73 20 6c 69 73 74 2e 0a  x of this list..
3410: 2f 2f 0a 73 74 6c 5f 70 72 65 66 69 78 28 41 29  //.stl_prefix(A)
3420: 20 3a 3a 3d 20 73 65 6c 74 61 62 6c 69 73 74 28   ::= seltablist(
3430: 58 29 20 6a 6f 69 6e 6f 70 28 59 29 2e 20 20 20  X) joinop(Y).   
3440: 20 7b 0a 20 20 20 41 20 3d 20 58 3b 0a 20 20 20   {.   A = X;.   
3450: 69 66 28 20 41 20 26 26 20 41 2d 3e 6e 53 72 63  if( A && A->nSrc
3460: 3e 30 20 29 20 41 2d 3e 61 5b 41 2d 3e 6e 53 72  >0 ) A->a[A->nSr
3470: 63 2d 31 5d 2e 6a 6f 69 6e 74 79 70 65 20 3d 20  c-1].jointype = 
3480: 59 3b 0a 7d 0a 73 74 6c 5f 70 72 65 66 69 78 28  Y;.}.stl_prefix(
3490: 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20  A) ::= .        
34a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
34b0: 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 73 65 6c 74     {A = 0;}.selt
34c0: 61 62 6c 69 73 74 28 41 29 20 3a 3a 3d 20 73 74  ablist(A) ::= st
34d0: 6c 5f 70 72 65 66 69 78 28 58 29 20 6e 6d 28 59  l_prefix(X) nm(Y
34e0: 29 20 64 62 6e 6d 28 44 29 20 61 73 28 5a 29 20  ) dbnm(D) as(Z) 
34f0: 6f 6e 5f 6f 70 74 28 4e 29 20 75 73 69 6e 67 5f  on_opt(N) using_
3500: 6f 70 74 28 55 29 2e 20 7b 0a 20 20 41 20 3d 20  opt(U). {.  A = 
3510: 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 41 70  sqlite3SrcListAp
3520: 70 65 6e 64 28 58 2c 26 59 2c 26 44 29 3b 0a 20  pend(X,&Y,&D);. 
3530: 20 69 66 28 20 5a 2e 6e 20 29 20 73 71 6c 69 74   if( Z.n ) sqlit
3540: 65 33 53 72 63 4c 69 73 74 41 64 64 41 6c 69 61  e3SrcListAddAlia
3550: 73 28 41 2c 26 5a 29 3b 0a 20 20 69 66 28 20 4e  s(A,&Z);.  if( N
3560: 20 29 7b 0a 20 20 20 20 69 66 28 20 41 20 26 26   ){.    if( A &&
3570: 20 41 2d 3e 6e 53 72 63 3e 31 20 29 7b 20 41 2d   A->nSrc>1 ){ A-
3580: 3e 61 5b 41 2d 3e 6e 53 72 63 2d 32 5d 2e 70 4f  >a[A->nSrc-2].pO
3590: 6e 20 3d 20 4e 3b 20 7d 0a 20 20 20 20 65 6c 73  n = N; }.    els
35a0: 65 20 7b 20 73 71 6c 69 74 65 33 45 78 70 72 44  e { sqlite3ExprD
35b0: 65 6c 65 74 65 28 4e 29 3b 20 7d 0a 20 20 7d 0a  elete(N); }.  }.
35c0: 20 20 69 66 28 20 55 20 29 7b 0a 20 20 20 20 69    if( U ){.    i
35d0: 66 28 20 41 20 26 26 20 41 2d 3e 6e 53 72 63 3e  f( A && A->nSrc>
35e0: 31 20 29 7b 20 41 2d 3e 61 5b 41 2d 3e 6e 53 72  1 ){ A->a[A->nSr
35f0: 63 2d 32 5d 2e 70 55 73 69 6e 67 20 3d 20 55 3b  c-2].pUsing = U;
3600: 20 7d 0a 20 20 20 20 65 6c 73 65 20 7b 20 73 71   }.    else { sq
3610: 6c 69 74 65 33 49 64 4c 69 73 74 44 65 6c 65 74  lite3IdListDelet
3620: 65 28 55 29 3b 20 7d 0a 20 20 7d 0a 7d 0a 73 65  e(U); }.  }.}.se
3630: 6c 74 61 62 6c 69 73 74 28 41 29 20 3a 3a 3d 20  ltablist(A) ::= 
3640: 73 74 6c 5f 70 72 65 66 69 78 28 58 29 20 4c 50  stl_prefix(X) LP
3650: 20 73 65 6c 74 61 62 6c 69 73 74 5f 70 61 72 65   seltablist_pare
3660: 6e 28 53 29 20 52 50 0a 20 20 20 20 20 20 20 20  n(S) RP.        
3670: 20 20 20 20 20 20 20 20 20 20 61 73 28 5a 29 20            as(Z) 
3680: 6f 6e 5f 6f 70 74 28 4e 29 20 75 73 69 6e 67 5f  on_opt(N) using_
3690: 6f 70 74 28 55 29 2e 20 7b 0a 20 20 41 20 3d 20  opt(U). {.  A = 
36a0: 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 41 70  sqlite3SrcListAp
36b0: 70 65 6e 64 28 58 2c 30 2c 30 29 3b 0a 20 20 41  pend(X,0,0);.  A
36c0: 2d 3e 61 5b 41 2d 3e 6e 53 72 63 2d 31 5d 2e 70  ->a[A->nSrc-1].p
36d0: 53 65 6c 65 63 74 20 3d 20 53 3b 0a 20 20 69 66  Select = S;.  if
36e0: 28 20 5a 2e 6e 20 29 20 73 71 6c 69 74 65 33 53  ( Z.n ) sqlite3S
36f0: 72 63 4c 69 73 74 41 64 64 41 6c 69 61 73 28 41  rcListAddAlias(A
3700: 2c 26 5a 29 3b 0a 20 20 69 66 28 20 4e 20 29 7b  ,&Z);.  if( N ){
3710: 0a 20 20 20 20 69 66 28 20 41 20 26 26 20 41 2d  .    if( A && A-
3720: 3e 6e 53 72 63 3e 31 20 29 7b 20 41 2d 3e 61 5b  >nSrc>1 ){ A->a[
3730: 41 2d 3e 6e 53 72 63 2d 32 5d 2e 70 4f 6e 20 3d  A->nSrc-2].pOn =
3740: 20 4e 3b 20 7d 0a 20 20 20 20 65 6c 73 65 20 7b   N; }.    else {
3750: 20 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65   sqlite3ExprDele
3760: 74 65 28 4e 29 3b 20 7d 0a 20 20 7d 0a 20 20 69  te(N); }.  }.  i
3770: 66 28 20 55 20 29 7b 0a 20 20 20 20 69 66 28 20  f( U ){.    if( 
3780: 41 20 26 26 20 41 2d 3e 6e 53 72 63 3e 31 20 29  A && A->nSrc>1 )
3790: 7b 20 41 2d 3e 61 5b 41 2d 3e 6e 53 72 63 2d 32  { A->a[A->nSrc-2
37a0: 5d 2e 70 55 73 69 6e 67 20 3d 20 55 3b 20 7d 0a  ].pUsing = U; }.
37b0: 20 20 20 20 65 6c 73 65 20 7b 20 73 71 6c 69 74      else { sqlit
37c0: 65 33 49 64 4c 69 73 74 44 65 6c 65 74 65 28 55  e3IdListDelete(U
37d0: 29 3b 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2f 20 41  ); }.  }.}..// A
37e0: 20 73 65 6c 74 61 62 6c 69 73 74 5f 70 61 72 65   seltablist_pare
37f0: 6e 20 6e 6f 6e 74 65 72 6d 69 6e 61 6c 20 72 65  n nonterminal re
3800: 70 72 65 73 65 6e 74 73 20 61 6e 79 74 68 69 6e  presents anythin
3810: 67 20 69 6e 20 61 20 46 52 4f 4d 20 74 68 61 74  g in a FROM that
3820: 0a 2f 2f 20 69 73 20 63 6f 6e 74 61 69 6e 65 64  .// is contained
3830: 20 69 6e 73 69 64 65 20 70 61 72 65 6e 74 68 65   inside parenthe
3840: 73 65 73 2e 20 20 54 68 69 73 20 63 61 6e 20 62  ses.  This can b
3850: 65 20 65 69 74 68 65 72 20 61 20 73 75 62 71 75  e either a subqu
3860: 65 72 79 20 6f 72 0a 2f 2f 20 61 20 67 72 6f 75  ery or.// a grou
3870: 70 69 6e 67 20 6f 66 20 74 61 62 6c 65 20 61 6e  ping of table an
3880: 64 20 73 75 62 71 75 65 72 69 65 73 2e 0a 2f 2f  d subqueries..//
3890: 0a 25 74 79 70 65 20 73 65 6c 74 61 62 6c 69 73  .%type seltablis
38a0: 74 5f 70 61 72 65 6e 20 7b 53 65 6c 65 63 74 2a  t_paren {Select*
38b0: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 73 65  }.%destructor se
38c0: 6c 74 61 62 6c 69 73 74 5f 70 61 72 65 6e 20 7b  ltablist_paren {
38d0: 73 71 6c 69 74 65 33 53 65 6c 65 63 74 44 65 6c  sqlite3SelectDel
38e0: 65 74 65 28 24 24 29 3b 7d 0a 73 65 6c 74 61 62  ete($$);}.seltab
38f0: 6c 69 73 74 5f 70 61 72 65 6e 28 41 29 20 3a 3a  list_paren(A) ::
3900: 3d 20 73 65 6c 65 63 74 28 53 29 2e 20 20 20 20  = select(S).    
3910: 20 20 7b 41 20 3d 20 53 3b 7d 0a 73 65 6c 74 61    {A = S;}.selta
3920: 62 6c 69 73 74 5f 70 61 72 65 6e 28 41 29 20 3a  blist_paren(A) :
3930: 3a 3d 20 73 65 6c 74 61 62 6c 69 73 74 28 46 29  := seltablist(F)
3940: 2e 20 20 7b 0a 20 20 20 41 20 3d 20 73 71 6c 69  .  {.   A = sqli
3950: 74 65 33 53 65 6c 65 63 74 4e 65 77 28 30 2c 46  te3SelectNew(0,F
3960: 2c 30 2c 30 2c 30 2c 30 2c 30 2c 2d 31 2c 30 29  ,0,0,0,0,0,-1,0)
3970: 3b 0a 7d 0a 0a 25 74 79 70 65 20 64 62 6e 6d 20  ;.}..%type dbnm 
3980: 7b 54 6f 6b 65 6e 7d 0a 64 62 6e 6d 28 41 29 20  {Token}.dbnm(A) 
3990: 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 7b  ::= .          {
39a0: 41 2e 7a 3d 30 3b 20 41 2e 6e 3d 30 3b 7d 0a 64  A.z=0; A.n=0;}.d
39b0: 62 6e 6d 28 41 29 20 3a 3a 3d 20 44 4f 54 20 6e  bnm(A) ::= DOT n
39c0: 6d 28 58 29 2e 20 7b 41 20 3d 20 58 3b 7d 0a 0a  m(X). {A = X;}..
39d0: 25 74 79 70 65 20 6a 6f 69 6e 6f 70 20 7b 69 6e  %type joinop {in
39e0: 74 7d 0a 25 74 79 70 65 20 6a 6f 69 6e 6f 70 32  t}.%type joinop2
39f0: 20 7b 69 6e 74 7d 0a 6a 6f 69 6e 6f 70 28 58 29   {int}.joinop(X)
3a00: 20 3a 3a 3d 20 43 4f 4d 4d 41 2e 20 20 20 20 20   ::= COMMA.     
3a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20                { 
3a20: 58 20 3d 20 4a 54 5f 49 4e 4e 45 52 3b 20 7d 0a  X = JT_INNER; }.
3a30: 6a 6f 69 6e 6f 70 28 58 29 20 3a 3a 3d 20 4a 4f  joinop(X) ::= JO
3a40: 49 4e 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  IN.             
3a50: 20 20 20 20 20 20 20 7b 20 58 20 3d 20 4a 54 5f         { X = JT_
3a60: 49 4e 4e 45 52 3b 20 7d 0a 6a 6f 69 6e 6f 70 28  INNER; }.joinop(
3a70: 58 29 20 3a 3a 3d 20 4a 4f 49 4e 5f 4b 57 28 41  X) ::= JOIN_KW(A
3a80: 29 20 4a 4f 49 4e 2e 20 20 20 20 20 20 20 20 20  ) JOIN.         
3a90: 7b 20 58 20 3d 20 73 71 6c 69 74 65 33 4a 6f 69  { X = sqlite3Joi
3aa0: 6e 54 79 70 65 28 70 50 61 72 73 65 2c 26 41 2c  nType(pParse,&A,
3ab0: 30 2c 30 29 3b 20 7d 0a 6a 6f 69 6e 6f 70 28 58  0,0); }.joinop(X
3ac0: 29 20 3a 3a 3d 20 4a 4f 49 4e 5f 4b 57 28 41 29  ) ::= JOIN_KW(A)
3ad0: 20 6e 6d 28 42 29 20 4a 4f 49 4e 2e 20 20 20 7b   nm(B) JOIN.   {
3ae0: 20 58 20 3d 20 73 71 6c 69 74 65 33 4a 6f 69 6e   X = sqlite3Join
3af0: 54 79 70 65 28 70 50 61 72 73 65 2c 26 41 2c 26  Type(pParse,&A,&
3b00: 42 2c 30 29 3b 20 7d 0a 6a 6f 69 6e 6f 70 28 58  B,0); }.joinop(X
3b10: 29 20 3a 3a 3d 20 4a 4f 49 4e 5f 4b 57 28 41 29  ) ::= JOIN_KW(A)
3b20: 20 6e 6d 28 42 29 20 6e 6d 28 43 29 20 4a 4f 49   nm(B) nm(C) JOI
3b30: 4e 2e 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  N..             
3b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3b50: 20 20 20 20 20 20 20 20 20 20 7b 20 58 20 3d 20            { X = 
3b60: 73 71 6c 69 74 65 33 4a 6f 69 6e 54 79 70 65 28  sqlite3JoinType(
3b70: 70 50 61 72 73 65 2c 26 41 2c 26 42 2c 26 43 29  pParse,&A,&B,&C)
3b80: 3b 20 7d 0a 0a 25 74 79 70 65 20 6f 6e 5f 6f 70  ; }..%type on_op
3b90: 74 20 7b 45 78 70 72 2a 7d 0a 25 64 65 73 74 72  t {Expr*}.%destr
3ba0: 75 63 74 6f 72 20 6f 6e 5f 6f 70 74 20 7b 73 71  uctor on_opt {sq
3bb0: 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65 28  lite3ExprDelete(
3bc0: 24 24 29 3b 7d 0a 6f 6e 5f 6f 70 74 28 4e 29 20  $$);}.on_opt(N) 
3bd0: 3a 3a 3d 20 4f 4e 20 65 78 70 72 28 45 29 2e 20  ::= ON expr(E). 
3be0: 20 20 7b 4e 20 3d 20 45 3b 7d 0a 6f 6e 5f 6f 70    {N = E;}.on_op
3bf0: 74 28 4e 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20  t(N) ::= .      
3c00: 20 20 20 20 20 20 20 7b 4e 20 3d 20 30 3b 7d 0a         {N = 0;}.
3c10: 0a 25 74 79 70 65 20 75 73 69 6e 67 5f 6f 70 74  .%type using_opt
3c20: 20 7b 49 64 4c 69 73 74 2a 7d 0a 25 64 65 73 74   {IdList*}.%dest
3c30: 72 75 63 74 6f 72 20 75 73 69 6e 67 5f 6f 70 74  ructor using_opt
3c40: 20 7b 73 71 6c 69 74 65 33 49 64 4c 69 73 74 44   {sqlite3IdListD
3c50: 65 6c 65 74 65 28 24 24 29 3b 7d 0a 75 73 69 6e  elete($$);}.usin
3c60: 67 5f 6f 70 74 28 55 29 20 3a 3a 3d 20 55 53 49  g_opt(U) ::= USI
3c70: 4e 47 20 4c 50 20 69 64 78 6c 69 73 74 28 4c 29  NG LP idxlist(L)
3c80: 20 52 50 2e 20 20 7b 55 20 3d 20 4c 3b 7d 0a 75   RP.  {U = L;}.u
3c90: 73 69 6e 67 5f 6f 70 74 28 55 29 20 3a 3a 3d 20  sing_opt(U) ::= 
3ca0: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3cb0: 20 20 20 20 20 20 20 20 20 7b 55 20 3d 20 30 3b           {U = 0;
3cc0: 7d 0a 0a 0a 25 74 79 70 65 20 6f 72 64 65 72 62  }...%type orderb
3cd0: 79 5f 6f 70 74 20 7b 45 78 70 72 4c 69 73 74 2a  y_opt {ExprList*
3ce0: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 6f 72  }.%destructor or
3cf0: 64 65 72 62 79 5f 6f 70 74 20 7b 73 71 6c 69 74  derby_opt {sqlit
3d00: 65 33 45 78 70 72 4c 69 73 74 44 65 6c 65 74 65  e3ExprListDelete
3d10: 28 24 24 29 3b 7d 0a 25 74 79 70 65 20 73 6f 72  ($$);}.%type sor
3d20: 74 6c 69 73 74 20 7b 45 78 70 72 4c 69 73 74 2a  tlist {ExprList*
3d30: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 73 6f  }.%destructor so
3d40: 72 74 6c 69 73 74 20 7b 73 71 6c 69 74 65 33 45  rtlist {sqlite3E
3d50: 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28 24 24  xprListDelete($$
3d60: 29 3b 7d 0a 25 74 79 70 65 20 73 6f 72 74 69 74  );}.%type sortit
3d70: 65 6d 20 7b 45 78 70 72 2a 7d 0a 25 64 65 73 74  em {Expr*}.%dest
3d80: 72 75 63 74 6f 72 20 73 6f 72 74 69 74 65 6d 20  ructor sortitem 
3d90: 7b 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65  {sqlite3ExprDele
3da0: 74 65 28 24 24 29 3b 7d 0a 0a 6f 72 64 65 72 62  te($$);}..orderb
3db0: 79 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20  y_opt(A) ::= .  
3dc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3dd0: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d          {A = 0;}
3de0: 0a 6f 72 64 65 72 62 79 5f 6f 70 74 28 41 29 20  .orderby_opt(A) 
3df0: 3a 3a 3d 20 4f 52 44 45 52 20 42 59 20 73 6f 72  ::= ORDER BY sor
3e00: 74 6c 69 73 74 28 58 29 2e 20 20 20 20 20 20 7b  tlist(X).      {
3e10: 41 20 3d 20 58 3b 7d 0a 73 6f 72 74 6c 69 73 74  A = X;}.sortlist
3e20: 28 41 29 20 3a 3a 3d 20 73 6f 72 74 6c 69 73 74  (A) ::= sortlist
3e30: 28 58 29 20 43 4f 4d 4d 41 20 73 6f 72 74 69 74  (X) COMMA sortit
3e40: 65 6d 28 59 29 20 63 6f 6c 6c 61 74 65 28 43 29  em(Y) collate(C)
3e50: 20 73 6f 72 74 6f 72 64 65 72 28 5a 29 2e 20 7b   sortorder(Z). {
3e60: 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78  .  A = sqlite3Ex
3e70: 70 72 4c 69 73 74 41 70 70 65 6e 64 28 58 2c 59  prListAppend(X,Y
3e80: 2c 30 29 3b 0a 20 20 69 66 28 20 41 20 29 20 41  ,0);.  if( A ) A
3e90: 2d 3e 61 5b 41 2d 3e 6e 45 78 70 72 2d 31 5d 2e  ->a[A->nExpr-1].
3ea0: 73 6f 72 74 4f 72 64 65 72 20 3d 20 43 2b 5a 3b  sortOrder = C+Z;
3eb0: 0a 7d 0a 73 6f 72 74 6c 69 73 74 28 41 29 20 3a  .}.sortlist(A) :
3ec0: 3a 3d 20 73 6f 72 74 69 74 65 6d 28 59 29 20 63  := sortitem(Y) c
3ed0: 6f 6c 6c 61 74 65 28 43 29 20 73 6f 72 74 6f 72  ollate(C) sortor
3ee0: 64 65 72 28 5a 29 2e 20 7b 0a 20 20 41 20 3d 20  der(Z). {.  A = 
3ef0: 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 41  sqlite3ExprListA
3f00: 70 70 65 6e 64 28 30 2c 59 2c 30 29 3b 0a 20 20  ppend(0,Y,0);.  
3f10: 69 66 28 20 41 20 29 20 41 2d 3e 61 5b 30 5d 2e  if( A ) A->a[0].
3f20: 73 6f 72 74 4f 72 64 65 72 20 3d 20 43 2b 5a 3b  sortOrder = C+Z;
3f30: 0a 7d 0a 73 6f 72 74 69 74 65 6d 28 41 29 20 3a  .}.sortitem(A) :
3f40: 3a 3d 20 65 78 70 72 28 58 29 2e 20 20 20 7b 41  := expr(X).   {A
3f50: 20 3d 20 58 3b 7d 0a 0a 25 74 79 70 65 20 73 6f   = X;}..%type so
3f60: 72 74 6f 72 64 65 72 20 7b 69 6e 74 7d 0a 25 74  rtorder {int}.%t
3f70: 79 70 65 20 63 6f 6c 6c 61 74 65 20 7b 69 6e 74  ype collate {int
3f80: 7d 0a 0a 73 6f 72 74 6f 72 64 65 72 28 41 29 20  }..sortorder(A) 
3f90: 3a 3a 3d 20 41 53 43 2e 20 20 20 20 20 20 20 20  ::= ASC.        
3fa0: 20 20 20 7b 41 20 3d 20 53 51 4c 49 54 45 5f 53     {A = SQLITE_S
3fb0: 4f 5f 41 53 43 3b 7d 0a 73 6f 72 74 6f 72 64 65  O_ASC;}.sortorde
3fc0: 72 28 41 29 20 3a 3a 3d 20 44 45 53 43 2e 20 20  r(A) ::= DESC.  
3fd0: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 53 51 4c          {A = SQL
3fe0: 49 54 45 5f 53 4f 5f 44 45 53 43 3b 7d 0a 73 6f  ITE_SO_DESC;}.so
3ff0: 72 74 6f 72 64 65 72 28 41 29 20 3a 3a 3d 20 2e  rtorder(A) ::= .
4000: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41                {A
4010: 20 3d 20 53 51 4c 49 54 45 5f 53 4f 5f 41 53 43   = SQLITE_SO_ASC
4020: 3b 7d 0a 63 6f 6c 6c 61 74 65 28 43 29 20 3a 3a  ;}.collate(C) ::
4030: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
4040: 20 20 20 7b 43 20 3d 20 53 51 4c 49 54 45 5f 53     {C = SQLITE_S
4050: 4f 5f 55 4e 4b 3b 7d 0a 63 6f 6c 6c 61 74 65 28  O_UNK;}.collate(
4060: 43 29 20 3a 3a 3d 20 43 4f 4c 4c 41 54 45 20 69  C) ::= COLLATE i
4070: 64 28 58 29 2e 20 20 20 7b 43 20 3d 20 73 71 6c  d(X).   {C = sql
4080: 69 74 65 33 43 6f 6c 6c 61 74 65 54 79 70 65 28  ite3CollateType(
4090: 58 2e 7a 2c 20 58 2e 6e 29 3b 7d 0a 0a 25 74 79  X.z, X.n);}..%ty
40a0: 70 65 20 67 72 6f 75 70 62 79 5f 6f 70 74 20 7b  pe groupby_opt {
40b0: 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65 73 74  ExprList*}.%dest
40c0: 72 75 63 74 6f 72 20 67 72 6f 75 70 62 79 5f 6f  ructor groupby_o
40d0: 70 74 20 7b 73 71 6c 69 74 65 33 45 78 70 72 4c  pt {sqlite3ExprL
40e0: 69 73 74 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a  istDelete($$);}.
40f0: 67 72 6f 75 70 62 79 5f 6f 70 74 28 41 29 20 3a  groupby_opt(A) :
4100: 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20  := .            
4110: 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30            {A = 0
4120: 3b 7d 0a 67 72 6f 75 70 62 79 5f 6f 70 74 28 41  ;}.groupby_opt(A
4130: 29 20 3a 3a 3d 20 47 52 4f 55 50 20 42 59 20 65  ) ::= GROUP BY e
4140: 78 70 72 6c 69 73 74 28 58 29 2e 20 20 7b 41 20  xprlist(X).  {A 
4150: 3d 20 58 3b 7d 0a 0a 25 74 79 70 65 20 68 61 76  = X;}..%type hav
4160: 69 6e 67 5f 6f 70 74 20 7b 45 78 70 72 2a 7d 0a  ing_opt {Expr*}.
4170: 25 64 65 73 74 72 75 63 74 6f 72 20 68 61 76 69  %destructor havi
4180: 6e 67 5f 6f 70 74 20 7b 73 71 6c 69 74 65 33 45  ng_opt {sqlite3E
4190: 78 70 72 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a  xprDelete($$);}.
41a0: 68 61 76 69 6e 67 5f 6f 70 74 28 41 29 20 3a 3a  having_opt(A) ::
41b0: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
41c0: 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 68 61 76 69     {A = 0;}.havi
41d0: 6e 67 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 48 41  ng_opt(A) ::= HA
41e0: 56 49 4e 47 20 65 78 70 72 28 58 29 2e 20 20 7b  VING expr(X).  {
41f0: 41 20 3d 20 58 3b 7d 0a 0a 25 74 79 70 65 20 6c  A = X;}..%type l
4200: 69 6d 69 74 5f 6f 70 74 20 7b 73 74 72 75 63 74  imit_opt {struct
4210: 20 4c 69 6d 69 74 56 61 6c 7d 0a 6c 69 6d 69 74   LimitVal}.limit
4220: 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20 20  _opt(A) ::= .   
4230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4240: 20 20 7b 41 2e 6c 69 6d 69 74 20 3d 20 2d 31 3b    {A.limit = -1;
4250: 20 41 2e 6f 66 66 73 65 74 20 3d 20 30 3b 7d 0a   A.offset = 0;}.
4260: 6c 69 6d 69 74 5f 6f 70 74 28 41 29 20 3a 3a 3d  limit_opt(A) ::=
4270: 20 4c 49 4d 49 54 20 73 69 67 6e 65 64 28 58 29   LIMIT signed(X)
4280: 2e 20 20 20 20 20 20 7b 41 2e 6c 69 6d 69 74 20  .      {A.limit 
4290: 3d 20 58 3b 20 41 2e 6f 66 66 73 65 74 20 3d 20  = X; A.offset = 
42a0: 30 3b 7d 0a 6c 69 6d 69 74 5f 6f 70 74 28 41 29  0;}.limit_opt(A)
42b0: 20 3a 3a 3d 20 4c 49 4d 49 54 20 73 69 67 6e 65   ::= LIMIT signe
42c0: 64 28 58 29 20 4f 46 46 53 45 54 20 73 69 67 6e  d(X) OFFSET sign
42d0: 65 64 28 59 29 2e 20 0a 20 20 20 20 20 20 20 20  ed(Y). .        
42e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
42f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
4300: 41 2e 6c 69 6d 69 74 20 3d 20 58 3b 20 41 2e 6f  A.limit = X; A.o
4310: 66 66 73 65 74 20 3d 20 59 3b 7d 0a 6c 69 6d 69  ffset = Y;}.limi
4320: 74 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 4c 49 4d  t_opt(A) ::= LIM
4330: 49 54 20 73 69 67 6e 65 64 28 58 29 20 43 4f 4d  IT signed(X) COM
4340: 4d 41 20 73 69 67 6e 65 64 28 59 29 2e 20 0a 20  MA signed(Y). . 
4350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4370: 20 20 20 20 20 20 7b 41 2e 6c 69 6d 69 74 20 3d        {A.limit =
4380: 20 59 3b 20 41 2e 6f 66 66 73 65 74 20 3d 20 58   Y; A.offset = X
4390: 3b 7d 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ;}..////////////
43a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20  /////////////// 
43b0: 54 68 65 20 44 45 4c 45 54 45 20 73 74 61 74 65  The DELETE state
43c0: 6d 65 6e 74 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ment ///////////
43d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
43e0: 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d 20 44 45  //.//.cmd ::= DE
43f0: 4c 45 54 45 20 46 52 4f 4d 20 6e 6d 28 58 29 20  LETE FROM nm(X) 
4400: 64 62 6e 6d 28 44 29 20 77 68 65 72 65 5f 6f 70  dbnm(D) where_op
4410: 74 28 59 29 2e 20 7b 0a 20 20 20 73 71 6c 69 74  t(Y). {.   sqlit
4420: 65 33 44 65 6c 65 74 65 46 72 6f 6d 28 70 50 61  e3DeleteFrom(pPa
4430: 72 73 65 2c 20 73 71 6c 69 74 65 33 53 72 63 4c  rse, sqlite3SrcL
4440: 69 73 74 41 70 70 65 6e 64 28 30 2c 26 58 2c 26  istAppend(0,&X,&
4450: 44 29 2c 20 59 29 3b 0a 7d 0a 0a 25 74 79 70 65  D), Y);.}..%type
4460: 20 77 68 65 72 65 5f 6f 70 74 20 7b 45 78 70 72   where_opt {Expr
4470: 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 77  *}.%destructor w
4480: 68 65 72 65 5f 6f 70 74 20 7b 73 71 6c 69 74 65  here_opt {sqlite
4490: 33 45 78 70 72 44 65 6c 65 74 65 28 24 24 29 3b  3ExprDelete($$);
44a0: 7d 0a 0a 77 68 65 72 65 5f 6f 70 74 28 41 29 20  }..where_opt(A) 
44b0: 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20  ::= .           
44c0: 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30 3b           {A = 0;
44d0: 7d 0a 77 68 65 72 65 5f 6f 70 74 28 41 29 20 3a  }.where_opt(A) :
44e0: 3a 3d 20 57 48 45 52 45 20 65 78 70 72 28 58 29  := WHERE expr(X)
44f0: 2e 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d  .       {A = X;}
4500: 0a 0a 25 74 79 70 65 20 73 65 74 6c 69 73 74 20  ..%type setlist 
4510: 7b 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65 73  {ExprList*}.%des
4520: 74 72 75 63 74 6f 72 20 73 65 74 6c 69 73 74 20  tructor setlist 
4530: 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74  {sqlite3ExprList
4540: 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a 0a 2f 2f  Delete($$);}..//
4550: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
4560: 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20 55 50 44  //////// The UPD
4570: 41 54 45 20 63 6f 6d 6d 61 6e 64 20 2f 2f 2f 2f  ATE command ////
4580: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
4590: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a  ////////////.//.
45a0: 63 6d 64 20 3a 3a 3d 20 55 50 44 41 54 45 20 6f  cmd ::= UPDATE o
45b0: 72 63 6f 6e 66 28 52 29 20 6e 6d 28 58 29 20 64  rconf(R) nm(X) d
45c0: 62 6e 6d 28 44 29 20 53 45 54 20 73 65 74 6c 69  bnm(D) SET setli
45d0: 73 74 28 59 29 20 77 68 65 72 65 5f 6f 70 74 28  st(Y) where_opt(
45e0: 5a 29 2e 0a 20 20 20 20 7b 73 71 6c 69 74 65 33  Z)..    {sqlite3
45f0: 55 70 64 61 74 65 28 70 50 61 72 73 65 2c 73 71  Update(pParse,sq
4600: 6c 69 74 65 33 53 72 63 4c 69 73 74 41 70 70 65  lite3SrcListAppe
4610: 6e 64 28 30 2c 26 58 2c 26 44 29 2c 59 2c 5a 2c  nd(0,&X,&D),Y,Z,
4620: 52 29 3b 7d 0a 0a 73 65 74 6c 69 73 74 28 41 29  R);}..setlist(A)
4630: 20 3a 3a 3d 20 73 65 74 6c 69 73 74 28 5a 29 20   ::= setlist(Z) 
4640: 43 4f 4d 4d 41 20 6e 6d 28 58 29 20 45 51 20 65  COMMA nm(X) EQ e
4650: 78 70 72 28 59 29 2e 0a 20 20 20 20 7b 41 20 3d  xpr(Y)..    {A =
4660: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
4670: 41 70 70 65 6e 64 28 5a 2c 59 2c 26 58 29 3b 7d  Append(Z,Y,&X);}
4680: 0a 73 65 74 6c 69 73 74 28 41 29 20 3a 3a 3d 20  .setlist(A) ::= 
4690: 6e 6d 28 58 29 20 45 51 20 65 78 70 72 28 59 29  nm(X) EQ expr(Y)
46a0: 2e 20 20 20 7b 41 20 3d 20 73 71 6c 69 74 65 33  .   {A = sqlite3
46b0: 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28 30  ExprListAppend(0
46c0: 2c 59 2c 26 58 29 3b 7d 0a 0a 2f 2f 2f 2f 2f 2f  ,Y,&X);}..//////
46d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
46e0: 2f 2f 2f 2f 20 54 68 65 20 49 4e 53 45 52 54 20  //// The INSERT 
46f0: 63 6f 6d 6d 61 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f  command ////////
4700: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
4710: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64  /////////.//.cmd
4720: 20 3a 3a 3d 20 69 6e 73 65 72 74 5f 63 6d 64 28   ::= insert_cmd(
4730: 52 29 20 49 4e 54 4f 20 6e 6d 28 58 29 20 64 62  R) INTO nm(X) db
4740: 6e 6d 28 44 29 20 69 6e 73 63 6f 6c 6c 69 73 74  nm(D) inscollist
4750: 5f 6f 70 74 28 46 29 20 0a 20 20 20 20 20 20 20  _opt(F) .       
4760: 20 56 41 4c 55 45 53 20 4c 50 20 69 74 65 6d 6c   VALUES LP iteml
4770: 69 73 74 28 59 29 20 52 50 2e 0a 20 20 20 20 20  ist(Y) RP..     
4780: 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33 49         {sqlite3I
4790: 6e 73 65 72 74 28 70 50 61 72 73 65 2c 20 73 71  nsert(pParse, sq
47a0: 6c 69 74 65 33 53 72 63 4c 69 73 74 41 70 70 65  lite3SrcListAppe
47b0: 6e 64 28 30 2c 26 58 2c 26 44 29 2c 20 59 2c 20  nd(0,&X,&D), Y, 
47c0: 30 2c 20 46 2c 20 52 29 3b 7d 0a 63 6d 64 20 3a  0, F, R);}.cmd :
47d0: 3a 3d 20 69 6e 73 65 72 74 5f 63 6d 64 28 52 29  := insert_cmd(R)
47e0: 20 49 4e 54 4f 20 6e 6d 28 58 29 20 64 62 6e 6d   INTO nm(X) dbnm
47f0: 28 44 29 20 69 6e 73 63 6f 6c 6c 69 73 74 5f 6f  (D) inscollist_o
4800: 70 74 28 46 29 20 73 65 6c 65 63 74 28 53 29 2e  pt(F) select(S).
4810: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 73 71  .            {sq
4820: 6c 69 74 65 33 49 6e 73 65 72 74 28 70 50 61 72  lite3Insert(pPar
4830: 73 65 2c 20 73 71 6c 69 74 65 33 53 72 63 4c 69  se, sqlite3SrcLi
4840: 73 74 41 70 70 65 6e 64 28 30 2c 26 58 2c 26 44  stAppend(0,&X,&D
4850: 29 2c 20 30 2c 20 53 2c 20 46 2c 20 52 29 3b 7d  ), 0, S, F, R);}
4860: 0a 0a 25 74 79 70 65 20 69 6e 73 65 72 74 5f 63  ..%type insert_c
4870: 6d 64 20 7b 69 6e 74 7d 0a 69 6e 73 65 72 74 5f  md {int}.insert_
4880: 63 6d 64 28 41 29 20 3a 3a 3d 20 49 4e 53 45 52  cmd(A) ::= INSER
4890: 54 20 6f 72 63 6f 6e 66 28 52 29 2e 20 20 20 7b  T orconf(R).   {
48a0: 41 20 3d 20 52 3b 7d 0a 69 6e 73 65 72 74 5f 63  A = R;}.insert_c
48b0: 6d 64 28 41 29 20 3a 3a 3d 20 52 45 50 4c 41 43  md(A) ::= REPLAC
48c0: 45 2e 20 20 20 20 20 20 20 20 20 20 20 20 7b 41  E.            {A
48d0: 20 3d 20 4f 45 5f 52 65 70 6c 61 63 65 3b 7d 0a   = OE_Replace;}.
48e0: 0a 0a 25 74 79 70 65 20 69 74 65 6d 6c 69 73 74  ..%type itemlist
48f0: 20 7b 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65   {ExprList*}.%de
4900: 73 74 72 75 63 74 6f 72 20 69 74 65 6d 6c 69 73  structor itemlis
4910: 74 20 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69  t {sqlite3ExprLi
4920: 73 74 44 65 6c 65 74 65 28 24 24 29 3b 7d 0a 0a  stDelete($$);}..
4930: 69 74 65 6d 6c 69 73 74 28 41 29 20 3a 3a 3d 20  itemlist(A) ::= 
4940: 69 74 65 6d 6c 69 73 74 28 58 29 20 43 4f 4d 4d  itemlist(X) COMM
4950: 41 20 65 78 70 72 28 59 29 2e 20 20 7b 41 20 3d  A expr(Y).  {A =
4960: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
4970: 41 70 70 65 6e 64 28 58 2c 59 2c 30 29 3b 7d 0a  Append(X,Y,0);}.
4980: 69 74 65 6d 6c 69 73 74 28 41 29 20 3a 3a 3d 20  itemlist(A) ::= 
4990: 65 78 70 72 28 58 29 2e 20 20 20 20 20 20 20 20  expr(X).        
49a0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d              {A =
49b0: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
49c0: 41 70 70 65 6e 64 28 30 2c 58 2c 30 29 3b 7d 0a  Append(0,X,0);}.
49d0: 0a 25 74 79 70 65 20 69 6e 73 63 6f 6c 6c 69 73  .%type inscollis
49e0: 74 5f 6f 70 74 20 7b 49 64 4c 69 73 74 2a 7d 0a  t_opt {IdList*}.
49f0: 25 64 65 73 74 72 75 63 74 6f 72 20 69 6e 73 63  %destructor insc
4a00: 6f 6c 6c 69 73 74 5f 6f 70 74 20 7b 73 71 6c 69  ollist_opt {sqli
4a10: 74 65 33 49 64 4c 69 73 74 44 65 6c 65 74 65 28  te3IdListDelete(
4a20: 24 24 29 3b 7d 0a 25 74 79 70 65 20 69 6e 73 63  $$);}.%type insc
4a30: 6f 6c 6c 69 73 74 20 7b 49 64 4c 69 73 74 2a 7d  ollist {IdList*}
4a40: 0a 25 64 65 73 74 72 75 63 74 6f 72 20 69 6e 73  .%destructor ins
4a50: 63 6f 6c 6c 69 73 74 20 7b 73 71 6c 69 74 65 33  collist {sqlite3
4a60: 49 64 4c 69 73 74 44 65 6c 65 74 65 28 24 24 29  IdListDelete($$)
4a70: 3b 7d 0a 0a 69 6e 73 63 6f 6c 6c 69 73 74 5f 6f  ;}..inscollist_o
4a80: 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20  pt(A) ::= .     
4a90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4aa0: 20 20 7b 41 20 3d 20 30 3b 7d 0a 69 6e 73 63 6f    {A = 0;}.insco
4ab0: 6c 6c 69 73 74 5f 6f 70 74 28 41 29 20 3a 3a 3d  llist_opt(A) ::=
4ac0: 20 4c 50 20 69 6e 73 63 6f 6c 6c 69 73 74 28 58   LP inscollist(X
4ad0: 29 20 52 50 2e 20 20 20 20 7b 41 20 3d 20 58 3b  ) RP.    {A = X;
4ae0: 7d 0a 69 6e 73 63 6f 6c 6c 69 73 74 28 41 29 20  }.inscollist(A) 
4af0: 3a 3a 3d 20 69 6e 73 63 6f 6c 6c 69 73 74 28 58  ::= inscollist(X
4b00: 29 20 43 4f 4d 4d 41 20 6e 6d 28 59 29 2e 20 20  ) COMMA nm(Y).  
4b10: 7b 41 20 3d 20 73 71 6c 69 74 65 33 49 64 4c 69  {A = sqlite3IdLi
4b20: 73 74 41 70 70 65 6e 64 28 58 2c 26 59 29 3b 7d  stAppend(X,&Y);}
4b30: 0a 69 6e 73 63 6f 6c 6c 69 73 74 28 41 29 20 3a  .inscollist(A) :
4b40: 3a 3d 20 6e 6d 28 59 29 2e 20 20 20 20 20 20 20  := nm(Y).       
4b50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
4b60: 41 20 3d 20 73 71 6c 69 74 65 33 49 64 4c 69 73  A = sqlite3IdLis
4b70: 74 41 70 70 65 6e 64 28 30 2c 26 59 29 3b 7d 0a  tAppend(0,&Y);}.
4b80: 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .///////////////
4b90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 45 78 70  //////////// Exp
4ba0: 72 65 73 73 69 6f 6e 20 50 72 6f 63 65 73 73 69  ression Processi
4bb0: 6e 67 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ng /////////////
4bc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
4bd0: 0a 2f 2f 0a 0a 25 74 79 70 65 20 65 78 70 72 20  .//..%type expr 
4be0: 7b 45 78 70 72 2a 7d 0a 25 64 65 73 74 72 75 63  {Expr*}.%destruc
4bf0: 74 6f 72 20 65 78 70 72 20 7b 73 71 6c 69 74 65  tor expr {sqlite
4c00: 33 45 78 70 72 44 65 6c 65 74 65 28 24 24 29 3b  3ExprDelete($$);
4c10: 7d 0a 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 4c  }..expr(A) ::= L
4c20: 50 28 42 29 20 65 78 70 72 28 58 29 20 52 50 28  P(B) expr(X) RP(
4c30: 45 29 2e 20 7b 41 20 3d 20 58 3b 20 73 71 6c 69  E). {A = X; sqli
4c40: 74 65 33 45 78 70 72 53 70 61 6e 28 41 2c 26 42  te3ExprSpan(A,&B
4c50: 2c 26 45 29 3b 20 7d 0a 65 78 70 72 28 41 29 20  ,&E); }.expr(A) 
4c60: 3a 3a 3d 20 4e 55 4c 4c 28 58 29 2e 20 20 20 20  ::= NULL(X).    
4c70: 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 73 71           {A = sq
4c80: 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 4e 55 4c  lite3Expr(TK_NUL
4c90: 4c 2c 20 30 2c 20 30 2c 20 26 58 29 3b 7d 0a 65  L, 0, 0, &X);}.e
4ca0: 78 70 72 28 41 29 20 3a 3a 3d 20 49 44 28 58 29  xpr(A) ::= ID(X)
4cb0: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4cc0: 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  {A = sqlite3Expr
4cd0: 28 54 4b 5f 49 44 2c 20 30 2c 20 30 2c 20 26 58  (TK_ID, 0, 0, &X
4ce0: 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20  );}.expr(A) ::= 
4cf0: 4a 4f 49 4e 5f 4b 57 28 58 29 2e 20 20 20 20 20  JOIN_KW(X).     
4d00: 20 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74 65       {A = sqlite
4d10: 33 45 78 70 72 28 54 4b 5f 49 44 2c 20 30 2c 20  3Expr(TK_ID, 0, 
4d20: 30 2c 20 26 58 29 3b 7d 0a 65 78 70 72 28 41 29  0, &X);}.expr(A)
4d30: 20 3a 3a 3d 20 6e 6d 28 58 29 20 44 4f 54 20 6e   ::= nm(X) DOT n
4d40: 6d 28 59 29 2e 20 7b 0a 20 20 45 78 70 72 20 2a  m(Y). {.  Expr *
4d50: 74 65 6d 70 31 20 3d 20 73 71 6c 69 74 65 33 45  temp1 = sqlite3E
4d60: 78 70 72 28 54 4b 5f 49 44 2c 20 30 2c 20 30 2c  xpr(TK_ID, 0, 0,
4d70: 20 26 58 29 3b 0a 20 20 45 78 70 72 20 2a 74 65   &X);.  Expr *te
4d80: 6d 70 32 20 3d 20 73 71 6c 69 74 65 33 45 78 70  mp2 = sqlite3Exp
4d90: 72 28 54 4b 5f 49 44 2c 20 30 2c 20 30 2c 20 26  r(TK_ID, 0, 0, &
4da0: 59 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65  Y);.  A = sqlite
4db0: 33 45 78 70 72 28 54 4b 5f 44 4f 54 2c 20 74 65  3Expr(TK_DOT, te
4dc0: 6d 70 31 2c 20 74 65 6d 70 32 2c 20 30 29 3b 0a  mp1, temp2, 0);.
4dd0: 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 6e 6d  }.expr(A) ::= nm
4de0: 28 58 29 20 44 4f 54 20 6e 6d 28 59 29 20 44 4f  (X) DOT nm(Y) DO
4df0: 54 20 6e 6d 28 5a 29 2e 20 7b 0a 20 20 45 78 70  T nm(Z). {.  Exp
4e00: 72 20 2a 74 65 6d 70 31 20 3d 20 73 71 6c 69 74  r *temp1 = sqlit
4e10: 65 33 45 78 70 72 28 54 4b 5f 49 44 2c 20 30 2c  e3Expr(TK_ID, 0,
4e20: 20 30 2c 20 26 58 29 3b 0a 20 20 45 78 70 72 20   0, &X);.  Expr 
4e30: 2a 74 65 6d 70 32 20 3d 20 73 71 6c 69 74 65 33  *temp2 = sqlite3
4e40: 45 78 70 72 28 54 4b 5f 49 44 2c 20 30 2c 20 30  Expr(TK_ID, 0, 0
4e50: 2c 20 26 59 29 3b 0a 20 20 45 78 70 72 20 2a 74  , &Y);.  Expr *t
4e60: 65 6d 70 33 20 3d 20 73 71 6c 69 74 65 33 45 78  emp3 = sqlite3Ex
4e70: 70 72 28 54 4b 5f 49 44 2c 20 30 2c 20 30 2c 20  pr(TK_ID, 0, 0, 
4e80: 26 5a 29 3b 0a 20 20 45 78 70 72 20 2a 74 65 6d  &Z);.  Expr *tem
4e90: 70 34 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  p4 = sqlite3Expr
4ea0: 28 54 4b 5f 44 4f 54 2c 20 74 65 6d 70 32 2c 20  (TK_DOT, temp2, 
4eb0: 74 65 6d 70 33 2c 20 30 29 3b 0a 20 20 41 20 3d  temp3, 0);.  A =
4ec0: 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f   sqlite3Expr(TK_
4ed0: 44 4f 54 2c 20 74 65 6d 70 31 2c 20 74 65 6d 70  DOT, temp1, temp
4ee0: 34 2c 20 30 29 3b 0a 7d 0a 65 78 70 72 28 41 29  4, 0);.}.expr(A)
4ef0: 20 3a 3a 3d 20 49 4e 54 45 47 45 52 28 58 29 2e   ::= INTEGER(X).
4f00: 20 20 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74        {A = sqlit
4f10: 65 33 45 78 70 72 28 54 4b 5f 49 4e 54 45 47 45  e3Expr(TK_INTEGE
4f20: 52 2c 20 30 2c 20 30 2c 20 26 58 29 3b 7d 0a 65  R, 0, 0, &X);}.e
4f30: 78 70 72 28 41 29 20 3a 3a 3d 20 46 4c 4f 41 54  xpr(A) ::= FLOAT
4f40: 28 58 29 2e 20 20 20 20 20 20 20 20 7b 41 20 3d  (X).        {A =
4f50: 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f   sqlite3Expr(TK_
4f60: 46 4c 4f 41 54 2c 20 30 2c 20 30 2c 20 26 58 29  FLOAT, 0, 0, &X)
4f70: 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 53  ;}.expr(A) ::= S
4f80: 54 52 49 4e 47 28 58 29 2e 20 20 20 20 20 20 20  TRING(X).       
4f90: 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  {A = sqlite3Expr
4fa0: 28 54 4b 5f 53 54 52 49 4e 47 2c 20 30 2c 20 30  (TK_STRING, 0, 0
4fb0: 2c 20 26 58 29 3b 7d 0a 65 78 70 72 28 41 29 20  , &X);}.expr(A) 
4fc0: 3a 3a 3d 20 56 41 52 49 41 42 4c 45 28 58 29 2e  ::= VARIABLE(X).
4fd0: 20 20 20 20 20 7b 0a 20 20 41 20 3d 20 73 71 6c       {.  A = sql
4fe0: 69 74 65 33 45 78 70 72 28 54 4b 5f 56 41 52 49  ite3Expr(TK_VARI
4ff0: 41 42 4c 45 2c 20 30 2c 20 30 2c 20 26 58 29 3b  ABLE, 0, 0, &X);
5000: 0a 20 20 69 66 28 20 41 20 29 20 41 2d 3e 69 54  .  if( A ) A->iT
5010: 61 62 6c 65 20 3d 20 2b 2b 70 50 61 72 73 65 2d  able = ++pParse-
5020: 3e 6e 56 61 72 3b 0a 7d 0a 65 78 70 72 28 41 29  >nVar;.}.expr(A)
5030: 20 3a 3a 3d 20 49 44 28 58 29 20 4c 50 20 65 78   ::= ID(X) LP ex
5040: 70 72 6c 69 73 74 28 59 29 20 52 50 28 45 29 2e  prlist(Y) RP(E).
5050: 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33   {.  A = sqlite3
5060: 45 78 70 72 46 75 6e 63 74 69 6f 6e 28 59 2c 20  ExprFunction(Y, 
5070: 26 58 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78  &X);.  sqlite3Ex
5080: 70 72 53 70 61 6e 28 41 2c 26 58 2c 26 45 29 3b  prSpan(A,&X,&E);
5090: 0a 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 49  .}.expr(A) ::= I
50a0: 44 28 58 29 20 4c 50 20 53 54 41 52 20 52 50 28  D(X) LP STAR RP(
50b0: 45 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69  E). {.  A = sqli
50c0: 74 65 33 45 78 70 72 46 75 6e 63 74 69 6f 6e 28  te3ExprFunction(
50d0: 30 2c 20 26 58 29 3b 0a 20 20 73 71 6c 69 74 65  0, &X);.  sqlite
50e0: 33 45 78 70 72 53 70 61 6e 28 41 2c 26 58 2c 26  3ExprSpan(A,&X,&
50f0: 45 29 3b 0a 7d 0a 65 78 70 72 28 41 29 20 3a 3a  E);.}.expr(A) ::
5100: 3d 20 65 78 70 72 28 58 29 20 41 4e 44 20 65 78  = expr(X) AND ex
5110: 70 72 28 59 29 2e 20 20 20 7b 41 20 3d 20 73 71  pr(Y).   {A = sq
5120: 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 41 4e 44  lite3Expr(TK_AND
5130: 2c 20 58 2c 20 59 2c 20 30 29 3b 7d 0a 65 78 70  , X, Y, 0);}.exp
5140: 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29  r(A) ::= expr(X)
5150: 20 4f 52 20 65 78 70 72 28 59 29 2e 20 20 20 20   OR expr(Y).    
5160: 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  {A = sqlite3Expr
5170: 28 54 4b 5f 4f 52 2c 20 58 2c 20 59 2c 20 30 29  (TK_OR, X, Y, 0)
5180: 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65  ;}.expr(A) ::= e
5190: 78 70 72 28 58 29 20 4c 54 20 65 78 70 72 28 59  xpr(X) LT expr(Y
51a0: 29 2e 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74  ).    {A = sqlit
51b0: 65 33 45 78 70 72 28 54 4b 5f 4c 54 2c 20 58 2c  e3Expr(TK_LT, X,
51c0: 20 59 2c 20 30 29 3b 7d 0a 65 78 70 72 28 41 29   Y, 0);}.expr(A)
51d0: 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 47 54 20   ::= expr(X) GT 
51e0: 65 78 70 72 28 59 29 2e 20 20 20 20 7b 41 20 3d  expr(Y).    {A =
51f0: 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f   sqlite3Expr(TK_
5200: 47 54 2c 20 58 2c 20 59 2c 20 30 29 3b 7d 0a 65  GT, X, Y, 0);}.e
5210: 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28  xpr(A) ::= expr(
5220: 58 29 20 4c 45 20 65 78 70 72 28 59 29 2e 20 20  X) LE expr(Y).  
5230: 20 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78    {A = sqlite3Ex
5240: 70 72 28 54 4b 5f 4c 45 2c 20 58 2c 20 59 2c 20  pr(TK_LE, X, Y, 
5250: 30 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d  0);}.expr(A) ::=
5260: 20 65 78 70 72 28 58 29 20 47 45 20 65 78 70 72   expr(X) GE expr
5270: 28 59 29 2e 20 20 20 20 7b 41 20 3d 20 73 71 6c  (Y).    {A = sql
5280: 69 74 65 33 45 78 70 72 28 54 4b 5f 47 45 2c 20  ite3Expr(TK_GE, 
5290: 58 2c 20 59 2c 20 30 29 3b 7d 0a 65 78 70 72 28  X, Y, 0);}.expr(
52a0: 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 4e  A) ::= expr(X) N
52b0: 45 20 65 78 70 72 28 59 29 2e 20 20 20 20 7b 41  E expr(Y).    {A
52c0: 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28 54   = sqlite3Expr(T
52d0: 4b 5f 4e 45 2c 20 58 2c 20 59 2c 20 30 29 3b 7d  K_NE, X, Y, 0);}
52e0: 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70  .expr(A) ::= exp
52f0: 72 28 58 29 20 45 51 20 65 78 70 72 28 59 29 2e  r(X) EQ expr(Y).
5300: 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74 65 33      {A = sqlite3
5310: 45 78 70 72 28 54 4b 5f 45 51 2c 20 58 2c 20 59  Expr(TK_EQ, X, Y
5320: 2c 20 30 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a  , 0);}.expr(A) :
5330: 3a 3d 20 65 78 70 72 28 58 29 20 42 49 54 41 4e  := expr(X) BITAN
5340: 44 20 65 78 70 72 28 59 29 2e 20 7b 41 20 3d 20  D expr(Y). {A = 
5350: 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 42  sqlite3Expr(TK_B
5360: 49 54 41 4e 44 2c 20 58 2c 20 59 2c 20 30 29 3b  ITAND, X, Y, 0);
5370: 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78  }.expr(A) ::= ex
5380: 70 72 28 58 29 20 42 49 54 4f 52 20 65 78 70 72  pr(X) BITOR expr
5390: 28 59 29 2e 20 20 7b 41 20 3d 20 73 71 6c 69 74  (Y).  {A = sqlit
53a0: 65 33 45 78 70 72 28 54 4b 5f 42 49 54 4f 52 2c  e3Expr(TK_BITOR,
53b0: 20 58 2c 20 59 2c 20 30 29 3b 7d 0a 65 78 70 72   X, Y, 0);}.expr
53c0: 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20  (A) ::= expr(X) 
53d0: 4c 53 48 49 46 54 20 65 78 70 72 28 59 29 2e 20  LSHIFT expr(Y). 
53e0: 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  {A = sqlite3Expr
53f0: 28 54 4b 5f 4c 53 48 49 46 54 2c 20 58 2c 20 59  (TK_LSHIFT, X, Y
5400: 2c 20 30 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a  , 0);}.expr(A) :
5410: 3a 3d 20 65 78 70 72 28 58 29 20 52 53 48 49 46  := expr(X) RSHIF
5420: 54 20 65 78 70 72 28 59 29 2e 20 7b 41 20 3d 20  T expr(Y). {A = 
5430: 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 52  sqlite3Expr(TK_R
5440: 53 48 49 46 54 2c 20 58 2c 20 59 2c 20 30 29 3b  SHIFT, X, Y, 0);
5450: 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78  }.expr(A) ::= ex
5460: 70 72 28 58 29 20 6c 69 6b 65 6f 70 28 4f 50 29  pr(X) likeop(OP)
5470: 20 65 78 70 72 28 59 29 2e 20 20 5b 4c 49 4b 45   expr(Y).  [LIKE
5480: 5d 20 20 7b 0a 20 20 45 78 70 72 4c 69 73 74 20  ]  {.  ExprList 
5490: 2a 70 4c 69 73 74 20 3d 20 73 71 6c 69 74 65 33  *pList = sqlite3
54a0: 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28 30  ExprListAppend(0
54b0: 2c 20 59 2c 20 30 29 3b 0a 20 20 70 4c 69 73 74  , Y, 0);.  pList
54c0: 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69   = sqlite3ExprLi
54d0: 73 74 41 70 70 65 6e 64 28 70 4c 69 73 74 2c 20  stAppend(pList, 
54e0: 58 2c 20 30 29 3b 0a 20 20 41 20 3d 20 73 71 6c  X, 0);.  A = sql
54f0: 69 74 65 33 45 78 70 72 46 75 6e 63 74 69 6f 6e  ite3ExprFunction
5500: 28 70 4c 69 73 74 2c 20 30 29 3b 0a 20 20 69 66  (pList, 0);.  if
5510: 28 20 41 20 29 20 41 2d 3e 6f 70 20 3d 20 4f 50  ( A ) A->op = OP
5520: 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 53  ;.  sqlite3ExprS
5530: 70 61 6e 28 41 2c 20 26 58 2d 3e 73 70 61 6e 2c  pan(A, &X->span,
5540: 20 26 59 2d 3e 73 70 61 6e 29 3b 0a 7d 0a 65 78   &Y->span);.}.ex
5550: 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58  pr(A) ::= expr(X
5560: 29 20 4e 4f 54 20 6c 69 6b 65 6f 70 28 4f 50 29  ) NOT likeop(OP)
5570: 20 65 78 70 72 28 59 29 2e 20 5b 4c 49 4b 45 5d   expr(Y). [LIKE]
5580: 20 7b 0a 20 20 45 78 70 72 4c 69 73 74 20 2a 70   {.  ExprList *p
5590: 4c 69 73 74 20 3d 20 73 71 6c 69 74 65 33 45 78  List = sqlite3Ex
55a0: 70 72 4c 69 73 74 41 70 70 65 6e 64 28 30 2c 20  prListAppend(0, 
55b0: 59 2c 20 30 29 3b 0a 20 20 70 4c 69 73 74 20 3d  Y, 0);.  pList =
55c0: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
55d0: 41 70 70 65 6e 64 28 70 4c 69 73 74 2c 20 58 2c  Append(pList, X,
55e0: 20 30 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74   0);.  A = sqlit
55f0: 65 33 45 78 70 72 46 75 6e 63 74 69 6f 6e 28 70  e3ExprFunction(p
5600: 4c 69 73 74 2c 20 30 29 3b 0a 20 20 69 66 28 20  List, 0);.  if( 
5610: 41 20 29 20 41 2d 3e 6f 70 20 3d 20 4f 50 3b 0a  A ) A->op = OP;.
5620: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
5630: 72 28 54 4b 5f 4e 4f 54 2c 20 41 2c 20 30 2c 20  r(TK_NOT, A, 0, 
5640: 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70  0);.  sqlite3Exp
5650: 72 53 70 61 6e 28 41 2c 26 58 2d 3e 73 70 61 6e  rSpan(A,&X->span
5660: 2c 26 59 2d 3e 73 70 61 6e 29 3b 0a 7d 0a 25 74  ,&Y->span);.}.%t
5670: 79 70 65 20 6c 69 6b 65 6f 70 20 7b 69 6e 74 7d  ype likeop {int}
5680: 0a 6c 69 6b 65 6f 70 28 41 29 20 3a 3a 3d 20 4c  .likeop(A) ::= L
5690: 49 4b 45 2e 20 7b 41 20 3d 20 54 4b 5f 4c 49 4b  IKE. {A = TK_LIK
56a0: 45 3b 7d 0a 6c 69 6b 65 6f 70 28 41 29 20 3a 3a  E;}.likeop(A) ::
56b0: 3d 20 47 4c 4f 42 2e 20 7b 41 20 3d 20 54 4b 5f  = GLOB. {A = TK_
56c0: 47 4c 4f 42 3b 7d 0a 65 78 70 72 28 41 29 20 3a  GLOB;}.expr(A) :
56d0: 3a 3d 20 65 78 70 72 28 58 29 20 50 4c 55 53 20  := expr(X) PLUS 
56e0: 65 78 70 72 28 59 29 2e 20 20 7b 41 20 3d 20 73  expr(Y).  {A = s
56f0: 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 50 4c  qlite3Expr(TK_PL
5700: 55 53 2c 20 58 2c 20 59 2c 20 30 29 3b 7d 0a 65  US, X, Y, 0);}.e
5710: 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28  xpr(A) ::= expr(
5720: 58 29 20 4d 49 4e 55 53 20 65 78 70 72 28 59 29  X) MINUS expr(Y)
5730: 2e 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78  . {A = sqlite3Ex
5740: 70 72 28 54 4b 5f 4d 49 4e 55 53 2c 20 58 2c 20  pr(TK_MINUS, X, 
5750: 59 2c 20 30 29 3b 7d 0a 65 78 70 72 28 41 29 20  Y, 0);}.expr(A) 
5760: 3a 3a 3d 20 65 78 70 72 28 58 29 20 53 54 41 52  ::= expr(X) STAR
5770: 20 65 78 70 72 28 59 29 2e 20 20 7b 41 20 3d 20   expr(Y).  {A = 
5780: 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 53  sqlite3Expr(TK_S
5790: 54 41 52 2c 20 58 2c 20 59 2c 20 30 29 3b 7d 0a  TAR, X, Y, 0);}.
57a0: 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72  expr(A) ::= expr
57b0: 28 58 29 20 53 4c 41 53 48 20 65 78 70 72 28 59  (X) SLASH expr(Y
57c0: 29 2e 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 45  ). {A = sqlite3E
57d0: 78 70 72 28 54 4b 5f 53 4c 41 53 48 2c 20 58 2c  xpr(TK_SLASH, X,
57e0: 20 59 2c 20 30 29 3b 7d 0a 65 78 70 72 28 41 29   Y, 0);}.expr(A)
57f0: 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 52 45 4d   ::= expr(X) REM
5800: 20 65 78 70 72 28 59 29 2e 20 20 20 7b 41 20 3d   expr(Y).   {A =
5810: 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f   sqlite3Expr(TK_
5820: 52 45 4d 2c 20 58 2c 20 59 2c 20 30 29 3b 7d 0a  REM, X, Y, 0);}.
5830: 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72  expr(A) ::= expr
5840: 28 58 29 20 43 4f 4e 43 41 54 20 65 78 70 72 28  (X) CONCAT expr(
5850: 59 29 2e 20 7b 41 20 3d 20 73 71 6c 69 74 65 33  Y). {A = sqlite3
5860: 45 78 70 72 28 54 4b 5f 43 4f 4e 43 41 54 2c 20  Expr(TK_CONCAT, 
5870: 58 2c 20 59 2c 20 30 29 3b 7d 0a 65 78 70 72 28  X, Y, 0);}.expr(
5880: 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 49  A) ::= expr(X) I
5890: 53 4e 55 4c 4c 28 45 29 2e 20 7b 0a 20 20 41 20  SNULL(E). {.  A 
58a0: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b  = sqlite3Expr(TK
58b0: 5f 49 53 4e 55 4c 4c 2c 20 58 2c 20 30 2c 20 30  _ISNULL, X, 0, 0
58c0: 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72  );.  sqlite3Expr
58d0: 53 70 61 6e 28 41 2c 26 58 2d 3e 73 70 61 6e 2c  Span(A,&X->span,
58e0: 26 45 29 3b 0a 7d 0a 65 78 70 72 28 41 29 20 3a  &E);.}.expr(A) :
58f0: 3a 3d 20 65 78 70 72 28 58 29 20 49 53 20 4e 55  := expr(X) IS NU
5900: 4c 4c 28 45 29 2e 20 7b 0a 20 20 41 20 3d 20 73  LL(E). {.  A = s
5910: 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 49 53  qlite3Expr(TK_IS
5920: 4e 55 4c 4c 2c 20 58 2c 20 30 2c 20 30 29 3b 0a  NULL, X, 0, 0);.
5930: 20 20 73 71 6c 69 74 65 33 45 78 70 72 53 70 61    sqlite3ExprSpa
5940: 6e 28 41 2c 26 58 2d 3e 73 70 61 6e 2c 26 45 29  n(A,&X->span,&E)
5950: 3b 0a 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20  ;.}.expr(A) ::= 
5960: 65 78 70 72 28 58 29 20 4e 4f 54 4e 55 4c 4c 28  expr(X) NOTNULL(
5970: 45 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69  E). {.  A = sqli
5980: 74 65 33 45 78 70 72 28 54 4b 5f 4e 4f 54 4e 55  te3Expr(TK_NOTNU
5990: 4c 4c 2c 20 58 2c 20 30 2c 20 30 29 3b 0a 20 20  LL, X, 0, 0);.  
59a0: 73 71 6c 69 74 65 33 45 78 70 72 53 70 61 6e 28  sqlite3ExprSpan(
59b0: 41 2c 26 58 2d 3e 73 70 61 6e 2c 26 45 29 3b 0a  A,&X->span,&E);.
59c0: 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78  }.expr(A) ::= ex
59d0: 70 72 28 58 29 20 4e 4f 54 20 4e 55 4c 4c 28 45  pr(X) NOT NULL(E
59e0: 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69 74  ). {.  A = sqlit
59f0: 65 33 45 78 70 72 28 54 4b 5f 4e 4f 54 4e 55 4c  e3Expr(TK_NOTNUL
5a00: 4c 2c 20 58 2c 20 30 2c 20 30 29 3b 0a 20 20 73  L, X, 0, 0);.  s
5a10: 71 6c 69 74 65 33 45 78 70 72 53 70 61 6e 28 41  qlite3ExprSpan(A
5a20: 2c 26 58 2d 3e 73 70 61 6e 2c 26 45 29 3b 0a 7d  ,&X->span,&E);.}
5a30: 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70  .expr(A) ::= exp
5a40: 72 28 58 29 20 49 53 20 4e 4f 54 20 4e 55 4c 4c  r(X) IS NOT NULL
5a50: 28 45 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c  (E). {.  A = sql
5a60: 69 74 65 33 45 78 70 72 28 54 4b 5f 4e 4f 54 4e  ite3Expr(TK_NOTN
5a70: 55 4c 4c 2c 20 58 2c 20 30 2c 20 30 29 3b 0a 20  ULL, X, 0, 0);. 
5a80: 20 73 71 6c 69 74 65 33 45 78 70 72 53 70 61 6e   sqlite3ExprSpan
5a90: 28 41 2c 26 58 2d 3e 73 70 61 6e 2c 26 45 29 3b  (A,&X->span,&E);
5aa0: 0a 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 4e  .}.expr(A) ::= N
5ab0: 4f 54 28 42 29 20 65 78 70 72 28 58 29 2e 20 7b  OT(B) expr(X). {
5ac0: 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78  .  A = sqlite3Ex
5ad0: 70 72 28 54 4b 5f 4e 4f 54 2c 20 58 2c 20 30 2c  pr(TK_NOT, X, 0,
5ae0: 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78   0);.  sqlite3Ex
5af0: 70 72 53 70 61 6e 28 41 2c 26 42 2c 26 58 2d 3e  prSpan(A,&B,&X->
5b00: 73 70 61 6e 29 3b 0a 7d 0a 65 78 70 72 28 41 29  span);.}.expr(A)
5b10: 20 3a 3a 3d 20 42 49 54 4e 4f 54 28 42 29 20 65   ::= BITNOT(B) e
5b20: 78 70 72 28 58 29 2e 20 7b 0a 20 20 41 20 3d 20  xpr(X). {.  A = 
5b30: 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 42  sqlite3Expr(TK_B
5b40: 49 54 4e 4f 54 2c 20 58 2c 20 30 2c 20 30 29 3b  ITNOT, X, 0, 0);
5b50: 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 53 70  .  sqlite3ExprSp
5b60: 61 6e 28 41 2c 26 42 2c 26 58 2d 3e 73 70 61 6e  an(A,&B,&X->span
5b70: 29 3b 0a 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d  );.}.expr(A) ::=
5b80: 20 4d 49 4e 55 53 28 42 29 20 65 78 70 72 28 58   MINUS(B) expr(X
5b90: 29 2e 20 5b 55 4d 49 4e 55 53 5d 20 7b 0a 20 20  ). [UMINUS] {.  
5ba0: 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28  A = sqlite3Expr(
5bb0: 54 4b 5f 55 4d 49 4e 55 53 2c 20 58 2c 20 30 2c  TK_UMINUS, X, 0,
5bc0: 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78   0);.  sqlite3Ex
5bd0: 70 72 53 70 61 6e 28 41 2c 26 42 2c 26 58 2d 3e  prSpan(A,&B,&X->
5be0: 73 70 61 6e 29 3b 0a 7d 0a 65 78 70 72 28 41 29  span);.}.expr(A)
5bf0: 20 3a 3a 3d 20 50 4c 55 53 28 42 29 20 65 78 70   ::= PLUS(B) exp
5c00: 72 28 58 29 2e 20 5b 55 50 4c 55 53 5d 20 7b 0a  r(X). [UPLUS] {.
5c10: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
5c20: 72 28 54 4b 5f 55 50 4c 55 53 2c 20 58 2c 20 30  r(TK_UPLUS, X, 0
5c30: 2c 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 45  , 0);.  sqlite3E
5c40: 78 70 72 53 70 61 6e 28 41 2c 26 42 2c 26 58 2d  xprSpan(A,&B,&X-
5c50: 3e 73 70 61 6e 29 3b 0a 7d 0a 65 78 70 72 28 41  >span);.}.expr(A
5c60: 29 20 3a 3a 3d 20 4c 50 28 42 29 20 73 65 6c 65  ) ::= LP(B) sele
5c70: 63 74 28 58 29 20 52 50 28 45 29 2e 20 7b 0a 20  ct(X) RP(E). {. 
5c80: 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72   A = sqlite3Expr
5c90: 28 54 4b 5f 53 45 4c 45 43 54 2c 20 30 2c 20 30  (TK_SELECT, 0, 0
5ca0: 2c 20 30 29 3b 0a 20 20 69 66 28 20 41 20 29 20  , 0);.  if( A ) 
5cb0: 41 2d 3e 70 53 65 6c 65 63 74 20 3d 20 58 3b 0a  A->pSelect = X;.
5cc0: 20 20 73 71 6c 69 74 65 33 45 78 70 72 53 70 61    sqlite3ExprSpa
5cd0: 6e 28 41 2c 26 42 2c 26 45 29 3b 0a 7d 0a 65 78  n(A,&B,&E);.}.ex
5ce0: 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 57  pr(A) ::= expr(W
5cf0: 29 20 42 45 54 57 45 45 4e 20 65 78 70 72 28 58  ) BETWEEN expr(X
5d00: 29 20 41 4e 44 20 65 78 70 72 28 59 29 2e 20 7b  ) AND expr(Y). {
5d10: 0a 20 20 45 78 70 72 4c 69 73 74 20 2a 70 4c 69  .  ExprList *pLi
5d20: 73 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  st = sqlite3Expr
5d30: 4c 69 73 74 41 70 70 65 6e 64 28 30 2c 20 58 2c  ListAppend(0, X,
5d40: 20 30 29 3b 0a 20 20 70 4c 69 73 74 20 3d 20 73   0);.  pList = s
5d50: 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 41 70  qlite3ExprListAp
5d60: 70 65 6e 64 28 70 4c 69 73 74 2c 20 59 2c 20 30  pend(pList, Y, 0
5d70: 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33  );.  A = sqlite3
5d80: 45 78 70 72 28 54 4b 5f 42 45 54 57 45 45 4e 2c  Expr(TK_BETWEEN,
5d90: 20 57 2c 20 30 2c 20 30 29 3b 0a 20 20 69 66 28   W, 0, 0);.  if(
5da0: 20 41 20 29 20 41 2d 3e 70 4c 69 73 74 20 3d 20   A ) A->pList = 
5db0: 70 4c 69 73 74 3b 0a 20 20 73 71 6c 69 74 65 33  pList;.  sqlite3
5dc0: 45 78 70 72 53 70 61 6e 28 41 2c 26 57 2d 3e 73  ExprSpan(A,&W->s
5dd0: 70 61 6e 2c 26 59 2d 3e 73 70 61 6e 29 3b 0a 7d  pan,&Y->span);.}
5de0: 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70  .expr(A) ::= exp
5df0: 72 28 57 29 20 4e 4f 54 20 42 45 54 57 45 45 4e  r(W) NOT BETWEEN
5e00: 20 65 78 70 72 28 58 29 20 41 4e 44 20 65 78 70   expr(X) AND exp
5e10: 72 28 59 29 2e 20 7b 0a 20 20 45 78 70 72 4c 69  r(Y). {.  ExprLi
5e20: 73 74 20 2a 70 4c 69 73 74 20 3d 20 73 71 6c 69  st *pList = sqli
5e30: 74 65 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e  te3ExprListAppen
5e40: 64 28 30 2c 20 58 2c 20 30 29 3b 0a 20 20 70 4c  d(0, X, 0);.  pL
5e50: 69 73 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70  ist = sqlite3Exp
5e60: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 4c 69 73  rListAppend(pLis
5e70: 74 2c 20 59 2c 20 30 29 3b 0a 20 20 41 20 3d 20  t, Y, 0);.  A = 
5e80: 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 42  sqlite3Expr(TK_B
5e90: 45 54 57 45 45 4e 2c 20 57 2c 20 30 2c 20 30 29  ETWEEN, W, 0, 0)
5ea0: 3b 0a 20 20 69 66 28 20 41 20 29 20 41 2d 3e 70  ;.  if( A ) A->p
5eb0: 4c 69 73 74 20 3d 20 70 4c 69 73 74 3b 0a 20 20  List = pList;.  
5ec0: 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28  A = sqlite3Expr(
5ed0: 54 4b 5f 4e 4f 54 2c 20 41 2c 20 30 2c 20 30 29  TK_NOT, A, 0, 0)
5ee0: 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 53  ;.  sqlite3ExprS
5ef0: 70 61 6e 28 41 2c 26 57 2d 3e 73 70 61 6e 2c 26  pan(A,&W->span,&
5f00: 59 2d 3e 73 70 61 6e 29 3b 0a 7d 0a 65 78 70 72  Y->span);.}.expr
5f10: 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20  (A) ::= expr(X) 
5f20: 49 4e 20 4c 50 20 65 78 70 72 6c 69 73 74 28 59  IN LP exprlist(Y
5f30: 29 20 52 50 28 45 29 2e 20 20 7b 0a 20 20 41 20  ) RP(E).  {.  A 
5f40: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b  = sqlite3Expr(TK
5f50: 5f 49 4e 2c 20 58 2c 20 30 2c 20 30 29 3b 0a 20  _IN, X, 0, 0);. 
5f60: 20 69 66 28 20 41 20 29 20 41 2d 3e 70 4c 69 73   if( A ) A->pLis
5f70: 74 20 3d 20 59 3b 0a 20 20 73 71 6c 69 74 65 33  t = Y;.  sqlite3
5f80: 45 78 70 72 53 70 61 6e 28 41 2c 26 58 2d 3e 73  ExprSpan(A,&X->s
5f90: 70 61 6e 2c 26 45 29 3b 0a 7d 0a 65 78 70 72 28  pan,&E);.}.expr(
5fa0: 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 49  A) ::= expr(X) I
5fb0: 4e 20 4c 50 20 73 65 6c 65 63 74 28 59 29 20 52  N LP select(Y) R
5fc0: 50 28 45 29 2e 20 20 7b 0a 20 20 41 20 3d 20 73  P(E).  {.  A = s
5fd0: 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 49 4e  qlite3Expr(TK_IN
5fe0: 2c 20 58 2c 20 30 2c 20 30 29 3b 0a 20 20 69 66  , X, 0, 0);.  if
5ff0: 28 20 41 20 29 20 41 2d 3e 70 53 65 6c 65 63 74  ( A ) A->pSelect
6000: 20 3d 20 59 3b 0a 20 20 73 71 6c 69 74 65 33 45   = Y;.  sqlite3E
6010: 78 70 72 53 70 61 6e 28 41 2c 26 58 2d 3e 73 70  xprSpan(A,&X->sp
6020: 61 6e 2c 26 45 29 3b 0a 7d 0a 65 78 70 72 28 41  an,&E);.}.expr(A
6030: 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 4e 4f  ) ::= expr(X) NO
6040: 54 20 49 4e 20 4c 50 20 65 78 70 72 6c 69 73 74  T IN LP exprlist
6050: 28 59 29 20 52 50 28 45 29 2e 20 20 7b 0a 20 20  (Y) RP(E).  {.  
6060: 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28  A = sqlite3Expr(
6070: 54 4b 5f 49 4e 2c 20 58 2c 20 30 2c 20 30 29 3b  TK_IN, X, 0, 0);
6080: 0a 20 20 69 66 28 20 41 20 29 20 41 2d 3e 70 4c  .  if( A ) A->pL
6090: 69 73 74 20 3d 20 59 3b 0a 20 20 41 20 3d 20 73  ist = Y;.  A = s
60a0: 71 6c 69 74 65 33 45 78 70 72 28 54 4b 5f 4e 4f  qlite3Expr(TK_NO
60b0: 54 2c 20 41 2c 20 30 2c 20 30 29 3b 0a 20 20 73  T, A, 0, 0);.  s
60c0: 71 6c 69 74 65 33 45 78 70 72 53 70 61 6e 28 41  qlite3ExprSpan(A
60d0: 2c 26 58 2d 3e 73 70 61 6e 2c 26 45 29 3b 0a 7d  ,&X->span,&E);.}
60e0: 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70  .expr(A) ::= exp
60f0: 72 28 58 29 20 4e 4f 54 20 49 4e 20 4c 50 20 73  r(X) NOT IN LP s
6100: 65 6c 65 63 74 28 59 29 20 52 50 28 45 29 2e 20  elect(Y) RP(E). 
6110: 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33   {.  A = sqlite3
6120: 45 78 70 72 28 54 4b 5f 49 4e 2c 20 58 2c 20 30  Expr(TK_IN, X, 0
6130: 2c 20 30 29 3b 0a 20 20 69 66 28 20 41 20 29 20  , 0);.  if( A ) 
6140: 41 2d 3e 70 53 65 6c 65 63 74 20 3d 20 59 3b 0a  A->pSelect = Y;.
6150: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
6160: 72 28 54 4b 5f 4e 4f 54 2c 20 41 2c 20 30 2c 20  r(TK_NOT, A, 0, 
6170: 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70  0);.  sqlite3Exp
6180: 72 53 70 61 6e 28 41 2c 26 58 2d 3e 73 70 61 6e  rSpan(A,&X->span
6190: 2c 26 45 29 3b 0a 7d 0a 65 78 70 72 28 41 29 20  ,&E);.}.expr(A) 
61a0: 3a 3a 3d 20 65 78 70 72 28 58 29 20 49 4e 20 6e  ::= expr(X) IN n
61b0: 6d 28 59 29 20 64 62 6e 6d 28 44 29 2e 20 7b 0a  m(Y) dbnm(D). {.
61c0: 20 20 53 72 63 4c 69 73 74 20 2a 70 53 72 63 20    SrcList *pSrc 
61d0: 3d 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74  = sqlite3SrcList
61e0: 41 70 70 65 6e 64 28 30 2c 20 26 59 2c 20 26 44  Append(0, &Y, &D
61f0: 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33  );.  A = sqlite3
6200: 45 78 70 72 28 54 4b 5f 49 4e 2c 20 58 2c 20 30  Expr(TK_IN, X, 0
6210: 2c 20 30 29 3b 0a 20 20 69 66 28 20 41 20 29 20  , 0);.  if( A ) 
6220: 41 2d 3e 70 53 65 6c 65 63 74 20 3d 20 73 71 6c  A->pSelect = sql
6230: 69 74 65 33 53 65 6c 65 63 74 4e 65 77 28 30 2c  ite3SelectNew(0,
6240: 70 53 72 63 2c 30 2c 30 2c 30 2c 30 2c 30 2c 2d  pSrc,0,0,0,0,0,-
6250: 31 2c 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 45  1,0);.  sqlite3E
6260: 78 70 72 53 70 61 6e 28 41 2c 26 58 2d 3e 73 70  xprSpan(A,&X->sp
6270: 61 6e 2c 44 2e 7a 3f 26 44 3a 26 59 29 3b 0a 7d  an,D.z?&D:&Y);.}
6280: 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70  .expr(A) ::= exp
6290: 72 28 58 29 20 4e 4f 54 20 49 4e 20 6e 6d 28 59  r(X) NOT IN nm(Y
62a0: 29 20 64 62 6e 6d 28 44 29 2e 20 7b 0a 20 20 53  ) dbnm(D). {.  S
62b0: 72 63 4c 69 73 74 20 2a 70 53 72 63 20 3d 20 73  rcList *pSrc = s
62c0: 71 6c 69 74 65 33 53 72 63 4c 69 73 74 41 70 70  qlite3SrcListApp
62d0: 65 6e 64 28 30 2c 20 26 59 2c 20 26 44 29 3b 0a  end(0, &Y, &D);.
62e0: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
62f0: 72 28 54 4b 5f 49 4e 2c 20 58 2c 20 30 2c 20 30  r(TK_IN, X, 0, 0
6300: 29 3b 0a 20 20 69 66 28 20 41 20 29 20 41 2d 3e  );.  if( A ) A->
6310: 70 53 65 6c 65 63 74 20 3d 20 73 71 6c 69 74 65  pSelect = sqlite
6320: 33 53 65 6c 65 63 74 4e 65 77 28 30 2c 70 53 72  3SelectNew(0,pSr
6330: 63 2c 30 2c 30 2c 30 2c 30 2c 30 2c 2d 31 2c 30  c,0,0,0,0,0,-1,0
6340: 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33  );.  A = sqlite3
6350: 45 78 70 72 28 54 4b 5f 4e 4f 54 2c 20 41 2c 20  Expr(TK_NOT, A, 
6360: 30 2c 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33  0, 0);.  sqlite3
6370: 45 78 70 72 53 70 61 6e 28 41 2c 26 58 2d 3e 73  ExprSpan(A,&X->s
6380: 70 61 6e 2c 44 2e 7a 3f 26 44 3a 26 59 29 3b 0a  pan,D.z?&D:&Y);.
6390: 7d 0a 0a 0a 2f 2a 20 43 41 53 45 20 65 78 70 72  }.../* CASE expr
63a0: 65 73 73 69 6f 6e 73 20 2a 2f 0a 65 78 70 72 28  essions */.expr(
63b0: 41 29 20 3a 3a 3d 20 43 41 53 45 28 43 29 20 63  A) ::= CASE(C) c
63c0: 61 73 65 5f 6f 70 65 72 61 6e 64 28 58 29 20 63  ase_operand(X) c
63d0: 61 73 65 5f 65 78 70 72 6c 69 73 74 28 59 29 20  ase_exprlist(Y) 
63e0: 63 61 73 65 5f 65 6c 73 65 28 5a 29 20 45 4e 44  case_else(Z) END
63f0: 28 45 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c  (E). {.  A = sql
6400: 69 74 65 33 45 78 70 72 28 54 4b 5f 43 41 53 45  ite3Expr(TK_CASE
6410: 2c 20 58 2c 20 5a 2c 20 30 29 3b 0a 20 20 69 66  , X, Z, 0);.  if
6420: 28 20 41 20 29 20 41 2d 3e 70 4c 69 73 74 20 3d  ( A ) A->pList =
6430: 20 59 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70   Y;.  sqlite3Exp
6440: 72 53 70 61 6e 28 41 2c 20 26 43 2c 20 26 45 29  rSpan(A, &C, &E)
6450: 3b 0a 7d 0a 25 74 79 70 65 20 63 61 73 65 5f 65  ;.}.%type case_e
6460: 78 70 72 6c 69 73 74 20 7b 45 78 70 72 4c 69 73  xprlist {ExprLis
6470: 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20  t*}.%destructor 
6480: 63 61 73 65 5f 65 78 70 72 6c 69 73 74 20 7b 73  case_exprlist {s
6490: 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 44 65  qlite3ExprListDe
64a0: 6c 65 74 65 28 24 24 29 3b 7d 0a 63 61 73 65 5f  lete($$);}.case_
64b0: 65 78 70 72 6c 69 73 74 28 41 29 20 3a 3a 3d 20  exprlist(A) ::= 
64c0: 63 61 73 65 5f 65 78 70 72 6c 69 73 74 28 58 29  case_exprlist(X)
64d0: 20 57 48 45 4e 20 65 78 70 72 28 59 29 20 54 48   WHEN expr(Y) TH
64e0: 45 4e 20 65 78 70 72 28 5a 29 2e 20 7b 0a 20 20  EN expr(Z). {.  
64f0: 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c  A = sqlite3ExprL
6500: 69 73 74 41 70 70 65 6e 64 28 58 2c 20 59 2c 20  istAppend(X, Y, 
6510: 30 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65  0);.  A = sqlite
6520: 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28  3ExprListAppend(
6530: 41 2c 20 5a 2c 20 30 29 3b 0a 7d 0a 63 61 73 65  A, Z, 0);.}.case
6540: 5f 65 78 70 72 6c 69 73 74 28 41 29 20 3a 3a 3d  _exprlist(A) ::=
6550: 20 57 48 45 4e 20 65 78 70 72 28 59 29 20 54 48   WHEN expr(Y) TH
6560: 45 4e 20 65 78 70 72 28 5a 29 2e 20 7b 0a 20 20  EN expr(Z). {.  
6570: 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c  A = sqlite3ExprL
6580: 69 73 74 41 70 70 65 6e 64 28 30 2c 20 59 2c 20  istAppend(0, Y, 
6590: 30 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65  0);.  A = sqlite
65a0: 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28  3ExprListAppend(
65b0: 41 2c 20 5a 2c 20 30 29 3b 0a 7d 0a 25 74 79 70  A, Z, 0);.}.%typ
65c0: 65 20 63 61 73 65 5f 65 6c 73 65 20 7b 45 78 70  e case_else {Exp
65d0: 72 2a 7d 0a 63 61 73 65 5f 65 6c 73 65 28 41 29  r*}.case_else(A)
65e0: 20 3a 3a 3d 20 20 45 4c 53 45 20 65 78 70 72 28   ::=  ELSE expr(
65f0: 58 29 2e 20 20 20 20 20 20 20 20 20 7b 41 20 3d  X).         {A =
6600: 20 58 3b 7d 0a 63 61 73 65 5f 65 6c 73 65 28 41   X;}.case_else(A
6610: 29 20 3a 3a 3d 20 20 2e 20 20 20 20 20 20 20 20  ) ::=  .        
6620: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20               {A 
6630: 3d 20 30 3b 7d 20 0a 25 74 79 70 65 20 63 61 73  = 0;} .%type cas
6640: 65 5f 6f 70 65 72 61 6e 64 20 7b 45 78 70 72 2a  e_operand {Expr*
6650: 7d 0a 63 61 73 65 5f 6f 70 65 72 61 6e 64 28 41  }.case_operand(A
6660: 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 2e 20 20  ) ::= expr(X).  
6670: 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58            {A = X
6680: 3b 7d 20 0a 63 61 73 65 5f 6f 70 65 72 61 6e 64  ;} .case_operand
6690: 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20  (A) ::= .       
66a0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d              {A =
66b0: 20 30 3b 7d 20 0a 0a 25 74 79 70 65 20 65 78 70   0;} ..%type exp
66c0: 72 6c 69 73 74 20 7b 45 78 70 72 4c 69 73 74 2a  rlist {ExprList*
66d0: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 65 78  }.%destructor ex
66e0: 70 72 6c 69 73 74 20 7b 73 71 6c 69 74 65 33 45  prlist {sqlite3E
66f0: 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28 24 24  xprListDelete($$
6700: 29 3b 7d 0a 25 74 79 70 65 20 65 78 70 72 69 74  );}.%type exprit
6710: 65 6d 20 7b 45 78 70 72 2a 7d 0a 25 64 65 73 74  em {Expr*}.%dest
6720: 72 75 63 74 6f 72 20 65 78 70 72 69 74 65 6d 20  ructor expritem 
6730: 7b 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65  {sqlite3ExprDele
6740: 74 65 28 24 24 29 3b 7d 0a 0a 65 78 70 72 6c 69  te($$);}..exprli
6750: 73 74 28 41 29 20 3a 3a 3d 20 65 78 70 72 6c 69  st(A) ::= exprli
6760: 73 74 28 58 29 20 43 4f 4d 4d 41 20 65 78 70 72  st(X) COMMA expr
6770: 69 74 65 6d 28 59 29 2e 20 0a 20 20 20 7b 41 20  item(Y). .   {A 
6780: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73  = sqlite3ExprLis
6790: 74 41 70 70 65 6e 64 28 58 2c 59 2c 30 29 3b 7d  tAppend(X,Y,0);}
67a0: 0a 65 78 70 72 6c 69 73 74 28 41 29 20 3a 3a 3d  .exprlist(A) ::=
67b0: 20 65 78 70 72 69 74 65 6d 28 58 29 2e 20 20 20   expritem(X).   
67c0: 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 73 71           {A = sq
67d0: 6c 69 74 65 33 45 78 70 72 4c 69 73 74 41 70 70  lite3ExprListApp
67e0: 65 6e 64 28 30 2c 58 2c 30 29 3b 7d 0a 65 78 70  end(0,X,0);}.exp
67f0: 72 69 74 65 6d 28 41 29 20 3a 3a 3d 20 65 78 70  ritem(A) ::= exp
6800: 72 28 58 29 2e 20 20 20 20 20 20 20 20 20 20 20  r(X).           
6810: 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 65 78       {A = X;}.ex
6820: 70 72 69 74 65 6d 28 41 29 20 3a 3a 3d 20 2e 20  pritem(A) ::= . 
6830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6840: 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 0a        {A = 0;}..
6850: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6860: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68  ///////////// Th
6870: 65 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 63  e CREATE INDEX c
6880: 6f 6d 6d 61 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f 2f  ommand /////////
6890: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f  //////////////./
68a0: 2f 0a 63 6d 64 20 3a 3a 3d 20 43 52 45 41 54 45  /.cmd ::= CREATE
68b0: 28 53 29 20 75 6e 69 71 75 65 66 6c 61 67 28 55  (S) uniqueflag(U
68c0: 29 20 49 4e 44 45 58 20 6e 6d 28 58 29 0a 20 20  ) INDEX nm(X).  
68d0: 20 20 20 20 20 20 4f 4e 20 6e 6d 28 59 29 20 64        ON nm(Y) d
68e0: 62 6e 6d 28 44 29 20 4c 50 20 69 64 78 6c 69 73  bnm(D) LP idxlis
68f0: 74 28 5a 29 20 52 50 28 45 29 20 6f 6e 63 6f 6e  t(Z) RP(E) oncon
6900: 66 28 52 29 2e 20 7b 0a 20 20 53 72 63 4c 69 73  f(R). {.  SrcLis
6910: 74 20 2a 70 53 72 63 20 3d 20 73 71 6c 69 74 65  t *pSrc = sqlite
6920: 33 53 72 63 4c 69 73 74 41 70 70 65 6e 64 28 30  3SrcListAppend(0
6930: 2c 20 26 59 2c 20 26 44 29 3b 0a 20 20 69 66 28  , &Y, &D);.  if(
6940: 20 55 21 3d 4f 45 5f 4e 6f 6e 65 20 29 20 55 20   U!=OE_None ) U 
6950: 3d 20 52 3b 0a 20 20 69 66 28 20 55 3d 3d 4f 45  = R;.  if( U==OE
6960: 5f 44 65 66 61 75 6c 74 29 20 55 20 3d 20 4f 45  _Default) U = OE
6970: 5f 41 62 6f 72 74 3b 0a 20 20 73 71 6c 69 74 65  _Abort;.  sqlite
6980: 33 43 72 65 61 74 65 49 6e 64 65 78 28 70 50 61  3CreateIndex(pPa
6990: 72 73 65 2c 20 26 58 2c 20 70 53 72 63 2c 20 5a  rse, &X, pSrc, Z
69a0: 2c 20 55 2c 20 26 53 2c 20 26 45 29 3b 0a 7d 0a  , U, &S, &E);.}.
69b0: 0a 25 74 79 70 65 20 75 6e 69 71 75 65 66 6c 61  .%type uniquefla
69c0: 67 20 7b 69 6e 74 7d 0a 75 6e 69 71 75 65 66 6c  g {int}.uniquefl
69d0: 61 67 28 41 29 20 3a 3a 3d 20 55 4e 49 51 55 45  ag(A) ::= UNIQUE
69e0: 2e 20 20 7b 20 41 20 3d 20 4f 45 5f 41 62 6f 72  .  { A = OE_Abor
69f0: 74 3b 20 7d 0a 75 6e 69 71 75 65 66 6c 61 67 28  t; }.uniqueflag(
6a00: 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20  A) ::= .        
6a10: 7b 20 41 20 3d 20 4f 45 5f 4e 6f 6e 65 3b 20 7d  { A = OE_None; }
6a20: 0a 0a 25 74 79 70 65 20 69 64 78 6c 69 73 74 20  ..%type idxlist 
6a30: 7b 49 64 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72  {IdList*}.%destr
6a40: 75 63 74 6f 72 20 69 64 78 6c 69 73 74 20 7b 73  uctor idxlist {s
6a50: 71 6c 69 74 65 33 49 64 4c 69 73 74 44 65 6c 65  qlite3IdListDele
6a60: 74 65 28 24 24 29 3b 7d 0a 25 74 79 70 65 20 69  te($$);}.%type i
6a70: 64 78 6c 69 73 74 5f 6f 70 74 20 7b 49 64 4c 69  dxlist_opt {IdLi
6a80: 73 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72  st*}.%destructor
6a90: 20 69 64 78 6c 69 73 74 5f 6f 70 74 20 7b 73 71   idxlist_opt {sq
6aa0: 6c 69 74 65 33 49 64 4c 69 73 74 44 65 6c 65 74  lite3IdListDelet
6ab0: 65 28 24 24 29 3b 7d 0a 25 74 79 70 65 20 69 64  e($$);}.%type id
6ac0: 78 69 74 65 6d 20 7b 54 6f 6b 65 6e 7d 0a 0a 69  xitem {Token}..i
6ad0: 64 78 6c 69 73 74 5f 6f 70 74 28 41 29 20 3a 3a  dxlist_opt(A) ::
6ae0: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
6af0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d              {A =
6b00: 20 30 3b 7d 0a 69 64 78 6c 69 73 74 5f 6f 70 74   0;}.idxlist_opt
6b10: 28 41 29 20 3a 3a 3d 20 4c 50 20 69 64 78 6c 69  (A) ::= LP idxli
6b20: 73 74 28 58 29 20 52 50 2e 20 20 20 20 20 20 20  st(X) RP.       
6b30: 20 20 7b 41 20 3d 20 58 3b 7d 0a 69 64 78 6c 69    {A = X;}.idxli
6b40: 73 74 28 41 29 20 3a 3a 3d 20 69 64 78 6c 69 73  st(A) ::= idxlis
6b50: 74 28 58 29 20 43 4f 4d 4d 41 20 69 64 78 69 74  t(X) COMMA idxit
6b60: 65 6d 28 59 29 2e 20 20 7b 41 20 3d 20 73 71 6c  em(Y).  {A = sql
6b70: 69 74 65 33 49 64 4c 69 73 74 41 70 70 65 6e 64  ite3IdListAppend
6b80: 28 58 2c 26 59 29 3b 7d 0a 69 64 78 6c 69 73 74  (X,&Y);}.idxlist
6b90: 28 41 29 20 3a 3a 3d 20 69 64 78 69 74 65 6d 28  (A) ::= idxitem(
6ba0: 59 29 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  Y).             
6bb0: 20 20 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74        {A = sqlit
6bc0: 65 33 49 64 4c 69 73 74 41 70 70 65 6e 64 28 30  e3IdListAppend(0
6bd0: 2c 26 59 29 3b 7d 0a 69 64 78 69 74 65 6d 28 41  ,&Y);}.idxitem(A
6be0: 29 20 3a 3a 3d 20 6e 6d 28 58 29 20 73 6f 72 74  ) ::= nm(X) sort
6bf0: 6f 72 64 65 72 2e 20 20 20 20 20 20 20 20 20 20  order.          
6c00: 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 0a 2f 2f      {A = X;}..//
6c10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6c20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20  /////////// The 
6c30: 44 52 4f 50 20 49 4e 44 45 58 20 63 6f 6d 6d 61  DROP INDEX comma
6c40: 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  nd /////////////
6c50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a  ////////////.//.
6c60: 0a 63 6d 64 20 3a 3a 3d 20 44 52 4f 50 20 49 4e  .cmd ::= DROP IN
6c70: 44 45 58 20 6e 6d 28 58 29 20 64 62 6e 6d 28 59  DEX nm(X) dbnm(Y
6c80: 29 2e 20 20 20 7b 0a 20 20 73 71 6c 69 74 65 33  ).   {.  sqlite3
6c90: 44 72 6f 70 49 6e 64 65 78 28 70 50 61 72 73 65  DropIndex(pParse
6ca0: 2c 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74  , sqlite3SrcList
6cb0: 41 70 70 65 6e 64 28 30 2c 26 58 2c 26 59 29 29  Append(0,&X,&Y))
6cc0: 3b 0a 7d 0a 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ;.}...//////////
6cd0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6ce0: 2f 2f 2f 20 54 68 65 20 43 4f 50 59 20 63 6f 6d  /// The COPY com
6cf0: 6d 61 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  mand ///////////
6d00: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6d10: 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d 20  ////.//.cmd ::= 
6d20: 43 4f 50 59 20 6f 72 63 6f 6e 66 28 52 29 20 6e  COPY orconf(R) n
6d30: 6d 28 58 29 20 64 62 6e 6d 28 44 29 20 46 52 4f  m(X) dbnm(D) FRO
6d40: 4d 20 6e 6d 28 59 29 20 55 53 49 4e 47 20 44 45  M nm(Y) USING DE
6d50: 4c 49 4d 49 54 45 52 53 20 53 54 52 49 4e 47 28  LIMITERS STRING(
6d60: 5a 29 2e 0a 20 20 20 20 7b 73 71 6c 69 74 65 33  Z)..    {sqlite3
6d70: 43 6f 70 79 28 70 50 61 72 73 65 2c 73 71 6c 69  Copy(pParse,sqli
6d80: 74 65 33 53 72 63 4c 69 73 74 41 70 70 65 6e 64  te3SrcListAppend
6d90: 28 30 2c 26 58 2c 26 44 29 2c 26 59 2c 26 5a 2c  (0,&X,&D),&Y,&Z,
6da0: 52 29 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 43 4f 50  R);}.cmd ::= COP
6db0: 59 20 6f 72 63 6f 6e 66 28 52 29 20 6e 6d 28 58  Y orconf(R) nm(X
6dc0: 29 20 64 62 6e 6d 28 44 29 20 46 52 4f 4d 20 6e  ) dbnm(D) FROM n
6dd0: 6d 28 59 29 2e 0a 20 20 20 20 7b 73 71 6c 69 74  m(Y)..    {sqlit
6de0: 65 33 43 6f 70 79 28 70 50 61 72 73 65 2c 73 71  e3Copy(pParse,sq
6df0: 6c 69 74 65 33 53 72 63 4c 69 73 74 41 70 70 65  lite3SrcListAppe
6e00: 6e 64 28 30 2c 26 58 2c 26 44 29 2c 26 59 2c 30  nd(0,&X,&D),&Y,0
6e10: 2c 52 29 3b 7d 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f  ,R);}../////////
6e20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6e30: 2f 2f 2f 2f 20 54 68 65 20 56 41 43 55 55 4d 20  //// The VACUUM 
6e40: 63 6f 6d 6d 61 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f  command ////////
6e50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6e60: 2f 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d  /////.//.cmd ::=
6e70: 20 56 41 43 55 55 4d 2e 20 20 20 20 20 20 20 20   VACUUM.        
6e80: 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33          {sqlite3
6e90: 56 61 63 75 75 6d 28 70 50 61 72 73 65 2c 30 29  Vacuum(pParse,0)
6ea0: 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 56 41 43 55 55  ;}.cmd ::= VACUU
6eb0: 4d 20 6e 6d 28 58 29 2e 20 20 20 20 20 20 20 20  M nm(X).        
6ec0: 20 7b 73 71 6c 69 74 65 33 56 61 63 75 75 6d 28   {sqlite3Vacuum(
6ed0: 70 50 61 72 73 65 2c 26 58 29 3b 7d 0a 0a 2f 2f  pParse,&X);}..//
6ee0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6ef0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20  /////////// The 
6f00: 50 52 41 47 4d 41 20 63 6f 6d 6d 61 6e 64 20 2f  PRAGMA command /
6f10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6f20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a  ////////////.//.
6f30: 63 6d 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 69  cmd ::= PRAGMA i
6f40: 64 73 28 58 29 20 45 51 20 6e 6d 28 59 29 2e 20  ds(X) EQ nm(Y). 
6f50: 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33          {sqlite3
6f60: 50 72 61 67 6d 61 28 70 50 61 72 73 65 2c 26 58  Pragma(pParse,&X
6f70: 2c 26 59 2c 30 29 3b 7d 0a 63 6d 64 20 3a 3a 3d  ,&Y,0);}.cmd ::=
6f80: 20 50 52 41 47 4d 41 20 69 64 73 28 58 29 20 45   PRAGMA ids(X) E
6f90: 51 20 4f 4e 28 59 29 2e 20 20 20 20 20 20 20 20  Q ON(Y).        
6fa0: 20 20 7b 73 71 6c 69 74 65 33 50 72 61 67 6d 61    {sqlite3Pragma
6fb0: 28 70 50 61 72 73 65 2c 26 58 2c 26 59 2c 30 29  (pParse,&X,&Y,0)
6fc0: 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 50 52 41 47 4d  ;}.cmd ::= PRAGM
6fd0: 41 20 69 64 73 28 58 29 20 45 51 20 70 6c 75 73  A ids(X) EQ plus
6fe0: 5f 6e 75 6d 28 59 29 2e 20 20 20 20 7b 73 71 6c  _num(Y).    {sql
6ff0: 69 74 65 33 50 72 61 67 6d 61 28 70 50 61 72 73  ite3Pragma(pPars
7000: 65 2c 26 58 2c 26 59 2c 30 29 3b 7d 0a 63 6d 64  e,&X,&Y,0);}.cmd
7010: 20 3a 3a 3d 20 50 52 41 47 4d 41 20 69 64 73 28   ::= PRAGMA ids(
7020: 58 29 20 45 51 20 6d 69 6e 75 73 5f 6e 75 6d 28  X) EQ minus_num(
7030: 59 29 2e 20 20 20 7b 73 71 6c 69 74 65 33 50 72  Y).   {sqlite3Pr
7040: 61 67 6d 61 28 70 50 61 72 73 65 2c 26 58 2c 26  agma(pParse,&X,&
7050: 59 2c 31 29 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 50  Y,1);}.cmd ::= P
7060: 52 41 47 4d 41 20 69 64 73 28 58 29 20 4c 50 20  RAGMA ids(X) LP 
7070: 6e 6d 28 59 29 20 52 50 2e 20 20 20 20 20 20 7b  nm(Y) RP.      {
7080: 73 71 6c 69 74 65 33 50 72 61 67 6d 61 28 70 50  sqlite3Pragma(pP
7090: 61 72 73 65 2c 26 58 2c 26 59 2c 30 29 3b 7d 0a  arse,&X,&Y,0);}.
70a0: 63 6d 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 69  cmd ::= PRAGMA i
70b0: 64 73 28 58 29 2e 20 20 20 20 20 20 20 20 20 20  ds(X).          
70c0: 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65           {sqlite
70d0: 33 50 72 61 67 6d 61 28 70 50 61 72 73 65 2c 26  3Pragma(pParse,&
70e0: 58 2c 26 58 2c 30 29 3b 7d 0a 70 6c 75 73 5f 6e  X,&X,0);}.plus_n
70f0: 75 6d 28 41 29 20 3a 3a 3d 20 70 6c 75 73 5f 6f  um(A) ::= plus_o
7100: 70 74 20 6e 75 6d 62 65 72 28 58 29 2e 20 20 20  pt number(X).   
7110: 7b 41 20 3d 20 58 3b 7d 0a 6d 69 6e 75 73 5f 6e  {A = X;}.minus_n
7120: 75 6d 28 41 29 20 3a 3a 3d 20 4d 49 4e 55 53 20  um(A) ::= MINUS 
7130: 6e 75 6d 62 65 72 28 58 29 2e 20 20 20 20 20 7b  number(X).     {
7140: 41 20 3d 20 58 3b 7d 0a 6e 75 6d 62 65 72 28 41  A = X;}.number(A
7150: 29 20 3a 3a 3d 20 49 4e 54 45 47 45 52 28 58 29  ) ::= INTEGER(X)
7160: 2e 20 20 7b 41 20 3d 20 58 3b 7d 0a 6e 75 6d 62  .  {A = X;}.numb
7170: 65 72 28 41 29 20 3a 3a 3d 20 46 4c 4f 41 54 28  er(A) ::= FLOAT(
7180: 58 29 2e 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a  X).    {A = X;}.
7190: 70 6c 75 73 5f 6f 70 74 20 3a 3a 3d 20 50 4c 55  plus_opt ::= PLU
71a0: 53 2e 0a 70 6c 75 73 5f 6f 70 74 20 3a 3a 3d 20  S..plus_opt ::= 
71b0: 2e 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .../////////////
71c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20  /////////////// 
71d0: 54 68 65 20 43 52 45 41 54 45 20 54 52 49 47 47  The CREATE TRIGG
71e0: 45 52 20 63 6f 6d 6d 61 6e 64 20 2f 2f 2f 2f 2f  ER command /////
71f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7200: 0a 0a 63 6d 64 20 3a 3a 3d 20 43 52 45 41 54 45  ..cmd ::= CREATE
7210: 28 41 29 20 74 72 69 67 67 65 72 5f 64 65 63 6c  (A) trigger_decl
7220: 20 42 45 47 49 4e 20 74 72 69 67 67 65 72 5f 63   BEGIN trigger_c
7230: 6d 64 5f 6c 69 73 74 28 53 29 20 45 4e 44 28 5a  md_list(S) END(Z
7240: 29 2e 20 7b 0a 20 20 54 6f 6b 65 6e 20 61 6c 6c  ). {.  Token all
7250: 3b 0a 20 20 61 6c 6c 2e 7a 20 3d 20 41 2e 7a 3b  ;.  all.z = A.z;
7260: 0a 20 20 61 6c 6c 2e 6e 20 3d 20 28 5a 2e 7a 20  .  all.n = (Z.z 
7270: 2d 20 41 2e 7a 29 20 2b 20 5a 2e 6e 3b 0a 20 20  - A.z) + Z.n;.  
7280: 73 71 6c 69 74 65 33 46 69 6e 69 73 68 54 72 69  sqlite3FinishTri
7290: 67 67 65 72 28 70 50 61 72 73 65 2c 20 53 2c 20  gger(pParse, S, 
72a0: 26 61 6c 6c 29 3b 0a 7d 0a 0a 74 72 69 67 67 65  &all);.}..trigge
72b0: 72 5f 64 65 63 6c 20 3a 3a 3d 20 74 65 6d 70 28  r_decl ::= temp(
72c0: 54 29 20 54 52 49 47 47 45 52 20 6e 6d 28 42 29  T) TRIGGER nm(B)
72d0: 20 74 72 69 67 67 65 72 5f 74 69 6d 65 28 43 29   trigger_time(C)
72e0: 20 74 72 69 67 67 65 72 5f 65 76 65 6e 74 28 44   trigger_event(D
72f0: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ).              
7300: 20 20 20 4f 4e 20 6e 6d 28 45 29 20 64 62 6e 6d     ON nm(E) dbnm
7310: 28 44 42 29 20 66 6f 72 65 61 63 68 5f 63 6c 61  (DB) foreach_cla
7320: 75 73 65 28 46 29 20 77 68 65 6e 5f 63 6c 61 75  use(F) when_clau
7330: 73 65 28 47 29 2e 20 7b 0a 20 20 53 72 63 4c 69  se(G). {.  SrcLi
7340: 73 74 20 2a 70 54 61 62 20 3d 20 73 71 6c 69 74  st *pTab = sqlit
7350: 65 33 53 72 63 4c 69 73 74 41 70 70 65 6e 64 28  e3SrcListAppend(
7360: 30 2c 20 26 45 2c 20 26 44 42 29 3b 0a 20 20 73  0, &E, &DB);.  s
7370: 71 6c 69 74 65 33 42 65 67 69 6e 54 72 69 67 67  qlite3BeginTrigg
7380: 65 72 28 70 50 61 72 73 65 2c 20 26 42 2c 20 43  er(pParse, &B, C
7390: 2c 20 44 2e 61 2c 20 44 2e 62 2c 20 70 54 61 62  , D.a, D.b, pTab
73a0: 2c 20 46 2c 20 47 2c 20 54 29 3b 0a 7d 0a 0a 25  , F, G, T);.}..%
73b0: 74 79 70 65 20 74 72 69 67 67 65 72 5f 74 69 6d  type trigger_tim
73c0: 65 20 20 7b 69 6e 74 7d 0a 74 72 69 67 67 65 72  e  {int}.trigger
73d0: 5f 74 69 6d 65 28 41 29 20 3a 3a 3d 20 42 45 46  _time(A) ::= BEF
73e0: 4f 52 45 2e 20 20 20 20 20 20 7b 20 41 20 3d 20  ORE.      { A = 
73f0: 54 4b 5f 42 45 46 4f 52 45 3b 20 7d 0a 74 72 69  TK_BEFORE; }.tri
7400: 67 67 65 72 5f 74 69 6d 65 28 41 29 20 3a 3a 3d  gger_time(A) ::=
7410: 20 41 46 54 45 52 2e 20 20 20 20 20 20 20 7b 20   AFTER.       { 
7420: 41 20 3d 20 54 4b 5f 41 46 54 45 52 3b 20 20 7d  A = TK_AFTER;  }
7430: 0a 74 72 69 67 67 65 72 5f 74 69 6d 65 28 41 29  .trigger_time(A)
7440: 20 3a 3a 3d 20 49 4e 53 54 45 41 44 20 4f 46 2e   ::= INSTEAD OF.
7450: 20 20 7b 20 41 20 3d 20 54 4b 5f 49 4e 53 54 45    { A = TK_INSTE
7460: 41 44 3b 7d 0a 74 72 69 67 67 65 72 5f 74 69 6d  AD;}.trigger_tim
7470: 65 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20  e(A) ::= .      
7480: 20 20 20 20 20 20 7b 20 41 20 3d 20 54 4b 5f 42        { A = TK_B
7490: 45 46 4f 52 45 3b 20 7d 0a 0a 25 74 79 70 65 20  EFORE; }..%type 
74a0: 74 72 69 67 67 65 72 5f 65 76 65 6e 74 20 7b 73  trigger_event {s
74b0: 74 72 75 63 74 20 54 72 69 67 45 76 65 6e 74 7d  truct TrigEvent}
74c0: 0a 25 64 65 73 74 72 75 63 74 6f 72 20 74 72 69  .%destructor tri
74d0: 67 67 65 72 5f 65 76 65 6e 74 20 7b 73 71 6c 69  gger_event {sqli
74e0: 74 65 33 49 64 4c 69 73 74 44 65 6c 65 74 65 28  te3IdListDelete(
74f0: 24 24 2e 62 29 3b 7d 0a 74 72 69 67 67 65 72 5f  $$.b);}.trigger_
7500: 65 76 65 6e 74 28 41 29 20 3a 3a 3d 20 44 45 4c  event(A) ::= DEL
7510: 45 54 45 2e 20 7b 20 41 2e 61 20 3d 20 54 4b 5f  ETE. { A.a = TK_
7520: 44 45 4c 45 54 45 3b 20 41 2e 62 20 3d 20 30 3b  DELETE; A.b = 0;
7530: 20 7d 0a 74 72 69 67 67 65 72 5f 65 76 65 6e 74   }.trigger_event
7540: 28 41 29 20 3a 3a 3d 20 49 4e 53 45 52 54 2e 20  (A) ::= INSERT. 
7550: 7b 20 41 2e 61 20 3d 20 54 4b 5f 49 4e 53 45 52  { A.a = TK_INSER
7560: 54 3b 20 41 2e 62 20 3d 20 30 3b 20 7d 0a 74 72  T; A.b = 0; }.tr
7570: 69 67 67 65 72 5f 65 76 65 6e 74 28 41 29 20 3a  igger_event(A) :
7580: 3a 3d 20 55 50 44 41 54 45 2e 20 7b 20 41 2e 61  := UPDATE. { A.a
7590: 20 3d 20 54 4b 5f 55 50 44 41 54 45 3b 20 41 2e   = TK_UPDATE; A.
75a0: 62 20 3d 20 30 3b 7d 0a 74 72 69 67 67 65 72 5f  b = 0;}.trigger_
75b0: 65 76 65 6e 74 28 41 29 20 3a 3a 3d 20 55 50 44  event(A) ::= UPD
75c0: 41 54 45 20 4f 46 20 69 6e 73 63 6f 6c 6c 69 73  ATE OF inscollis
75d0: 74 28 58 29 2e 20 7b 41 2e 61 20 3d 20 54 4b 5f  t(X). {A.a = TK_
75e0: 55 50 44 41 54 45 3b 20 41 2e 62 20 3d 20 58 3b  UPDATE; A.b = X;
75f0: 20 7d 0a 0a 25 74 79 70 65 20 66 6f 72 65 61 63   }..%type foreac
7600: 68 5f 63 6c 61 75 73 65 20 7b 69 6e 74 7d 0a 66  h_clause {int}.f
7610: 6f 72 65 61 63 68 5f 63 6c 61 75 73 65 28 41 29  oreach_clause(A)
7620: 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20   ::= .          
7630: 20 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20 54           { A = T
7640: 4b 5f 52 4f 57 3b 20 7d 0a 66 6f 72 65 61 63 68  K_ROW; }.foreach
7650: 5f 63 6c 61 75 73 65 28 41 29 20 3a 3a 3d 20 46  _clause(A) ::= F
7660: 4f 52 20 45 41 43 48 20 52 4f 57 2e 20 20 20 20  OR EACH ROW.    
7670: 20 20 20 7b 20 41 20 3d 20 54 4b 5f 52 4f 57 3b     { A = TK_ROW;
7680: 20 7d 0a 66 6f 72 65 61 63 68 5f 63 6c 61 75 73   }.foreach_claus
7690: 65 28 41 29 20 3a 3a 3d 20 46 4f 52 20 45 41 43  e(A) ::= FOR EAC
76a0: 48 20 53 54 41 54 45 4d 45 4e 54 2e 20 7b 20 41  H STATEMENT. { A
76b0: 20 3d 20 54 4b 5f 53 54 41 54 45 4d 45 4e 54 3b   = TK_STATEMENT;
76c0: 20 7d 0a 0a 25 74 79 70 65 20 77 68 65 6e 5f 63   }..%type when_c
76d0: 6c 61 75 73 65 20 7b 45 78 70 72 20 2a 7d 0a 77  lause {Expr *}.w
76e0: 68 65 6e 5f 63 6c 61 75 73 65 28 41 29 20 3a 3a  hen_clause(A) ::
76f0: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
7700: 7b 20 41 20 3d 20 30 3b 20 7d 0a 77 68 65 6e 5f  { A = 0; }.when_
7710: 63 6c 61 75 73 65 28 41 29 20 3a 3a 3d 20 57 48  clause(A) ::= WH
7720: 45 4e 20 65 78 70 72 28 58 29 2e 20 7b 20 41 20  EN expr(X). { A 
7730: 3d 20 58 3b 20 7d 0a 0a 25 74 79 70 65 20 74 72  = X; }..%type tr
7740: 69 67 67 65 72 5f 63 6d 64 5f 6c 69 73 74 20 7b  igger_cmd_list {
7750: 54 72 69 67 67 65 72 53 74 65 70 20 2a 7d 0a 25  TriggerStep *}.%
7760: 64 65 73 74 72 75 63 74 6f 72 20 74 72 69 67 67  destructor trigg
7770: 65 72 5f 63 6d 64 5f 6c 69 73 74 20 7b 73 71 6c  er_cmd_list {sql
7780: 69 74 65 33 44 65 6c 65 74 65 54 72 69 67 67 65  ite3DeleteTrigge
7790: 72 53 74 65 70 28 24 24 29 3b 7d 0a 74 72 69 67  rStep($$);}.trig
77a0: 67 65 72 5f 63 6d 64 5f 6c 69 73 74 28 41 29 20  ger_cmd_list(A) 
77b0: 3a 3a 3d 20 74 72 69 67 67 65 72 5f 63 6d 64 28  ::= trigger_cmd(
77c0: 58 29 20 53 45 4d 49 20 74 72 69 67 67 65 72 5f  X) SEMI trigger_
77d0: 63 6d 64 5f 6c 69 73 74 28 59 29 2e 20 7b 0a 20  cmd_list(Y). {. 
77e0: 20 58 2d 3e 70 4e 65 78 74 20 3d 20 59 3b 0a 20   X->pNext = Y;. 
77f0: 20 41 20 3d 20 58 3b 0a 7d 0a 74 72 69 67 67 65   A = X;.}.trigge
7800: 72 5f 63 6d 64 5f 6c 69 73 74 28 41 29 20 3a 3a  r_cmd_list(A) ::
7810: 3d 20 2e 20 7b 20 41 20 3d 20 30 3b 20 7d 0a 0a  = . { A = 0; }..
7820: 25 74 79 70 65 20 74 72 69 67 67 65 72 5f 63 6d  %type trigger_cm
7830: 64 20 7b 54 72 69 67 67 65 72 53 74 65 70 20 2a  d {TriggerStep *
7840: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 74 72  }.%destructor tr
7850: 69 67 67 65 72 5f 63 6d 64 20 7b 73 71 6c 69 74  igger_cmd {sqlit
7860: 65 33 44 65 6c 65 74 65 54 72 69 67 67 65 72 53  e3DeleteTriggerS
7870: 74 65 70 28 24 24 29 3b 7d 0a 2f 2f 20 55 50 44  tep($$);}.// UPD
7880: 41 54 45 20 0a 74 72 69 67 67 65 72 5f 63 6d 64  ATE .trigger_cmd
7890: 28 41 29 20 3a 3a 3d 20 55 50 44 41 54 45 20 6f  (A) ::= UPDATE o
78a0: 72 63 6f 6e 66 28 52 29 20 6e 6d 28 58 29 20 53  rconf(R) nm(X) S
78b0: 45 54 20 73 65 74 6c 69 73 74 28 59 29 20 77 68  ET setlist(Y) wh
78c0: 65 72 65 5f 6f 70 74 28 5a 29 2e 20 20 0a 20 20  ere_opt(Z).  .  
78d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 41               { A
78e0: 20 3d 20 73 71 6c 69 74 65 33 54 72 69 67 67 65   = sqlite3Trigge
78f0: 72 55 70 64 61 74 65 53 74 65 70 28 26 58 2c 20  rUpdateStep(&X, 
7900: 59 2c 20 5a 2c 20 52 29 3b 20 7d 0a 0a 2f 2f 20  Y, Z, R); }..// 
7910: 49 4e 53 45 52 54 0a 74 72 69 67 67 65 72 5f 63  INSERT.trigger_c
7920: 6d 64 28 41 29 20 3a 3a 3d 20 69 6e 73 65 72 74  md(A) ::= insert
7930: 5f 63 6d 64 28 52 29 20 49 4e 54 4f 20 6e 6d 28  _cmd(R) INTO nm(
7940: 58 29 20 69 6e 73 63 6f 6c 6c 69 73 74 5f 6f 70  X) inscollist_op
7950: 74 28 46 29 20 0a 20 20 56 41 4c 55 45 53 20 4c  t(F) .  VALUES L
7960: 50 20 69 74 65 6d 6c 69 73 74 28 59 29 20 52 50  P itemlist(Y) RP
7970: 2e 20 20 0a 7b 41 20 3d 20 73 71 6c 69 74 65 33  .  .{A = sqlite3
7980: 54 72 69 67 67 65 72 49 6e 73 65 72 74 53 74 65  TriggerInsertSte
7990: 70 28 26 58 2c 20 46 2c 20 59 2c 20 30 2c 20 52  p(&X, F, Y, 0, R
79a0: 29 3b 7d 0a 0a 74 72 69 67 67 65 72 5f 63 6d 64  );}..trigger_cmd
79b0: 28 41 29 20 3a 3a 3d 20 69 6e 73 65 72 74 5f 63  (A) ::= insert_c
79c0: 6d 64 28 52 29 20 49 4e 54 4f 20 6e 6d 28 58 29  md(R) INTO nm(X)
79d0: 20 69 6e 73 63 6f 6c 6c 69 73 74 5f 6f 70 74 28   inscollist_opt(
79e0: 46 29 20 73 65 6c 65 63 74 28 53 29 2e 0a 20 20  F) select(S)..  
79f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20               {A 
7a00: 3d 20 73 71 6c 69 74 65 33 54 72 69 67 67 65 72  = sqlite3Trigger
7a10: 49 6e 73 65 72 74 53 74 65 70 28 26 58 2c 20 46  InsertStep(&X, F
7a20: 2c 20 30 2c 20 53 2c 20 52 29 3b 7d 0a 0a 2f 2f  , 0, S, R);}..//
7a30: 20 44 45 4c 45 54 45 0a 74 72 69 67 67 65 72 5f   DELETE.trigger_
7a40: 63 6d 64 28 41 29 20 3a 3a 3d 20 44 45 4c 45 54  cmd(A) ::= DELET
7a50: 45 20 46 52 4f 4d 20 6e 6d 28 58 29 20 77 68 65  E FROM nm(X) whe
7a60: 72 65 5f 6f 70 74 28 59 29 2e 0a 20 20 20 20 20  re_opt(Y)..     
7a70: 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 73            {A = s
7a80: 71 6c 69 74 65 33 54 72 69 67 67 65 72 44 65 6c  qlite3TriggerDel
7a90: 65 74 65 53 74 65 70 28 26 58 2c 20 59 29 3b 7d  eteStep(&X, Y);}
7aa0: 0a 0a 2f 2f 20 53 45 4c 45 43 54 0a 74 72 69 67  ..// SELECT.trig
7ab0: 67 65 72 5f 63 6d 64 28 41 29 20 3a 3a 3d 20 73  ger_cmd(A) ::= s
7ac0: 65 6c 65 63 74 28 58 29 2e 20 20 7b 41 20 3d 20  elect(X).  {A = 
7ad0: 73 71 6c 69 74 65 33 54 72 69 67 67 65 72 53 65  sqlite3TriggerSe
7ae0: 6c 65 63 74 53 74 65 70 28 58 29 3b 20 7d 0a 0a  lectStep(X); }..
7af0: 2f 2f 20 54 68 65 20 73 70 65 63 69 61 6c 20 52  // The special R
7b00: 41 49 53 45 20 65 78 70 72 65 73 73 69 6f 6e 20  AISE expression 
7b10: 74 68 61 74 20 6d 61 79 20 6f 63 63 75 72 20 69  that may occur i
7b20: 6e 20 74 72 69 67 67 65 72 20 70 72 6f 67 72 61  n trigger progra
7b30: 6d 73 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 52  ms.expr(A) ::= R
7b40: 41 49 53 45 28 58 29 20 4c 50 20 49 47 4e 4f 52  AISE(X) LP IGNOR
7b50: 45 20 52 50 28 59 29 2e 20 20 7b 0a 20 20 41 20  E RP(Y).  {.  A 
7b60: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b  = sqlite3Expr(TK
7b70: 5f 52 41 49 53 45 2c 20 30 2c 20 30 2c 20 30 29  _RAISE, 0, 0, 0)
7b80: 3b 20 0a 20 20 41 2d 3e 69 43 6f 6c 75 6d 6e 20  ; .  A->iColumn 
7b90: 3d 20 4f 45 5f 49 67 6e 6f 72 65 3b 0a 20 20 73  = OE_Ignore;.  s
7ba0: 71 6c 69 74 65 33 45 78 70 72 53 70 61 6e 28 41  qlite3ExprSpan(A
7bb0: 2c 20 26 58 2c 20 26 59 29 3b 0a 7d 0a 65 78 70  , &X, &Y);.}.exp
7bc0: 72 28 41 29 20 3a 3a 3d 20 52 41 49 53 45 28 58  r(A) ::= RAISE(X
7bd0: 29 20 4c 50 20 52 4f 4c 4c 42 41 43 4b 20 43 4f  ) LP ROLLBACK CO
7be0: 4d 4d 41 20 6e 6d 28 5a 29 20 52 50 28 59 29 2e  MMA nm(Z) RP(Y).
7bf0: 20 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65    {.  A = sqlite
7c00: 33 45 78 70 72 28 54 4b 5f 52 41 49 53 45 2c 20  3Expr(TK_RAISE, 
7c10: 30 2c 20 30 2c 20 26 5a 29 3b 20 0a 20 20 41 2d  0, 0, &Z); .  A-
7c20: 3e 69 43 6f 6c 75 6d 6e 20 3d 20 4f 45 5f 52 6f  >iColumn = OE_Ro
7c30: 6c 6c 62 61 63 6b 3b 0a 20 20 73 71 6c 69 74 65  llback;.  sqlite
7c40: 33 45 78 70 72 53 70 61 6e 28 41 2c 20 26 58 2c  3ExprSpan(A, &X,
7c50: 20 26 59 29 3b 0a 7d 0a 65 78 70 72 28 41 29 20   &Y);.}.expr(A) 
7c60: 3a 3a 3d 20 52 41 49 53 45 28 58 29 20 4c 50 20  ::= RAISE(X) LP 
7c70: 41 42 4f 52 54 20 43 4f 4d 4d 41 20 6e 6d 28 5a  ABORT COMMA nm(Z
7c80: 29 20 52 50 28 59 29 2e 20 20 7b 0a 20 20 41 20  ) RP(Y).  {.  A 
7c90: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 28 54 4b  = sqlite3Expr(TK
7ca0: 5f 52 41 49 53 45 2c 20 30 2c 20 30 2c 20 26 5a  _RAISE, 0, 0, &Z
7cb0: 29 3b 20 0a 20 20 41 2d 3e 69 43 6f 6c 75 6d 6e  ); .  A->iColumn
7cc0: 20 3d 20 4f 45 5f 41 62 6f 72 74 3b 0a 20 20 73   = OE_Abort;.  s
7cd0: 71 6c 69 74 65 33 45 78 70 72 53 70 61 6e 28 41  qlite3ExprSpan(A
7ce0: 2c 20 26 58 2c 20 26 59 29 3b 0a 7d 0a 65 78 70  , &X, &Y);.}.exp
7cf0: 72 28 41 29 20 3a 3a 3d 20 52 41 49 53 45 28 58  r(A) ::= RAISE(X
7d00: 29 20 4c 50 20 46 41 49 4c 20 43 4f 4d 4d 41 20  ) LP FAIL COMMA 
7d10: 6e 6d 28 5a 29 20 52 50 28 59 29 2e 20 20 7b 0a  nm(Z) RP(Y).  {.
7d20: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
7d30: 72 28 54 4b 5f 52 41 49 53 45 2c 20 30 2c 20 30  r(TK_RAISE, 0, 0
7d40: 2c 20 26 5a 29 3b 20 0a 20 20 41 2d 3e 69 43 6f  , &Z); .  A->iCo
7d50: 6c 75 6d 6e 20 3d 20 4f 45 5f 46 61 69 6c 3b 0a  lumn = OE_Fail;.
7d60: 20 20 73 71 6c 69 74 65 33 45 78 70 72 53 70 61    sqlite3ExprSpa
7d70: 6e 28 41 2c 20 26 58 2c 20 26 59 29 3b 0a 7d 0a  n(A, &X, &Y);.}.
7d80: 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .///////////////
7d90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 20 44 52 4f 50 20  /////////  DROP 
7da0: 54 52 49 47 47 45 52 20 73 74 61 74 65 6d 65 6e  TRIGGER statemen
7db0: 74 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  t //////////////
7dc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7dd0: 0a 63 6d 64 20 3a 3a 3d 20 44 52 4f 50 20 54 52  .cmd ::= DROP TR
7de0: 49 47 47 45 52 20 6e 6d 28 58 29 20 64 62 6e 6d  IGGER nm(X) dbnm
7df0: 28 44 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33  (D). {.  sqlite3
7e00: 44 72 6f 70 54 72 69 67 67 65 72 28 70 50 61 72  DropTrigger(pPar
7e10: 73 65 2c 73 71 6c 69 74 65 33 53 72 63 4c 69 73  se,sqlite3SrcLis
7e20: 74 41 70 70 65 6e 64 28 30 2c 26 58 2c 26 44 29  tAppend(0,&X,&D)
7e30: 29 3b 0a 7d 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  );.}..//////////
7e40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 41  ////////////// A
7e50: 54 54 41 43 48 20 44 41 54 41 42 41 53 45 20 66  TTACH DATABASE f
7e60: 69 6c 65 20 41 53 20 6e 61 6d 65 20 2f 2f 2f 2f  ile AS name ////
7e70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7e80: 2f 2f 2f 2f 2f 0a 63 6d 64 20 3a 3a 3d 20 41 54  /////.cmd ::= AT
7e90: 54 41 43 48 20 64 61 74 61 62 61 73 65 5f 6b 77  TACH database_kw
7ea0: 5f 6f 70 74 20 69 64 73 28 46 29 20 41 53 20 6e  _opt ids(F) AS n
7eb0: 6d 28 44 29 20 6b 65 79 5f 6f 70 74 28 4b 29 2e  m(D) key_opt(K).
7ec0: 20 7b 0a 20 20 73 71 6c 69 74 65 33 41 74 74 61   {.  sqlite3Atta
7ed0: 63 68 28 70 50 61 72 73 65 2c 20 26 46 2c 20 26  ch(pParse, &F, &
7ee0: 44 2c 20 26 4b 29 3b 0a 7d 0a 25 74 79 70 65 20  D, &K);.}.%type 
7ef0: 6b 65 79 5f 6f 70 74 20 7b 54 6f 6b 65 6e 7d 0a  key_opt {Token}.
7f00: 6b 65 79 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 55  key_opt(A) ::= U
7f10: 53 49 4e 47 20 69 64 73 28 58 29 2e 20 20 7b 20  SING ids(X).  { 
7f20: 41 20 3d 20 58 3b 20 7d 0a 6b 65 79 5f 6f 70 74  A = X; }.key_opt
7f30: 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20  (A) ::= .       
7f40: 20 20 20 20 20 20 20 7b 20 41 2e 7a 20 3d 20 30         { A.z = 0
7f50: 3b 20 41 2e 6e 20 3d 20 30 3b 20 7d 0a 0a 64 61  ; A.n = 0; }..da
7f60: 74 61 62 61 73 65 5f 6b 77 5f 6f 70 74 20 3a 3a  tabase_kw_opt ::
7f70: 3d 20 44 41 54 41 42 41 53 45 2e 0a 64 61 74 61  = DATABASE..data
7f80: 62 61 73 65 5f 6b 77 5f 6f 70 74 20 3a 3a 3d 20  base_kw_opt ::= 
7f90: 2e 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .../////////////
7fa0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 44 45 54 41  /////////// DETA
7fb0: 43 48 20 44 41 54 41 42 41 53 45 20 6e 61 6d 65  CH DATABASE name
7fc0: 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f   ///////////////
7fd0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7fe0: 2f 2f 0a 63 6d 64 20 3a 3a 3d 20 44 45 54 41 43  //.cmd ::= DETAC
7ff0: 48 20 64 61 74 61 62 61 73 65 5f 6b 77 5f 6f 70  H database_kw_op
8000: 74 20 6e 6d 28 44 29 2e 20 7b 0a 20 20 73 71 6c  t nm(D). {.  sql
8010: 69 74 65 33 44 65 74 61 63 68 28 70 50 61 72 73  ite3Detach(pPars
8020: 65 2c 20 26 44 29 3b 0a 7d 0a 0a 0a 0a           e, &D);.}....