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

Artifact e14dd3b06cedeadcc027f0b6706b2f53d456a46e:


0000: 2f 2a 0a 2a 2a 20 32 30 30 33 20 41 70 72 69 6c  /*.** 2003 April
0010: 20 36 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74   6.**.** The aut
0020: 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f  hor disclaims co
0030: 70 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20  pyright to this 
0040: 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e  source code.  In
0050: 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c   place of.** a l
0060: 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72  egal notice, her
0070: 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a  e is a blessing:
0080: 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f  .**.**    May yo
0090: 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f  u do good and no
00a0: 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61  t evil..**    Ma
00b0: 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69  y you find forgi
00c0: 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73  veness for yours
00d0: 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20  elf and forgive 
00e0: 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61  others..**    Ma
00f0: 79 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65  y you share free
0100: 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67  ly, never taking
0110: 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67   more than you g
0120: 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a  ive..**.********
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 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63  *.** This file c
0180: 6f 6e 74 61 69 6e 73 20 63 6f 64 65 20 75 73 65  ontains code use
0190: 64 20 74 6f 20 69 6d 70 6c 65 6d 65 6e 74 20 74  d to implement t
01a0: 68 65 20 50 52 41 47 4d 41 20 63 6f 6d 6d 61 6e  he PRAGMA comman
01b0: 64 2e 0a 2a 2a 0a 2a 2a 20 24 49 64 3a 20 70 72  d..**.** $Id: pr
01c0: 61 67 6d 61 2e 63 2c 76 20 31 2e 32 38 20 32 30  agma.c,v 1.28 20
01d0: 30 34 2f 30 35 2f 32 32 20 32 31 3a 33 30 3a 34  04/05/22 21:30:4
01e0: 31 20 64 72 68 20 45 78 70 20 24 0a 2a 2f 0a 23  1 drh Exp $.*/.#
01f0: 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65 49  include "sqliteI
0200: 6e 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 3c  nt.h".#include <
0210: 63 74 79 70 65 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20  ctype.h>../*.** 
0220: 49 6e 74 65 72 70 72 65 74 20 74 68 65 20 67 69  Interpret the gi
0230: 76 65 6e 20 73 74 72 69 6e 67 20 61 73 20 61 20  ven string as a 
0240: 62 6f 6f 6c 65 61 6e 20 76 61 6c 75 65 2e 0a 2a  boolean value..*
0250: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 67 65 74  /.static int get
0260: 42 6f 6f 6c 65 61 6e 28 63 6f 6e 73 74 20 63 68  Boolean(const ch
0270: 61 72 20 2a 7a 29 7b 0a 20 20 73 74 61 74 69 63  ar *z){.  static
0280: 20 63 68 61 72 20 2a 61 7a 54 72 75 65 5b 5d 20   char *azTrue[] 
0290: 3d 20 7b 20 22 79 65 73 22 2c 20 22 6f 6e 22 2c  = { "yes", "on",
02a0: 20 22 74 72 75 65 22 20 7d 3b 0a 20 20 69 6e 74   "true" };.  int
02b0: 20 69 3b 0a 20 20 69 66 28 20 7a 5b 30 5d 3d 3d   i;.  if( z[0]==
02c0: 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  0 ) return 0;.  
02d0: 69 66 28 20 69 73 64 69 67 69 74 28 7a 5b 30 5d  if( isdigit(z[0]
02e0: 29 20 7c 7c 20 28 7a 5b 30 5d 3d 3d 27 2d 27 20  ) || (z[0]=='-' 
02f0: 26 26 20 69 73 64 69 67 69 74 28 7a 5b 31 5d 29  && isdigit(z[1])
0300: 29 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  ) ){.    return 
0310: 61 74 6f 69 28 7a 29 3b 0a 20 20 7d 0a 20 20 66  atoi(z);.  }.  f
0320: 6f 72 28 69 3d 30 3b 20 69 3c 73 69 7a 65 6f 66  or(i=0; i<sizeof
0330: 28 61 7a 54 72 75 65 29 2f 73 69 7a 65 6f 66 28  (azTrue)/sizeof(
0340: 61 7a 54 72 75 65 5b 30 5d 29 3b 20 69 2b 2b 29  azTrue[0]); i++)
0350: 7b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  {.    if( sqlite
0360: 33 53 74 72 49 43 6d 70 28 7a 2c 61 7a 54 72 75  3StrICmp(z,azTru
0370: 65 5b 69 5d 29 3d 3d 30 20 29 20 72 65 74 75 72  e[i])==0 ) retur
0380: 6e 20 31 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  n 1;.  }.  retur
0390: 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e  n 0;.}../*.** In
03a0: 74 65 72 70 72 65 74 20 74 68 65 20 67 69 76 65  terpret the give
03b0: 6e 20 73 74 72 69 6e 67 20 61 73 20 61 20 73 61  n string as a sa
03c0: 66 65 74 79 20 6c 65 76 65 6c 2e 20 20 52 65 74  fety level.  Ret
03d0: 75 72 6e 20 30 20 66 6f 72 20 4f 46 46 2c 0a 2a  urn 0 for OFF,.*
03e0: 2a 20 31 20 66 6f 72 20 4f 4e 20 6f 72 20 4e 4f  * 1 for ON or NO
03f0: 52 4d 41 4c 20 61 6e 64 20 32 20 66 6f 72 20 46  RMAL and 2 for F
0400: 55 4c 4c 2e 20 20 52 65 74 75 72 6e 20 31 20 66  ULL.  Return 1 f
0410: 6f 72 20 61 6e 20 65 6d 70 74 79 20 6f 72 20 0a  or an empty or .
0420: 2a 2a 20 75 6e 72 65 63 6f 67 6e 69 7a 65 64 20  ** unrecognized 
0430: 73 74 72 69 6e 67 20 61 72 67 75 6d 65 6e 74 2e  string argument.
0440: 0a 2a 2a 0a 2a 2a 20 4e 6f 74 65 20 74 68 61 74  .**.** Note that
0450: 20 74 68 65 20 76 61 6c 75 65 73 20 72 65 74 75   the values retu
0460: 72 6e 65 64 20 61 72 65 20 6f 6e 65 20 6c 65 73  rned are one les
0470: 73 20 74 68 61 74 20 74 68 65 20 76 61 6c 75 65  s that the value
0480: 73 20 74 68 61 74 0a 2a 2a 20 73 68 6f 75 6c 64  s that.** should
0490: 20 62 65 20 70 61 73 73 65 64 20 69 6e 74 6f 20   be passed into 
04a0: 73 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 53  sqlite3BtreeSetS
04b0: 61 66 65 74 79 4c 65 76 65 6c 28 29 2e 20 20 54  afetyLevel().  T
04c0: 68 65 20 69 73 20 64 6f 6e 65 0a 2a 2a 20 74 6f  he is done.** to
04d0: 20 73 75 70 70 6f 72 74 20 6c 65 67 61 63 79 20   support legacy 
04e0: 53 51 4c 20 63 6f 64 65 2e 20 20 54 68 65 20 73  SQL code.  The s
04f0: 61 66 65 74 79 20 6c 65 76 65 6c 20 75 73 65 64  afety level used
0500: 20 74 6f 20 62 65 20 62 6f 6f 6c 65 61 6e 0a 2a   to be boolean.*
0510: 2a 20 61 6e 64 20 6f 6c 64 65 72 20 73 63 72 69  * and older scri
0520: 70 74 73 20 6d 61 79 20 68 61 76 65 20 75 73 65  pts may have use
0530: 64 20 6e 75 6d 62 65 72 73 20 30 20 66 6f 72 20  d numbers 0 for 
0540: 4f 46 46 20 61 6e 64 20 31 20 66 6f 72 20 4f 4e  OFF and 1 for ON
0550: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
0560: 67 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28 63  getSafetyLevel(c
0570: 68 61 72 20 2a 7a 29 7b 0a 20 20 73 74 61 74 69  har *z){.  stati
0580: 63 20 63 6f 6e 73 74 20 73 74 72 75 63 74 20 7b  c const struct {
0590: 0a 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20  .    const char 
05a0: 2a 7a 57 6f 72 64 3b 0a 20 20 20 20 69 6e 74 20  *zWord;.    int 
05b0: 76 61 6c 3b 0a 20 20 7d 20 61 4b 65 79 5b 5d 20  val;.  } aKey[] 
05c0: 3d 20 7b 0a 20 20 20 20 7b 20 22 6e 6f 22 2c 20  = {.    { "no", 
05d0: 20 20 20 30 20 7d 2c 0a 20 20 20 20 7b 20 22 6f     0 },.    { "o
05e0: 66 66 22 2c 20 20 20 30 20 7d 2c 0a 20 20 20 20  ff",   0 },.    
05f0: 7b 20 22 66 61 6c 73 65 22 2c 20 30 20 7d 2c 0a  { "false", 0 },.
0600: 20 20 20 20 7b 20 22 79 65 73 22 2c 20 20 20 31      { "yes",   1
0610: 20 7d 2c 0a 20 20 20 20 7b 20 22 6f 6e 22 2c 20   },.    { "on", 
0620: 20 20 20 31 20 7d 2c 0a 20 20 20 20 7b 20 22 74     1 },.    { "t
0630: 72 75 65 22 2c 20 20 31 20 7d 2c 0a 20 20 20 20  rue",  1 },.    
0640: 7b 20 22 66 75 6c 6c 22 2c 20 20 32 20 7d 2c 0a  { "full",  2 },.
0650: 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20    };.  int i;.  
0660: 69 66 28 20 7a 5b 30 5d 3d 3d 30 20 29 20 72 65  if( z[0]==0 ) re
0670: 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20 69 73  turn 1;.  if( is
0680: 64 69 67 69 74 28 7a 5b 30 5d 29 20 7c 7c 20 28  digit(z[0]) || (
0690: 7a 5b 30 5d 3d 3d 27 2d 27 20 26 26 20 69 73 64  z[0]=='-' && isd
06a0: 69 67 69 74 28 7a 5b 31 5d 29 29 20 29 7b 0a 20  igit(z[1])) ){. 
06b0: 20 20 20 72 65 74 75 72 6e 20 61 74 6f 69 28 7a     return atoi(z
06c0: 29 3b 0a 20 20 7d 0a 20 20 66 6f 72 28 69 3d 30  );.  }.  for(i=0
06d0: 3b 20 69 3c 73 69 7a 65 6f 66 28 61 4b 65 79 29  ; i<sizeof(aKey)
06e0: 2f 73 69 7a 65 6f 66 28 61 4b 65 79 5b 30 5d 29  /sizeof(aKey[0])
06f0: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20  ; i++){.    if( 
0700: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
0710: 2c 61 4b 65 79 5b 69 5d 2e 7a 57 6f 72 64 29 3d  ,aKey[i].zWord)=
0720: 3d 30 20 29 20 72 65 74 75 72 6e 20 61 4b 65 79  =0 ) return aKey
0730: 5b 69 5d 2e 76 61 6c 3b 0a 20 20 7d 0a 20 20 72  [i].val;.  }.  r
0740: 65 74 75 72 6e 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a  eturn 1;.}../*.*
0750: 2a 20 49 6e 74 65 72 70 72 65 74 20 74 68 65 20  * Interpret the 
0760: 67 69 76 65 6e 20 73 74 72 69 6e 67 20 61 73 20  given string as 
0770: 61 20 74 65 6d 70 20 64 62 20 6c 6f 63 61 74 69  a temp db locati
0780: 6f 6e 2e 20 52 65 74 75 72 6e 20 31 20 66 6f 72  on. Return 1 for
0790: 20 66 69 6c 65 0a 2a 2a 20 62 61 63 6b 65 64 20   file.** backed 
07a0: 74 65 6d 70 6f 72 61 72 79 20 64 61 74 61 62 61  temporary databa
07b0: 73 65 73 2c 20 32 20 66 6f 72 20 74 68 65 20 52  ses, 2 for the R
07c0: 65 64 2d 42 6c 61 63 6b 20 74 72 65 65 20 69 6e  ed-Black tree in
07d0: 20 6d 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65   memory database
07e0: 0a 2a 2a 20 61 6e 64 20 30 20 74 6f 20 75 73 65  .** and 0 to use
07f0: 20 74 68 65 20 63 6f 6d 70 69 6c 65 2d 74 69 6d   the compile-tim
0800: 65 20 64 65 66 61 75 6c 74 2e 0a 2a 2f 0a 73 74  e default..*/.st
0810: 61 74 69 63 20 69 6e 74 20 67 65 74 54 65 6d 70  atic int getTemp
0820: 53 74 6f 72 65 28 63 6f 6e 73 74 20 63 68 61 72  Store(const char
0830: 20 2a 7a 29 7b 0a 20 20 69 66 28 20 7a 5b 30 5d   *z){.  if( z[0]
0840: 3e 3d 27 30 27 20 26 26 20 7a 5b 30 5d 3c 3d 27  >='0' && z[0]<='
0850: 32 27 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e  2' ){.    return
0860: 20 7a 5b 30 5d 20 2d 20 27 30 27 3b 0a 20 20 7d   z[0] - '0';.  }
0870: 65 6c 73 65 20 69 66 28 20 73 71 6c 69 74 65 33  else if( sqlite3
0880: 53 74 72 49 43 6d 70 28 7a 2c 20 22 66 69 6c 65  StrICmp(z, "file
0890: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74  ")==0 ){.    ret
08a0: 75 72 6e 20 31 3b 0a 20 20 7d 65 6c 73 65 20 69  urn 1;.  }else i
08b0: 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d  f( sqlite3StrICm
08c0: 70 28 7a 2c 20 22 6d 65 6d 6f 72 79 22 29 3d 3d  p(z, "memory")==
08d0: 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  0 ){.    return 
08e0: 32 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  2;.  }else{.    
08f0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 7d 0a  return 0;.  }.}.
0900: 0a 2f 2a 0a 2a 2a 20 49 66 20 74 68 65 20 54 45  ./*.** If the TE
0910: 4d 50 20 64 61 74 61 62 61 73 65 20 69 73 20 6f  MP database is o
0920: 70 65 6e 2c 20 63 6c 6f 73 65 20 69 74 20 61 6e  pen, close it an
0930: 64 20 6d 61 72 6b 20 74 68 65 20 64 61 74 61 62  d mark the datab
0940: 61 73 65 20 73 63 68 65 6d 61 0a 2a 2a 20 61 73  ase schema.** as
0950: 20 6e 65 65 64 69 6e 67 20 72 65 6c 6f 61 64 69   needing reloadi
0960: 6e 67 2e 20 20 54 68 69 73 20 6d 75 73 74 20 62  ng.  This must b
0970: 65 20 64 6f 6e 65 20 77 68 65 6e 20 75 73 69 6e  e done when usin
0980: 67 20 74 68 65 20 54 45 4d 50 5f 53 54 4f 52 45  g the TEMP_STORE
0990: 0a 2a 2a 20 6f 72 20 44 45 46 41 55 4c 54 5f 54  .** or DEFAULT_T
09a0: 45 4d 50 5f 53 54 4f 52 45 20 70 72 61 67 6d 61  EMP_STORE pragma
09b0: 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  s..*/.static int
09c0: 20 63 68 61 6e 67 65 54 65 6d 70 53 74 6f 72 61   changeTempStora
09d0: 67 65 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  ge(Parse *pParse
09e0: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53  , const char *zS
09f0: 74 6f 72 61 67 65 54 79 70 65 29 7b 0a 20 20 69  torageType){.  i
0a00: 6e 74 20 74 73 20 3d 20 67 65 74 54 65 6d 70 53  nt ts = getTempS
0a10: 74 6f 72 65 28 7a 53 74 6f 72 61 67 65 54 79 70  tore(zStorageTyp
0a20: 65 29 3b 0a 20 20 73 71 6c 69 74 65 20 2a 64 62  e);.  sqlite *db
0a30: 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20   = pParse->db;. 
0a40: 20 69 66 28 20 64 62 2d 3e 74 65 6d 70 5f 73 74   if( db->temp_st
0a50: 6f 72 65 3d 3d 74 73 20 29 20 72 65 74 75 72 6e  ore==ts ) return
0a60: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 66   SQLITE_OK;.  if
0a70: 28 20 64 62 2d 3e 61 44 62 5b 31 5d 2e 70 42 74  ( db->aDb[1].pBt
0a80: 21 3d 30 20 29 7b 0a 20 20 20 20 69 66 28 20 64  !=0 ){.    if( d
0a90: 62 2d 3e 66 6c 61 67 73 20 26 20 53 51 4c 49 54  b->flags & SQLIT
0aa0: 45 5f 49 6e 54 72 61 6e 73 20 29 7b 0a 20 20 20  E_InTrans ){.   
0ab0: 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d     sqlite3ErrorM
0ac0: 73 67 28 70 50 61 72 73 65 2c 20 22 74 65 6d 70  sg(pParse, "temp
0ad0: 6f 72 61 72 79 20 73 74 6f 72 61 67 65 20 63 61  orary storage ca
0ae0: 6e 6e 6f 74 20 62 65 20 63 68 61 6e 67 65 64 20  nnot be changed 
0af0: 22 0a 20 20 20 20 20 20 20 20 22 66 72 6f 6d 20  ".        "from 
0b00: 77 69 74 68 69 6e 20 61 20 74 72 61 6e 73 61 63  within a transac
0b10: 74 69 6f 6e 22 29 3b 0a 20 20 20 20 20 20 72 65  tion");.      re
0b20: 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f  turn SQLITE_ERRO
0b30: 52 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c  R;.    }.    sql
0b40: 69 74 65 33 42 74 72 65 65 43 6c 6f 73 65 28 64  ite3BtreeClose(d
0b50: 62 2d 3e 61 44 62 5b 31 5d 2e 70 42 74 29 3b 0a  b->aDb[1].pBt);.
0b60: 20 20 20 20 64 62 2d 3e 61 44 62 5b 31 5d 2e 70      db->aDb[1].p
0b70: 42 74 20 3d 20 30 3b 0a 20 20 20 20 73 71 6c 69  Bt = 0;.    sqli
0b80: 74 65 33 52 65 73 65 74 49 6e 74 65 72 6e 61 6c  te3ResetInternal
0b90: 53 63 68 65 6d 61 28 64 62 2c 20 30 29 3b 0a 20  Schema(db, 0);. 
0ba0: 20 7d 0a 20 20 64 62 2d 3e 74 65 6d 70 5f 73 74   }.  db->temp_st
0bb0: 6f 72 65 20 3d 20 74 73 3b 0a 20 20 72 65 74 75  ore = ts;.  retu
0bc0: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
0bd0: 0a 2f 2a 0a 2a 2a 20 43 68 65 63 6b 20 74 6f 20  ./*.** Check to 
0be0: 73 65 65 20 69 66 20 7a 52 69 67 68 74 20 61 6e  see if zRight an
0bf0: 64 20 7a 4c 65 66 74 20 72 65 66 65 72 20 74 6f  d zLeft refer to
0c00: 20 61 20 70 72 61 67 6d 61 20 74 68 61 74 20 71   a pragma that q
0c10: 75 65 72 69 65 73 0a 2a 2a 20 6f 72 20 63 68 61  ueries.** or cha
0c20: 6e 67 65 73 20 6f 6e 65 20 6f 66 20 74 68 65 20  nges one of the 
0c30: 66 6c 61 67 73 20 69 6e 20 64 62 2d 3e 66 6c 61  flags in db->fla
0c40: 67 73 2e 20 20 52 65 74 75 72 6e 20 31 20 69 66  gs.  Return 1 if
0c50: 20 73 6f 20 61 6e 64 20 30 20 69 66 20 6e 6f 74   so and 0 if not
0c60: 2e 0a 2a 2a 20 41 6c 73 6f 2c 20 69 6d 70 6c 65  ..** Also, imple
0c70: 6d 65 6e 74 20 74 68 65 20 70 72 61 67 6d 61 2e  ment the pragma.
0c80: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 66  .*/.static int f
0c90: 6c 61 67 50 72 61 67 6d 61 28 50 61 72 73 65 20  lagPragma(Parse 
0ca0: 2a 70 50 61 72 73 65 2c 20 63 6f 6e 73 74 20 63  *pParse, const c
0cb0: 68 61 72 20 2a 7a 4c 65 66 74 2c 20 63 6f 6e 73  har *zLeft, cons
0cc0: 74 20 63 68 61 72 20 2a 7a 52 69 67 68 74 29 7b  t char *zRight){
0cd0: 0a 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20  .  static const 
0ce0: 73 74 72 75 63 74 20 7b 0a 20 20 20 20 63 6f 6e  struct {.    con
0cf0: 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 20  st char *zName; 
0d00: 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 68 65 20   /* Name of the 
0d10: 70 72 61 67 6d 61 20 2a 2f 0a 20 20 20 20 69 6e  pragma */.    in
0d20: 74 20 6d 61 73 6b 3b 20 20 20 20 20 20 20 20 20  t mask;         
0d30: 20 20 2f 2a 20 4d 61 73 6b 20 66 6f 72 20 74 68    /* Mask for th
0d40: 65 20 64 62 2d 3e 66 6c 61 67 73 20 76 61 6c 75  e db->flags valu
0d50: 65 20 2a 2f 0a 20 20 7d 20 61 50 72 61 67 6d 61  e */.  } aPragma
0d60: 5b 5d 20 3d 20 7b 0a 20 20 20 20 7b 20 22 76 64  [] = {.    { "vd
0d70: 62 65 5f 74 72 61 63 65 22 2c 20 20 20 20 20 20  be_trace",      
0d80: 20 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f           SQLITE_
0d90: 56 64 62 65 54 72 61 63 65 20 20 20 20 20 7d 2c  VdbeTrace     },
0da0: 0a 20 20 20 20 7b 20 22 66 75 6c 6c 5f 63 6f 6c  .    { "full_col
0db0: 75 6d 6e 5f 6e 61 6d 65 73 22 2c 20 20 20 20 20  umn_names",     
0dc0: 20 20 20 53 51 4c 49 54 45 5f 46 75 6c 6c 43 6f     SQLITE_FullCo
0dd0: 6c 4e 61 6d 65 73 20 20 7d 2c 0a 20 20 20 20 7b  lNames  },.    {
0de0: 20 22 73 68 6f 72 74 5f 63 6f 6c 75 6d 6e 5f 6e   "short_column_n
0df0: 61 6d 65 73 22 2c 20 20 20 20 20 20 20 53 51 4c  ames",       SQL
0e00: 49 54 45 5f 53 68 6f 72 74 43 6f 6c 4e 61 6d 65  ITE_ShortColName
0e10: 73 20 7d 2c 0a 20 20 20 20 7b 20 22 73 68 6f 77  s },.    { "show
0e20: 5f 64 61 74 61 74 79 70 65 73 22 2c 20 20 20 20  _datatypes",    
0e30: 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f 52 65         SQLITE_Re
0e40: 70 6f 72 74 54 79 70 65 73 20 20 20 7d 2c 0a 20  portTypes   },. 
0e50: 20 20 20 7b 20 22 63 6f 75 6e 74 5f 63 68 61 6e     { "count_chan
0e60: 67 65 73 22 2c 20 20 20 20 20 20 20 20 20 20 20  ges",           
0e70: 20 53 51 4c 49 54 45 5f 43 6f 75 6e 74 52 6f 77   SQLITE_CountRow
0e80: 73 20 20 20 20 20 7d 2c 0a 20 20 20 20 7b 20 22  s     },.    { "
0e90: 65 6d 70 74 79 5f 72 65 73 75 6c 74 5f 63 61 6c  empty_result_cal
0ea0: 6c 62 61 63 6b 73 22 2c 20 20 20 53 51 4c 49 54  lbacks",   SQLIT
0eb0: 45 5f 4e 75 6c 6c 43 61 6c 6c 62 61 63 6b 20 20  E_NullCallback  
0ec0: 7d 2c 0a 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b  },.  };.  int i;
0ed0: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 73 69  .  for(i=0; i<si
0ee0: 7a 65 6f 66 28 61 50 72 61 67 6d 61 29 2f 73 69  zeof(aPragma)/si
0ef0: 7a 65 6f 66 28 61 50 72 61 67 6d 61 5b 30 5d 29  zeof(aPragma[0])
0f00: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20  ; i++){.    if( 
0f10: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
0f20: 4c 65 66 74 2c 20 61 50 72 61 67 6d 61 5b 69 5d  Left, aPragma[i]
0f30: 2e 7a 4e 61 6d 65 29 3d 3d 30 20 29 7b 0a 20 20  .zName)==0 ){.  
0f40: 20 20 20 20 73 71 6c 69 74 65 20 2a 64 62 20 3d      sqlite *db =
0f50: 20 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 20   pParse->db;.   
0f60: 20 20 20 56 64 62 65 20 2a 76 3b 0a 20 20 20 20     Vdbe *v;.    
0f70: 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 4c 65    if( strcmp(zLe
0f80: 66 74 2c 7a 52 69 67 68 74 29 3d 3d 30 20 26 26  ft,zRight)==0 &&
0f90: 20 28 76 20 3d 20 73 71 6c 69 74 65 33 47 65 74   (v = sqlite3Get
0fa0: 56 64 62 65 28 70 50 61 72 73 65 29 29 21 3d 30  Vdbe(pParse))!=0
0fb0: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
0fc0: 74 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50  te3VdbeOp3(v, OP
0fd0: 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 30 2c 20  _ColumnName, 0, 
0fe0: 31 2c 20 61 50 72 61 67 6d 61 5b 69 5d 2e 7a 4e  1, aPragma[i].zN
0ff0: 61 6d 65 2c 20 50 33 5f 53 54 41 54 49 43 29 3b  ame, P3_STATIC);
1000: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
1010: 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 43 6f  VdbeOp3(v, OP_Co
1020: 6c 75 6d 6e 4e 61 6d 65 2c 20 31 2c 20 30 2c 20  lumnName, 1, 0, 
1030: 22 62 6f 6f 6c 65 61 6e 22 2c 20 50 33 5f 53 54  "boolean", P3_ST
1040: 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 73  ATIC);.        s
1050: 71 6c 69 74 65 33 56 64 62 65 43 6f 64 65 28 76  qlite3VdbeCode(v
1060: 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 28 64  , OP_Integer, (d
1070: 62 2d 3e 66 6c 61 67 73 20 26 20 61 50 72 61 67  b->flags & aPrag
1080: 6d 61 5b 69 5d 2e 6d 61 73 6b 29 21 3d 30 2c 20  ma[i].mask)!=0, 
1090: 30 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  0,.             
10a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 4f 50 5f               OP_
10b0: 43 61 6c 6c 62 61 63 6b 2c 20 31 2c 20 30 2c 0a  Callback, 1, 0,.
10c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
10d0: 20 20 20 20 20 20 20 20 20 20 30 29 3b 0a 20 20            0);.  
10e0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 67 65      }else if( ge
10f0: 74 42 6f 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29  tBoolean(zRight)
1100: 20 29 7b 0a 20 20 20 20 20 20 20 20 64 62 2d 3e   ){.        db->
1110: 66 6c 61 67 73 20 7c 3d 20 61 50 72 61 67 6d 61  flags |= aPragma
1120: 5b 69 5d 2e 6d 61 73 6b 3b 0a 20 20 20 20 20 20  [i].mask;.      
1130: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 64  }else{.        d
1140: 62 2d 3e 66 6c 61 67 73 20 26 3d 20 7e 61 50 72  b->flags &= ~aPr
1150: 61 67 6d 61 5b 69 5d 2e 6d 61 73 6b 3b 0a 20 20  agma[i].mask;.  
1160: 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65 74 75      }.      retu
1170: 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  rn 1;.    }.  }.
1180: 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f    return 0;.}../
1190: 2a 0a 2a 2a 20 50 72 6f 63 65 73 73 20 61 20 70  *.** Process a p
11a0: 72 61 67 6d 61 20 73 74 61 74 65 6d 65 6e 74 2e  ragma statement.
11b0: 20 20 0a 2a 2a 0a 2a 2a 20 50 72 61 67 6d 61 73    .**.** Pragmas
11c0: 20 61 72 65 20 6f 66 20 74 68 69 73 20 66 6f 72   are of this for
11d0: 6d 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 20 50 52  m:.**.**      PR
11e0: 41 47 4d 41 20 69 64 20 3d 20 76 61 6c 75 65 0a  AGMA id = value.
11f0: 2a 2a 0a 2a 2a 20 54 68 65 20 69 64 65 6e 74 69  **.** The identi
1200: 66 69 65 72 20 6d 69 67 68 74 20 61 6c 73 6f 20  fier might also 
1210: 62 65 20 61 20 73 74 72 69 6e 67 2e 20 20 54 68  be a string.  Th
1220: 65 20 76 61 6c 75 65 20 69 73 20 61 20 73 74 72  e value is a str
1230: 69 6e 67 2c 20 61 6e 64 0a 2a 2a 20 69 64 65 6e  ing, and.** iden
1240: 74 69 66 69 65 72 2c 20 6f 72 20 61 20 6e 75 6d  tifier, or a num
1250: 62 65 72 2e 20 20 49 66 20 6d 69 6e 75 73 46 6c  ber.  If minusFl
1260: 61 67 20 69 73 20 74 72 75 65 2c 20 74 68 65 6e  ag is true, then
1270: 20 74 68 65 20 76 61 6c 75 65 20 69 73 0a 2a 2a   the value is.**
1280: 20 61 20 6e 75 6d 62 65 72 20 74 68 61 74 20 77   a number that w
1290: 61 73 20 70 72 65 63 65 64 65 64 20 62 79 20 61  as preceded by a
12a0: 20 6d 69 6e 75 73 20 73 69 67 6e 2e 0a 2a 2f 0a   minus sign..*/.
12b0: 76 6f 69 64 20 73 71 6c 69 74 65 33 50 72 61 67  void sqlite3Prag
12c0: 6d 61 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  ma(Parse *pParse
12d0: 2c 20 54 6f 6b 65 6e 20 2a 70 4c 65 66 74 2c 20  , Token *pLeft, 
12e0: 54 6f 6b 65 6e 20 2a 70 52 69 67 68 74 2c 20 69  Token *pRight, i
12f0: 6e 74 20 6d 69 6e 75 73 46 6c 61 67 29 7b 0a 20  nt minusFlag){. 
1300: 20 63 68 61 72 20 2a 7a 4c 65 66 74 20 3d 20 30   char *zLeft = 0
1310: 3b 0a 20 20 63 68 61 72 20 2a 7a 52 69 67 68 74  ;.  char *zRight
1320: 20 3d 20 30 3b 0a 20 20 73 71 6c 69 74 65 20 2a   = 0;.  sqlite *
1330: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
1340: 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71 6c  .  Vdbe *v = sql
1350: 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72  ite3GetVdbe(pPar
1360: 73 65 29 3b 0a 20 20 69 66 28 20 76 3d 3d 30 20  se);.  if( v==0 
1370: 29 20 72 65 74 75 72 6e 3b 0a 0a 20 20 7a 4c 65  ) return;..  zLe
1380: 66 74 20 3d 20 73 71 6c 69 74 65 53 74 72 4e 44  ft = sqliteStrND
1390: 75 70 28 70 4c 65 66 74 2d 3e 7a 2c 20 70 4c 65  up(pLeft->z, pLe
13a0: 66 74 2d 3e 6e 29 3b 0a 20 20 73 71 6c 69 74 65  ft->n);.  sqlite
13b0: 33 44 65 71 75 6f 74 65 28 7a 4c 65 66 74 29 3b  3Dequote(zLeft);
13c0: 0a 20 20 69 66 28 20 6d 69 6e 75 73 46 6c 61 67  .  if( minusFlag
13d0: 20 29 7b 0a 20 20 20 20 7a 52 69 67 68 74 20 3d   ){.    zRight =
13e0: 20 30 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 53   0;.    sqlite3S
13f0: 65 74 4e 53 74 72 69 6e 67 28 26 7a 52 69 67 68  etNString(&zRigh
1400: 74 2c 20 22 2d 22 2c 20 31 2c 20 70 52 69 67 68  t, "-", 1, pRigh
1410: 74 2d 3e 7a 2c 20 70 52 69 67 68 74 2d 3e 6e 2c  t->z, pRight->n,
1420: 20 30 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20   0);.  }else{.  
1430: 20 20 7a 52 69 67 68 74 20 3d 20 73 71 6c 69 74    zRight = sqlit
1440: 65 53 74 72 4e 44 75 70 28 70 52 69 67 68 74 2d  eStrNDup(pRight-
1450: 3e 7a 2c 20 70 52 69 67 68 74 2d 3e 6e 29 3b 0a  >z, pRight->n);.
1460: 20 20 20 20 73 71 6c 69 74 65 33 44 65 71 75 6f      sqlite3Dequo
1470: 74 65 28 7a 52 69 67 68 74 29 3b 0a 20 20 7d 0a  te(zRight);.  }.
1480: 20 20 69 66 28 20 73 71 6c 69 74 65 33 41 75 74    if( sqlite3Aut
1490: 68 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20 53  hCheck(pParse, S
14a0: 51 4c 49 54 45 5f 50 52 41 47 4d 41 2c 20 7a 4c  QLITE_PRAGMA, zL
14b0: 65 66 74 2c 20 7a 52 69 67 68 74 2c 20 30 29 20  eft, zRight, 0) 
14c0: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 46 72 65  ){.    sqliteFre
14d0: 65 28 7a 4c 65 66 74 29 3b 0a 20 20 20 20 73 71  e(zLeft);.    sq
14e0: 6c 69 74 65 46 72 65 65 28 7a 52 69 67 68 74 29  liteFree(zRight)
14f0: 3b 0a 20 20 20 20 72 65 74 75 72 6e 3b 0a 20 20  ;.    return;.  
1500: 7d 0a 20 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 50  }. .  /*.  **  P
1510: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61  RAGMA default_ca
1520: 63 68 65 5f 73 69 7a 65 0a 20 20 2a 2a 20 20 50  che_size.  **  P
1530: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61  RAGMA default_ca
1540: 63 68 65 5f 73 69 7a 65 3d 4e 0a 20 20 2a 2a 0a  che_size=N.  **.
1550: 20 20 2a 2a 20 54 68 65 20 66 69 72 73 74 20 66    ** The first f
1560: 6f 72 6d 20 72 65 70 6f 72 74 73 20 74 68 65 20  orm reports the 
1570: 63 75 72 72 65 6e 74 20 70 65 72 73 69 73 74 65  current persiste
1580: 6e 74 20 73 65 74 74 69 6e 67 20 66 6f 72 20 74  nt setting for t
1590: 68 65 0a 20 20 2a 2a 20 70 61 67 65 20 63 61 63  he.  ** page cac
15a0: 68 65 20 73 69 7a 65 2e 20 20 54 68 65 20 76 61  he size.  The va
15b0: 6c 75 65 20 72 65 74 75 72 6e 65 64 20 69 73 20  lue returned is 
15c0: 74 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  the maximum numb
15d0: 65 72 20 6f 66 0a 20 20 2a 2a 20 70 61 67 65 73  er of.  ** pages
15e0: 20 69 6e 20 74 68 65 20 70 61 67 65 20 63 61 63   in the page cac
15f0: 68 65 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20  he.  The second 
1600: 66 6f 72 6d 20 73 65 74 73 20 62 6f 74 68 20 74  form sets both t
1610: 68 65 20 63 75 72 72 65 6e 74 0a 20 20 2a 2a 20  he current.  ** 
1620: 70 61 67 65 20 63 61 63 68 65 20 73 69 7a 65 20  page cache size 
1630: 76 61 6c 75 65 20 61 6e 64 20 74 68 65 20 70 65  value and the pe
1640: 72 73 69 73 74 65 6e 74 20 70 61 67 65 20 63 61  rsistent page ca
1650: 63 68 65 20 73 69 7a 65 20 76 61 6c 75 65 0a 20  che size value. 
1660: 20 2a 2a 20 73 74 6f 72 65 64 20 69 6e 20 74 68   ** stored in th
1670: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  e database file.
1680: 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 64  .  **.  ** The d
1690: 65 66 61 75 6c 74 20 63 61 63 68 65 20 73 69 7a  efault cache siz
16a0: 65 20 69 73 20 73 74 6f 72 65 64 20 69 6e 20 6d  e is stored in m
16b0: 65 74 61 2d 76 61 6c 75 65 20 32 20 6f 66 20 70  eta-value 2 of p
16c0: 61 67 65 20 31 20 6f 66 20 74 68 65 0a 20 20 2a  age 1 of the.  *
16d0: 2a 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  * database file.
16e0: 20 20 54 68 65 20 63 61 63 68 65 20 73 69 7a 65    The cache size
16f0: 20 69 73 20 61 63 74 75 61 6c 6c 79 20 74 68 65   is actually the
1700: 20 61 62 73 6f 6c 75 74 65 20 76 61 6c 75 65 20   absolute value 
1710: 6f 66 0a 20 20 2a 2a 20 74 68 69 73 20 6d 65 6d  of.  ** this mem
1720: 6f 72 79 20 6c 6f 63 61 74 69 6f 6e 2e 20 20 54  ory location.  T
1730: 68 65 20 73 69 67 6e 20 6f 66 20 6d 65 74 61 2d  he sign of meta-
1740: 76 61 6c 75 65 20 32 20 64 65 74 65 72 6d 69 6e  value 2 determin
1750: 65 73 20 74 68 65 0a 20 20 2a 2a 20 73 79 6e 63  es the.  ** sync
1760: 68 72 6f 6e 6f 75 73 20 73 65 74 74 69 6e 67 2e  hronous setting.
1770: 20 20 41 20 6e 65 67 61 74 69 76 65 20 76 61 6c    A negative val
1780: 75 65 20 6d 65 61 6e 73 20 73 79 6e 63 68 72 6f  ue means synchro
1790: 6e 6f 75 73 20 69 73 20 6f 66 66 0a 20 20 2a 2a  nous is off.  **
17a0: 20 61 6e 64 20 61 20 70 6f 73 69 74 69 76 65 20   and a positive 
17b0: 76 61 6c 75 65 20 6d 65 61 6e 73 20 73 79 6e 63  value means sync
17c0: 68 72 6f 6e 6f 75 73 20 69 73 20 6f 6e 2e 0a 20  hronous is on.. 
17d0: 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65   */.  if( sqlite
17e0: 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22  3StrICmp(zLeft,"
17f0: 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73 69  default_cache_si
1800: 7a 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73  ze")==0 ){.    s
1810: 74 61 74 69 63 20 56 64 62 65 4f 70 4c 69 73 74  tatic VdbeOpList
1820: 20 67 65 74 43 61 63 68 65 53 69 7a 65 5b 5d 20   getCacheSize[] 
1830: 3d 20 7b 0a 20 20 20 20 20 20 7b 20 4f 50 5f 52  = {.      { OP_R
1840: 65 61 64 43 6f 6f 6b 69 65 2c 20 20 30 2c 20 32  eadCookie,  0, 2
1850: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
1860: 20 20 20 7b 20 4f 50 5f 41 62 73 56 61 6c 75 65     { OP_AbsValue
1870: 2c 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20  ,    0, 0,      
1880: 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50    0},.      { OP
1890: 5f 44 75 70 2c 20 20 20 20 20 20 20 20 20 30 2c  _Dup,         0,
18a0: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20   0,        0},. 
18b0: 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65       { OP_Intege
18c0: 72 2c 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20  r,     0, 0,    
18d0: 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20      0},.      { 
18e0: 4f 50 5f 4e 65 2c 20 20 20 20 20 20 20 20 20 20  OP_Ne,          
18f0: 30 2c 20 36 2c 20 20 20 20 20 20 20 20 30 7d 2c  0, 6,        0},
1900: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65  .      { OP_Inte
1910: 67 65 72 2c 20 20 20 20 20 30 2c 20 30 2c 20 20  ger,     0, 0,  
1920: 20 20 20 20 20 20 30 7d 2c 20 20 2f 2a 20 35 20        0},  /* 5 
1930: 2a 2f 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f  */.      { OP_Co
1940: 6c 75 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 31 2c  lumnName,  0, 1,
1950: 20 20 20 20 20 20 20 20 22 63 61 63 68 65 5f 73          "cache_s
1960: 69 7a 65 22 7d 2c 0a 20 20 20 20 20 20 7b 20 4f  ize"},.      { O
1970: 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31  P_Callback,    1
1980: 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a  , 0,        0},.
1990: 20 20 20 20 7d 3b 0a 20 20 20 20 69 6e 74 20 61      };.    int a
19a0: 64 64 72 3b 0a 20 20 20 20 69 66 28 20 70 52 69  ddr;.    if( pRi
19b0: 67 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a  ght->z==pLeft->z
19c0: 20 29 7b 0a 20 20 20 20 20 20 61 64 64 72 20 3d   ){.      addr =
19d0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
19e0: 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69  pList(v, ArraySi
19f0: 7a 65 28 67 65 74 43 61 63 68 65 53 69 7a 65 29  ze(getCacheSize)
1a00: 2c 20 67 65 74 43 61 63 68 65 53 69 7a 65 29 3b  , getCacheSize);
1a10: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
1a20: 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20 61 64  beChangeP1(v, ad
1a30: 64 72 2b 35 2c 20 4d 41 58 5f 50 41 47 45 53 29  dr+5, MAX_PAGES)
1a40: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
1a50: 20 20 20 69 6e 74 20 73 69 7a 65 20 3d 20 61 74     int size = at
1a60: 6f 69 28 7a 52 69 67 68 74 29 3b 0a 20 20 20 20  oi(zRight);.    
1a70: 20 20 69 66 28 20 73 69 7a 65 3c 30 20 29 20 73    if( size<0 ) s
1a80: 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20  ize = -size;.   
1a90: 20 20 20 73 71 6c 69 74 65 33 42 65 67 69 6e 57     sqlite3BeginW
1aa0: 72 69 74 65 4f 70 65 72 61 74 69 6f 6e 28 70 50  riteOperation(pP
1ab0: 61 72 73 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20  arse, 0, 0);.   
1ac0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
1ad0: 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65  dOp(v, OP_Intege
1ae0: 72 2c 20 73 69 7a 65 2c 20 30 29 3b 0a 20 20 20  r, size, 0);.   
1af0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
1b00: 64 4f 70 28 76 2c 20 4f 50 5f 52 65 61 64 43 6f  dOp(v, OP_ReadCo
1b10: 6f 6b 69 65 2c 20 30 2c 20 32 29 3b 0a 20 20 20  okie, 0, 2);.   
1b20: 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65     addr = sqlite
1b30: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
1b40: 5f 49 6e 74 65 67 65 72 2c 20 30 2c 20 30 29 3b  _Integer, 0, 0);
1b50: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
1b60: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 47 65  beAddOp(v, OP_Ge
1b70: 2c 20 30 2c 20 61 64 64 72 2b 33 29 3b 0a 20 20  , 0, addr+3);.  
1b80: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
1b90: 64 64 4f 70 28 76 2c 20 4f 50 5f 4e 65 67 61 74  ddOp(v, OP_Negat
1ba0: 69 76 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  ive, 0, 0);.    
1bb0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
1bc0: 4f 70 28 76 2c 20 4f 50 5f 53 65 74 43 6f 6f 6b  Op(v, OP_SetCook
1bd0: 69 65 2c 20 30 2c 20 32 29 3b 0a 20 20 20 20 20  ie, 0, 2);.     
1be0: 20 73 71 6c 69 74 65 33 45 6e 64 57 72 69 74 65   sqlite3EndWrite
1bf0: 4f 70 65 72 61 74 69 6f 6e 28 70 50 61 72 73 65  Operation(pParse
1c00: 29 3b 0a 20 20 20 20 20 20 64 62 2d 3e 63 61 63  );.      db->cac
1c10: 68 65 5f 73 69 7a 65 20 3d 20 64 62 2d 3e 63 61  he_size = db->ca
1c20: 63 68 65 5f 73 69 7a 65 3c 30 20 3f 20 2d 73 69  che_size<0 ? -si
1c30: 7a 65 20 3a 20 73 69 7a 65 3b 0a 20 20 20 20 20  ze : size;.     
1c40: 20 73 71 6c 69 74 65 33 42 74 72 65 65 53 65 74   sqlite3BtreeSet
1c50: 43 61 63 68 65 53 69 7a 65 28 64 62 2d 3e 61 44  CacheSize(db->aD
1c60: 62 5b 30 5d 2e 70 42 74 2c 20 64 62 2d 3e 63 61  b[0].pBt, db->ca
1c70: 63 68 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20 7d  che_size);.    }
1c80: 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20  .  }else..  /*. 
1c90: 20 2a 2a 20 20 50 52 41 47 4d 41 20 63 61 63 68   **  PRAGMA cach
1ca0: 65 5f 73 69 7a 65 0a 20 20 2a 2a 20 20 50 52 41  e_size.  **  PRA
1cb0: 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3d 4e  GMA cache_size=N
1cc0: 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 66  .  **.  ** The f
1cd0: 69 72 73 74 20 66 6f 72 6d 20 72 65 70 6f 72 74  irst form report
1ce0: 73 20 74 68 65 20 63 75 72 72 65 6e 74 20 6c 6f  s the current lo
1cf0: 63 61 6c 20 73 65 74 74 69 6e 67 20 66 6f 72 20  cal setting for 
1d00: 74 68 65 0a 20 20 2a 2a 20 70 61 67 65 20 63 61  the.  ** page ca
1d10: 63 68 65 20 73 69 7a 65 2e 20 20 54 68 65 20 6c  che size.  The l
1d20: 6f 63 61 6c 20 73 65 74 74 69 6e 67 20 63 61 6e  ocal setting can
1d30: 20 62 65 20 64 69 66 66 65 72 65 6e 74 20 66 72   be different fr
1d40: 6f 6d 0a 20 20 2a 2a 20 74 68 65 20 70 65 72 73  om.  ** the pers
1d50: 69 73 74 65 6e 74 20 63 61 63 68 65 20 73 69 7a  istent cache siz
1d60: 65 20 76 61 6c 75 65 20 74 68 61 74 20 69 73 20  e value that is 
1d70: 73 74 6f 72 65 64 20 69 6e 20 74 68 65 20 64 61  stored in the da
1d80: 74 61 62 61 73 65 0a 20 20 2a 2a 20 66 69 6c 65  tabase.  ** file
1d90: 20 69 74 73 65 6c 66 2e 20 20 54 68 65 20 76 61   itself.  The va
1da0: 6c 75 65 20 72 65 74 75 72 6e 65 64 20 69 73 20  lue returned is 
1db0: 74 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  the maximum numb
1dc0: 65 72 20 6f 66 0a 20 20 2a 2a 20 70 61 67 65 73  er of.  ** pages
1dd0: 20 69 6e 20 74 68 65 20 70 61 67 65 20 63 61 63   in the page cac
1de0: 68 65 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20  he.  The second 
1df0: 66 6f 72 6d 20 73 65 74 73 20 74 68 65 20 6c 6f  form sets the lo
1e00: 63 61 6c 0a 20 20 2a 2a 20 70 61 67 65 20 63 61  cal.  ** page ca
1e10: 63 68 65 20 73 69 7a 65 20 76 61 6c 75 65 2e 20  che size value. 
1e20: 20 49 74 20 64 6f 65 73 20 6e 6f 74 20 63 68 61   It does not cha
1e30: 6e 67 65 20 74 68 65 20 70 65 72 73 69 73 74 65  nge the persiste
1e40: 6e 74 0a 20 20 2a 2a 20 63 61 63 68 65 20 73 69  nt.  ** cache si
1e50: 7a 65 20 73 74 6f 72 65 64 20 6f 6e 20 74 68 65  ze stored on the
1e60: 20 64 69 73 6b 20 73 6f 20 74 68 65 20 63 61 63   disk so the cac
1e70: 68 65 20 73 69 7a 65 20 77 69 6c 6c 20 72 65 76  he size will rev
1e80: 65 72 74 0a 20 20 2a 2a 20 74 6f 20 69 74 73 20  ert.  ** to its 
1e90: 64 65 66 61 75 6c 74 20 76 61 6c 75 65 20 77 68  default value wh
1ea0: 65 6e 20 74 68 65 20 64 61 74 61 62 61 73 65 20  en the database 
1eb0: 69 73 20 63 6c 6f 73 65 64 20 61 6e 64 20 72 65  is closed and re
1ec0: 6f 70 65 6e 65 64 2e 0a 20 20 2a 2a 20 4e 20 73  opened..  ** N s
1ed0: 68 6f 75 6c 64 20 62 65 20 61 20 70 6f 73 69 74  hould be a posit
1ee0: 69 76 65 20 69 6e 74 65 67 65 72 2e 0a 20 20 2a  ive integer..  *
1ef0: 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 53  /.  if( sqlite3S
1f00: 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22 63 61  trICmp(zLeft,"ca
1f10: 63 68 65 5f 73 69 7a 65 22 29 3d 3d 30 20 29 7b  che_size")==0 ){
1f20: 0a 20 20 20 20 73 74 61 74 69 63 20 56 64 62 65  .    static Vdbe
1f30: 4f 70 4c 69 73 74 20 67 65 74 43 61 63 68 65 53  OpList getCacheS
1f40: 69 7a 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20  ize[] = {.      
1f50: 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c  { OP_ColumnName,
1f60: 20 20 30 2c 20 31 2c 20 20 20 20 20 20 20 20 22    0, 1,        "
1f70: 63 61 63 68 65 5f 73 69 7a 65 22 7d 2c 0a 20 20  cache_size"},.  
1f80: 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63      { OP_Callbac
1f90: 6b 2c 20 20 20 20 31 2c 20 30 2c 20 20 20 20 20  k,    1, 0,     
1fa0: 20 20 20 30 7d 2c 0a 20 20 20 20 7d 3b 0a 20 20     0},.    };.  
1fb0: 20 20 69 66 28 20 70 52 69 67 68 74 2d 3e 7a 3d    if( pRight->z=
1fc0: 3d 70 4c 65 66 74 2d 3e 7a 20 29 7b 0a 20 20 20  =pLeft->z ){.   
1fd0: 20 20 20 69 6e 74 20 73 69 7a 65 20 3d 20 64 62     int size = db
1fe0: 2d 3e 63 61 63 68 65 5f 73 69 7a 65 3b 3b 0a 20  ->cache_size;;. 
1ff0: 20 20 20 20 20 69 66 28 20 73 69 7a 65 3c 30 20       if( size<0 
2000: 29 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a  ) size = -size;.
2010: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
2020: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74  eAddOp(v, OP_Int
2030: 65 67 65 72 2c 20 73 69 7a 65 2c 20 30 29 3b 0a  eger, size, 0);.
2040: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
2050: 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72  eAddOpList(v, Ar
2060: 72 61 79 53 69 7a 65 28 67 65 74 43 61 63 68 65  raySize(getCache
2070: 53 69 7a 65 29 2c 20 67 65 74 43 61 63 68 65 53  Size), getCacheS
2080: 69 7a 65 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  ize);.    }else{
2090: 0a 20 20 20 20 20 20 69 6e 74 20 73 69 7a 65 20  .      int size 
20a0: 3d 20 61 74 6f 69 28 7a 52 69 67 68 74 29 3b 0a  = atoi(zRight);.
20b0: 20 20 20 20 20 20 69 66 28 20 73 69 7a 65 3c 30        if( size<0
20c0: 20 29 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b   ) size = -size;
20d0: 0a 20 20 20 20 20 20 69 66 28 20 64 62 2d 3e 63  .      if( db->c
20e0: 61 63 68 65 5f 73 69 7a 65 3c 30 20 29 20 73 69  ache_size<0 ) si
20f0: 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20  ze = -size;.    
2100: 20 20 64 62 2d 3e 63 61 63 68 65 5f 73 69 7a 65    db->cache_size
2110: 20 3d 20 73 69 7a 65 3b 0a 20 20 20 20 20 20 73   = size;.      s
2120: 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 43 61  qlite3BtreeSetCa
2130: 63 68 65 53 69 7a 65 28 64 62 2d 3e 61 44 62 5b  cheSize(db->aDb[
2140: 30 5d 2e 70 42 74 2c 20 64 62 2d 3e 63 61 63 68  0].pBt, db->cach
2150: 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20 7d 0a 20  e_size);.    }. 
2160: 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a   }else..  /*.  *
2170: 2a 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c  *  PRAGMA defaul
2180: 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 0a 20 20  t_synchronous.  
2190: 2a 2a 20 20 50 52 41 47 4d 41 20 64 65 66 61 75  **  PRAGMA defau
21a0: 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f  lt_synchronous=O
21b0: 4e 7c 4f 46 46 7c 4e 4f 52 4d 41 4c 7c 46 55 4c  N|OFF|NORMAL|FUL
21c0: 4c 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20  L.  **.  ** The 
21d0: 66 69 72 73 74 20 66 6f 72 6d 20 72 65 74 75 72  first form retur
21e0: 6e 73 20 74 68 65 20 70 65 72 73 69 73 74 65 6e  ns the persisten
21f0: 74 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20 22  t value of the "
2200: 73 79 6e 63 68 72 6f 6e 6f 75 73 22 20 73 65 74  synchronous" set
2210: 74 69 6e 67 0a 20 20 2a 2a 20 74 68 61 74 20 69  ting.  ** that i
2220: 73 20 73 74 6f 72 65 64 20 69 6e 20 74 68 65 20  s stored in the 
2230: 64 61 74 61 62 61 73 65 2e 20 20 54 68 69 73 20  database.  This 
2240: 69 73 20 74 68 65 20 73 79 6e 63 68 72 6f 6e 6f  is the synchrono
2250: 75 73 20 73 65 74 74 69 6e 67 20 74 68 61 74 0a  us setting that.
2260: 20 20 2a 2a 20 69 73 20 75 73 65 64 20 77 68 65    ** is used whe
2270: 6e 65 76 65 72 20 74 68 65 20 64 61 74 61 62 61  never the databa
2280: 73 65 20 69 73 20 6f 70 65 6e 65 64 20 75 6e 6c  se is opened unl
2290: 65 73 73 20 6f 76 65 72 72 69 64 64 65 6e 20 62  ess overridden b
22a0: 79 20 61 20 73 65 70 61 72 61 74 65 0a 20 20 2a  y a separate.  *
22b0: 2a 20 22 73 79 6e 63 68 72 6f 6e 6f 75 73 22 20  * "synchronous" 
22c0: 70 72 61 67 6d 61 2e 20 20 54 68 65 20 73 65 63  pragma.  The sec
22d0: 6f 6e 64 20 66 6f 72 6d 20 63 68 61 6e 67 65 73  ond form changes
22e0: 20 74 68 65 20 70 65 72 73 69 73 74 65 6e 74 20   the persistent 
22f0: 61 6e 64 20 74 68 65 0a 20 20 2a 2a 20 6c 6f 63  and the.  ** loc
2300: 61 6c 20 73 79 6e 63 68 72 6f 6e 6f 75 73 20 73  al synchronous s
2310: 65 74 74 69 6e 67 20 74 6f 20 74 68 65 20 76 61  etting to the va
2320: 6c 75 65 20 67 69 76 65 6e 2e 0a 20 20 2a 2a 0a  lue given..  **.
2330: 20 20 2a 2a 20 49 66 20 73 79 6e 63 68 72 6f 6e    ** If synchron
2340: 6f 75 73 20 69 73 20 4f 46 46 2c 20 53 51 4c 69  ous is OFF, SQLi
2350: 74 65 20 64 6f 65 73 20 6e 6f 74 20 61 74 74 65  te does not atte
2360: 6d 70 74 20 61 6e 79 20 66 73 79 6e 63 28 29 20  mpt any fsync() 
2370: 73 79 73 74 65 6d 73 20 63 61 6c 6c 73 0a 20 20  systems calls.  
2380: 2a 2a 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20  ** to make sure 
2390: 64 61 74 61 20 69 73 20 63 6f 6d 6d 69 74 74 65  data is committe
23a0: 64 20 74 6f 20 64 69 73 6b 2e 20 20 57 72 69 74  d to disk.  Writ
23b0: 65 20 6f 70 65 72 61 74 69 6f 6e 73 20 61 72 65  e operations are
23c0: 20 76 65 72 79 20 66 61 73 74 2c 0a 20 20 2a 2a   very fast,.  **
23d0: 20 62 75 74 20 61 20 70 6f 77 65 72 20 66 61 69   but a power fai
23e0: 6c 75 72 65 20 63 61 6e 20 6c 65 61 76 65 20 74  lure can leave t
23f0: 68 65 20 64 61 74 61 62 61 73 65 20 69 6e 20 61  he database in a
2400: 6e 20 69 6e 63 6f 6e 73 69 73 74 65 6e 74 20 73  n inconsistent s
2410: 74 61 74 65 2e 0a 20 20 2a 2a 20 49 66 20 73 79  tate..  ** If sy
2420: 6e 63 68 72 6f 6e 6f 75 73 20 69 73 20 4f 4e 20  nchronous is ON 
2430: 6f 72 20 4e 4f 52 4d 41 4c 2c 20 53 51 4c 69 74  or NORMAL, SQLit
2440: 65 20 77 69 6c 6c 20 64 6f 20 61 6e 20 66 73 79  e will do an fsy
2450: 6e 63 28 29 20 73 79 73 74 65 6d 20 63 61 6c 6c  nc() system call
2460: 20 74 6f 0a 20 20 2a 2a 20 6d 61 6b 65 20 73 75   to.  ** make su
2470: 72 65 20 64 61 74 61 20 69 73 20 62 65 69 6e 67  re data is being
2480: 20 77 72 69 74 74 65 6e 20 74 6f 20 64 69 73 6b   written to disk
2490: 2e 20 20 54 68 65 20 72 69 73 6b 20 6f 66 20 63  .  The risk of c
24a0: 6f 72 72 75 70 74 69 6f 6e 20 64 75 65 20 74 6f  orruption due to
24b0: 0a 20 20 2a 2a 20 61 20 70 6f 77 65 72 20 6c 6f  .  ** a power lo
24c0: 73 73 20 69 6e 20 74 68 69 73 20 6d 6f 64 65 20  ss in this mode 
24d0: 69 73 20 6e 65 67 6c 69 67 69 62 6c 65 20 62 75  is negligible bu
24e0: 74 20 6e 6f 6e 2d 7a 65 72 6f 2e 20 20 49 66 20  t non-zero.  If 
24f0: 73 79 6e 63 68 72 6f 6e 6f 75 73 0a 20 20 2a 2a  synchronous.  **
2500: 20 69 73 20 46 55 4c 4c 2c 20 65 78 74 72 61 20   is FULL, extra 
2510: 66 73 79 6e 63 28 29 73 20 6f 63 63 75 72 20 74  fsync()s occur t
2520: 6f 20 72 65 64 75 63 65 20 74 68 65 20 72 69 73  o reduce the ris
2530: 6b 20 6f 66 20 63 6f 72 72 75 70 74 69 6f 6e 20  k of corruption 
2540: 74 6f 20 6e 65 61 72 0a 20 20 2a 2a 20 7a 65 72  to near.  ** zer
2550: 6f 2c 20 62 75 74 20 77 69 74 68 20 61 20 77 72  o, but with a wr
2560: 69 74 65 20 70 65 72 66 6f 72 6d 61 6e 63 65 20  ite performance 
2570: 70 65 6e 61 6c 74 79 2e 20 20 54 68 65 20 64 65  penalty.  The de
2580: 66 61 75 6c 74 20 6d 6f 64 65 20 69 73 20 4e 4f  fault mode is NO
2590: 52 4d 41 4c 2e 0a 20 20 2a 2f 0a 20 20 69 66 28  RMAL..  */.  if(
25a0: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
25b0: 7a 4c 65 66 74 2c 22 64 65 66 61 75 6c 74 5f 73  zLeft,"default_s
25c0: 79 6e 63 68 72 6f 6e 6f 75 73 22 29 3d 3d 30 20  ynchronous")==0 
25d0: 29 7b 0a 20 20 20 20 73 74 61 74 69 63 20 56 64  ){.    static Vd
25e0: 62 65 4f 70 4c 69 73 74 20 67 65 74 53 79 6e 63  beOpList getSync
25f0: 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 7b 20 4f  [] = {.      { O
2600: 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 20 30  P_ColumnName,  0
2610: 2c 20 31 2c 20 20 20 20 20 20 20 20 22 73 79 6e  , 1,        "syn
2620: 63 68 72 6f 6e 6f 75 73 22 7d 2c 0a 20 20 20 20  chronous"},.    
2630: 20 20 7b 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69    { OP_ReadCooki
2640: 65 2c 20 20 30 2c 20 33 2c 20 20 20 20 20 20 20  e,  0, 3,       
2650: 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f   0},.      { OP_
2660: 44 75 70 2c 20 20 20 20 20 20 20 20 20 30 2c 20  Dup,         0, 
2670: 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20  0,        0},.  
2680: 20 20 20 20 7b 20 4f 50 5f 49 66 2c 20 20 20 20      { OP_If,    
2690: 20 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20        0, 0,     
26a0: 20 20 20 30 7d 2c 20 20 2f 2a 20 33 20 2a 2f 0a     0},  /* 3 */.
26b0: 20 20 20 20 20 20 7b 20 4f 50 5f 52 65 61 64 43        { OP_ReadC
26c0: 6f 6f 6b 69 65 2c 20 20 30 2c 20 32 2c 20 20 20  ookie,  0, 2,   
26d0: 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b       0},.      {
26e0: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20   OP_Integer,    
26f0: 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   0, 0,        0}
2700: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4c 74 2c  ,.      { OP_Lt,
2710: 20 20 20 20 20 20 20 20 20 20 30 2c 20 35 2c 20            0, 5, 
2720: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20         0},.     
2730: 20 7b 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 20 20   { OP_AddImm,   
2740: 20 20 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20     1, 0,        
2750: 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43  0},.      { OP_C
2760: 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30  allback,    1, 0
2770: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
2780: 20 20 20 7b 20 4f 50 5f 48 61 6c 74 2c 20 20 20     { OP_Halt,   
2790: 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20       0, 0,      
27a0: 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50    0},.      { OP
27b0: 5f 41 64 64 49 6d 6d 2c 20 20 20 20 20 2d 31 2c  _AddImm,     -1,
27c0: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 20 20   0,        0},  
27d0: 2f 2a 20 31 30 20 2a 2f 0a 20 20 20 20 20 20 7b  /* 10 */.      {
27e0: 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 20 20   OP_Callback,   
27f0: 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   1, 0,        0}
2800: 0a 20 20 20 20 7d 3b 0a 20 20 20 20 69 66 28 20  .    };.    if( 
2810: 70 52 69 67 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74  pRight->z==pLeft
2820: 2d 3e 7a 20 29 7b 0a 20 20 20 20 20 20 69 6e 74  ->z ){.      int
2830: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
2840: 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20  dbeAddOpList(v, 
2850: 41 72 72 61 79 53 69 7a 65 28 67 65 74 53 79 6e  ArraySize(getSyn
2860: 63 29 2c 20 67 65 74 53 79 6e 63 29 3b 0a 20 20  c), getSync);.  
2870: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43      sqlite3VdbeC
2880: 68 61 6e 67 65 50 32 28 76 2c 20 61 64 64 72 2b  hangeP2(v, addr+
2890: 33 2c 20 61 64 64 72 2b 31 30 29 3b 0a 20 20 20  3, addr+10);.   
28a0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e   }else{.      in
28b0: 74 20 61 64 64 72 3b 0a 20 20 20 20 20 20 69 6e  t addr;.      in
28c0: 74 20 73 69 7a 65 20 3d 20 64 62 2d 3e 63 61 63  t size = db->cac
28d0: 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 20 20 69  he_size;.      i
28e0: 66 28 20 73 69 7a 65 3c 30 20 29 20 73 69 7a 65  f( size<0 ) size
28f0: 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20   = -size;.      
2900: 73 71 6c 69 74 65 33 42 65 67 69 6e 57 72 69 74  sqlite3BeginWrit
2910: 65 4f 70 65 72 61 74 69 6f 6e 28 70 50 61 72 73  eOperation(pPars
2920: 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  e, 0, 0);.      
2930: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
2940: 28 76 2c 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69  (v, OP_ReadCooki
2950: 65 2c 20 30 2c 20 32 29 3b 0a 20 20 20 20 20 20  e, 0, 2);.      
2960: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
2970: 28 76 2c 20 4f 50 5f 44 75 70 2c 20 30 2c 20 30  (v, OP_Dup, 0, 0
2980: 29 3b 0a 20 20 20 20 20 20 61 64 64 72 20 3d 20  );.      addr = 
2990: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
29a0: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
29b0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
29c0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
29d0: 20 4f 50 5f 4e 65 2c 20 30 2c 20 61 64 64 72 2b   OP_Ne, 0, addr+
29e0: 33 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  3);.      sqlite
29f0: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
2a00: 5f 41 64 64 49 6d 6d 2c 20 4d 41 58 5f 50 41 47  _AddImm, MAX_PAG
2a10: 45 53 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71  ES, 0);.      sq
2a20: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
2a30: 2c 20 4f 50 5f 41 62 73 56 61 6c 75 65 2c 20 30  , OP_AbsValue, 0
2a40: 2c 20 30 29 3b 0a 20 20 20 20 20 20 64 62 2d 3e  , 0);.      db->
2a50: 73 61 66 65 74 79 5f 6c 65 76 65 6c 20 3d 20 67  safety_level = g
2a60: 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28 7a 52  etSafetyLevel(zR
2a70: 69 67 68 74 29 2b 31 3b 0a 20 20 20 20 20 20 69  ight)+1;.      i
2a80: 66 28 20 64 62 2d 3e 73 61 66 65 74 79 5f 6c 65  f( db->safety_le
2a90: 76 65 6c 3d 3d 31 20 29 7b 0a 20 20 20 20 20 20  vel==1 ){.      
2aa0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
2ab0: 4f 70 28 76 2c 20 4f 50 5f 4e 65 67 61 74 69 76  Op(v, OP_Negativ
2ac0: 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  e, 0, 0);.      
2ad0: 20 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a    size = -size;.
2ae0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71        }.      sq
2af0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
2b00: 2c 20 4f 50 5f 53 65 74 43 6f 6f 6b 69 65 2c 20  , OP_SetCookie, 
2b10: 30 2c 20 32 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 2);.      sql
2b20: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
2b30: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 64 62 2d   OP_Integer, db-
2b40: 3e 73 61 66 65 74 79 5f 6c 65 76 65 6c 2c 20 30  >safety_level, 0
2b50: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
2b60: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
2b70: 53 65 74 43 6f 6f 6b 69 65 2c 20 30 2c 20 33 29  SetCookie, 0, 3)
2b80: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45  ;.      sqlite3E
2b90: 6e 64 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e  ndWriteOperation
2ba0: 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20  (pParse);.      
2bb0: 64 62 2d 3e 63 61 63 68 65 5f 73 69 7a 65 20 3d  db->cache_size =
2bc0: 20 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c   size;.      sql
2bd0: 69 74 65 33 42 74 72 65 65 53 65 74 43 61 63 68  ite3BtreeSetCach
2be0: 65 53 69 7a 65 28 64 62 2d 3e 61 44 62 5b 30 5d  eSize(db->aDb[0]
2bf0: 2e 70 42 74 2c 20 64 62 2d 3e 63 61 63 68 65 5f  .pBt, db->cache_
2c00: 73 69 7a 65 29 3b 0a 20 20 20 20 20 20 73 71 6c  size);.      sql
2c10: 69 74 65 33 42 74 72 65 65 53 65 74 53 61 66 65  ite3BtreeSetSafe
2c20: 74 79 4c 65 76 65 6c 28 64 62 2d 3e 61 44 62 5b  tyLevel(db->aDb[
2c30: 30 5d 2e 70 42 74 2c 20 64 62 2d 3e 73 61 66 65  0].pBt, db->safe
2c40: 74 79 5f 6c 65 76 65 6c 29 3b 0a 20 20 20 20 7d  ty_level);.    }
2c50: 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20  .  }else..  /*. 
2c60: 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 73 79 6e   **   PRAGMA syn
2c70: 63 68 72 6f 6e 6f 75 73 0a 20 20 2a 2a 20 20 20  chronous.  **   
2c80: 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f  PRAGMA synchrono
2c90: 75 73 3d 4f 46 46 7c 4f 4e 7c 4e 4f 52 4d 41 4c  us=OFF|ON|NORMAL
2ca0: 7c 46 55 4c 4c 0a 20 20 2a 2a 0a 20 20 2a 2a 20  |FULL.  **.  ** 
2cb0: 52 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74 68  Return or set th
2cc0: 65 20 6c 6f 63 61 6c 20 76 61 6c 75 65 20 6f 66  e local value of
2cd0: 20 74 68 65 20 73 79 6e 63 68 72 6f 6e 6f 75 73   the synchronous
2ce0: 20 66 6c 61 67 2e 20 20 43 68 61 6e 67 69 6e 67   flag.  Changing
2cf0: 0a 20 20 2a 2a 20 74 68 65 20 6c 6f 63 61 6c 20  .  ** the local 
2d00: 76 61 6c 75 65 20 64 6f 65 73 20 6e 6f 74 20 6d  value does not m
2d10: 61 6b 65 20 63 68 61 6e 67 65 73 20 74 6f 20 74  ake changes to t
2d20: 68 65 20 64 69 73 6b 20 66 69 6c 65 20 61 6e 64  he disk file and
2d30: 20 74 68 65 0a 20 20 2a 2a 20 64 65 66 61 75 6c   the.  ** defaul
2d40: 74 20 76 61 6c 75 65 20 77 69 6c 6c 20 62 65 20  t value will be 
2d50: 72 65 73 74 6f 72 65 64 20 74 68 65 20 6e 65 78  restored the nex
2d60: 74 20 74 69 6d 65 20 74 68 65 20 64 61 74 61 62  t time the datab
2d70: 61 73 65 20 69 73 0a 20 20 2a 2a 20 6f 70 65 6e  ase is.  ** open
2d80: 65 64 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73  ed..  */.  if( s
2d90: 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c  qlite3StrICmp(zL
2da0: 65 66 74 2c 22 73 79 6e 63 68 72 6f 6e 6f 75 73  eft,"synchronous
2db0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73 74 61  ")==0 ){.    sta
2dc0: 74 69 63 20 56 64 62 65 4f 70 4c 69 73 74 20 67  tic VdbeOpList g
2dd0: 65 74 53 79 6e 63 5b 5d 20 3d 20 7b 0a 20 20 20  etSync[] = {.   
2de0: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
2df0: 6d 65 2c 20 20 30 2c 20 31 2c 20 20 20 20 20 20  me,  0, 1,      
2e00: 20 20 22 73 79 6e 63 68 72 6f 6e 6f 75 73 22 7d    "synchronous"}
2e10: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c  ,.      { OP_Cal
2e20: 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30 2c 20  lback,    1, 0, 
2e30: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7d         0},.    }
2e40: 3b 0a 20 20 20 20 69 66 28 20 70 52 69 67 68 74  ;.    if( pRight
2e50: 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a 20 29 7b  ->z==pLeft->z ){
2e60: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
2e70: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e  beAddOp(v, OP_In
2e80: 74 65 67 65 72 2c 20 64 62 2d 3e 73 61 66 65 74  teger, db->safet
2e90: 79 5f 6c 65 76 65 6c 2d 31 2c 20 30 29 3b 0a 20  y_level-1, 0);. 
2ea0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
2eb0: 41 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72  AddOpList(v, Arr
2ec0: 61 79 53 69 7a 65 28 67 65 74 53 79 6e 63 29 2c  aySize(getSync),
2ed0: 20 67 65 74 53 79 6e 63 29 3b 0a 20 20 20 20 7d   getSync);.    }
2ee0: 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74 20  else{.      int 
2ef0: 73 69 7a 65 20 3d 20 64 62 2d 3e 63 61 63 68 65  size = db->cache
2f00: 5f 73 69 7a 65 3b 0a 20 20 20 20 20 20 69 66 28  _size;.      if(
2f10: 20 73 69 7a 65 3c 30 20 29 20 73 69 7a 65 20 3d   size<0 ) size =
2f20: 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20 64 62   -size;.      db
2f30: 2d 3e 73 61 66 65 74 79 5f 6c 65 76 65 6c 20 3d  ->safety_level =
2f40: 20 67 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28   getSafetyLevel(
2f50: 7a 52 69 67 68 74 29 2b 31 3b 0a 20 20 20 20 20  zRight)+1;.     
2f60: 20 69 66 28 20 64 62 2d 3e 73 61 66 65 74 79 5f   if( db->safety_
2f70: 6c 65 76 65 6c 3d 3d 31 20 29 20 73 69 7a 65 20  level==1 ) size 
2f80: 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20 64  = -size;.      d
2f90: 62 2d 3e 63 61 63 68 65 5f 73 69 7a 65 20 3d 20  b->cache_size = 
2fa0: 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c 69  size;.      sqli
2fb0: 74 65 33 42 74 72 65 65 53 65 74 43 61 63 68 65  te3BtreeSetCache
2fc0: 53 69 7a 65 28 64 62 2d 3e 61 44 62 5b 30 5d 2e  Size(db->aDb[0].
2fd0: 70 42 74 2c 20 64 62 2d 3e 63 61 63 68 65 5f 73  pBt, db->cache_s
2fe0: 69 7a 65 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  ize);.      sqli
2ff0: 74 65 33 42 74 72 65 65 53 65 74 53 61 66 65 74  te3BtreeSetSafet
3000: 79 4c 65 76 65 6c 28 64 62 2d 3e 61 44 62 5b 30  yLevel(db->aDb[0
3010: 5d 2e 70 42 74 2c 20 64 62 2d 3e 73 61 66 65 74  ].pBt, db->safet
3020: 79 5f 6c 65 76 65 6c 29 3b 0a 20 20 20 20 7d 0a  y_level);.    }.
3030: 20 20 7d 65 6c 73 65 0a 0a 23 69 66 6e 64 65 66    }else..#ifndef
3040: 20 4e 44 45 42 55 47 0a 20 20 69 66 28 20 73 71   NDEBUG.  if( sq
3050: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65  lite3StrICmp(zLe
3060: 66 74 2c 20 22 74 72 69 67 67 65 72 5f 6f 76 65  ft, "trigger_ove
3070: 72 68 65 61 64 5f 74 65 73 74 22 29 3d 3d 30 20  rhead_test")==0 
3080: 29 7b 0a 20 20 20 20 69 66 28 20 67 65 74 42 6f  ){.    if( getBo
3090: 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29 20 29 7b  olean(zRight) ){
30a0: 0a 20 20 20 20 20 20 61 6c 77 61 79 73 5f 63 6f  .      always_co
30b0: 64 65 5f 74 72 69 67 67 65 72 5f 73 65 74 75 70  de_trigger_setup
30c0: 20 3d 20 31 3b 0a 20 20 20 20 7d 65 6c 73 65 7b   = 1;.    }else{
30d0: 0a 20 20 20 20 20 20 61 6c 77 61 79 73 5f 63 6f  .      always_co
30e0: 64 65 5f 74 72 69 67 67 65 72 5f 73 65 74 75 70  de_trigger_setup
30f0: 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 65   = 0;.    }.  }e
3100: 6c 73 65 0a 23 65 6e 64 69 66 0a 0a 20 20 69 66  lse.#endif..  if
3110: 28 20 66 6c 61 67 50 72 61 67 6d 61 28 70 50 61  ( flagPragma(pPa
3120: 72 73 65 2c 20 7a 4c 65 66 74 2c 20 7a 52 69 67  rse, zLeft, zRig
3130: 68 74 29 20 29 7b 0a 20 20 20 20 2f 2a 20 54 68  ht) ){.    /* Th
3140: 65 20 66 6c 61 67 50 72 61 67 6d 61 28 29 20 63  e flagPragma() c
3150: 61 6c 6c 20 61 6c 73 6f 20 67 65 6e 65 72 61 74  all also generat
3160: 65 73 20 61 6e 79 20 6e 65 63 65 73 73 61 72 79  es any necessary
3170: 20 63 6f 64 65 20 2a 2f 0a 20 20 7d 65 6c 73 65   code */.  }else
3180: 0a 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 53  ..  if( sqlite3S
3190: 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 74  trICmp(zLeft, "t
31a0: 61 62 6c 65 5f 69 6e 66 6f 22 29 3d 3d 30 20 29  able_info")==0 )
31b0: 7b 0a 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61  {.    Table *pTa
31c0: 62 3b 0a 20 20 20 20 70 54 61 62 20 3d 20 73 71  b;.    pTab = sq
31d0: 6c 69 74 65 33 46 69 6e 64 54 61 62 6c 65 28 64  lite3FindTable(d
31e0: 62 2c 20 7a 52 69 67 68 74 2c 20 30 29 3b 0a 20  b, zRight, 0);. 
31f0: 20 20 20 69 66 28 20 70 54 61 62 20 29 7b 0a 20     if( pTab ){. 
3200: 20 20 20 20 20 73 74 61 74 69 63 20 56 64 62 65       static Vdbe
3210: 4f 70 4c 69 73 74 20 74 61 62 6c 65 49 6e 66 6f  OpList tableInfo
3220: 50 72 65 66 61 63 65 5b 5d 20 3d 20 7b 0a 20 20  Preface[] = {.  
3230: 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d        { OP_Colum
3240: 6e 4e 61 6d 65 2c 20 20 30 2c 20 30 2c 20 20 20  nName,  0, 0,   
3250: 20 20 20 20 22 63 69 64 22 7d 2c 0a 20 20 20 20      "cid"},.    
3260: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3270: 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20 20  ame,  1, 0,     
3280: 20 20 22 6e 61 6d 65 22 7d 2c 0a 20 20 20 20 20    "name"},.     
3290: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
32a0: 6d 65 2c 20 20 32 2c 20 30 2c 20 20 20 20 20 20  me,  2, 0,      
32b0: 20 22 74 79 70 65 22 7d 2c 0a 20 20 20 20 20 20   "type"},.      
32c0: 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d    { OP_ColumnNam
32d0: 65 2c 20 20 33 2c 20 30 2c 20 20 20 20 20 20 20  e,  3, 0,       
32e0: 22 6e 6f 74 6e 75 6c 6c 22 7d 2c 0a 20 20 20 20  "notnull"},.    
32f0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3300: 61 6d 65 2c 20 20 34 2c 20 30 2c 20 20 20 20 20  ame,  4, 0,     
3310: 20 20 22 64 66 6c 74 5f 76 61 6c 75 65 22 7d 2c    "dflt_value"},
3320: 0a 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f  .        { OP_Co
3330: 6c 75 6d 6e 4e 61 6d 65 2c 20 20 35 2c 20 31 2c  lumnName,  5, 1,
3340: 20 20 20 20 20 20 20 22 70 6b 22 7d 2c 0a 20 20         "pk"},.  
3350: 20 20 20 20 7d 3b 0a 20 20 20 20 20 20 69 6e 74      };.      int
3360: 20 69 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   i;.      sqlite
3370: 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76  3VdbeAddOpList(v
3380: 2c 20 41 72 72 61 79 53 69 7a 65 28 74 61 62 6c  , ArraySize(tabl
3390: 65 49 6e 66 6f 50 72 65 66 61 63 65 29 2c 20 74  eInfoPreface), t
33a0: 61 62 6c 65 49 6e 66 6f 50 72 65 66 61 63 65 29  ableInfoPreface)
33b0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
33c0: 69 65 77 47 65 74 43 6f 6c 75 6d 6e 4e 61 6d 65  iewGetColumnName
33d0: 73 28 70 50 61 72 73 65 2c 20 70 54 61 62 29 3b  s(pParse, pTab);
33e0: 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20  .      for(i=0; 
33f0: 69 3c 70 54 61 62 2d 3e 6e 43 6f 6c 3b 20 69 2b  i<pTab->nCol; i+
3400: 2b 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  +){.        sqli
3410: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
3420: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30  OP_Integer, i, 0
3430: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
3440: 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f  e3VdbeOp3(v, OP_
3450: 53 74 72 69 6e 67 2c 20 30 2c 20 30 2c 20 70 54  String, 0, 0, pT
3460: 61 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 7a 4e 61 6d  ab->aCol[i].zNam
3470: 65 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  e, 0);.        s
3480: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
3490: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
34a0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 70 54 61  ,.           pTa
34b0: 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 7a 54 79 70 65  b->aCol[i].zType
34c0: 20 3f 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 69 5d   ? pTab->aCol[i]
34d0: 2e 7a 54 79 70 65 20 3a 20 22 6e 75 6d 65 72 69  .zType : "numeri
34e0: 63 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  c", 0);.        
34f0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3500: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
3510: 70 54 61 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 6e 6f  pTab->aCol[i].no
3520: 74 4e 75 6c 6c 2c 20 30 29 3b 0a 20 20 20 20 20  tNull, 0);.     
3530: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f 70     sqlite3VdbeOp
3540: 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20  3(v, OP_String, 
3550: 30 2c 20 30 2c 0a 20 20 20 20 20 20 20 20 20 20  0, 0,.          
3560: 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 7a   pTab->aCol[i].z
3570: 44 66 6c 74 2c 20 50 33 5f 53 54 41 54 49 43 29  Dflt, P3_STATIC)
3580: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
3590: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
35a0: 5f 49 6e 74 65 67 65 72 2c 20 70 54 61 62 2d 3e  _Integer, pTab->
35b0: 61 43 6f 6c 5b 69 5d 2e 69 73 50 72 69 6d 4b 65  aCol[i].isPrimKe
35c0: 79 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  y, 0);.        s
35d0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
35e0: 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20  v, OP_Callback, 
35f0: 36 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20  6, 0);.      }. 
3600: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20     }.  }else..  
3610: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
3620: 6d 70 28 7a 4c 65 66 74 2c 20 22 69 6e 64 65 78  mp(zLeft, "index
3630: 5f 69 6e 66 6f 22 29 3d 3d 30 20 29 7b 0a 20 20  _info")==0 ){.  
3640: 20 20 49 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20    Index *pIdx;. 
3650: 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a     Table *pTab;.
3660: 20 20 20 20 70 49 64 78 20 3d 20 73 71 6c 69 74      pIdx = sqlit
3670: 65 33 46 69 6e 64 49 6e 64 65 78 28 64 62 2c 20  e3FindIndex(db, 
3680: 7a 52 69 67 68 74 2c 20 30 29 3b 0a 20 20 20 20  zRight, 0);.    
3690: 69 66 28 20 70 49 64 78 20 29 7b 0a 20 20 20 20  if( pIdx ){.    
36a0: 20 20 73 74 61 74 69 63 20 56 64 62 65 4f 70 4c    static VdbeOpL
36b0: 69 73 74 20 74 61 62 6c 65 49 6e 66 6f 50 72 65  ist tableInfoPre
36c0: 66 61 63 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20  face[] = {.     
36d0: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
36e0: 6d 65 2c 20 20 30 2c 20 30 2c 20 20 20 20 20 20  me,  0, 0,      
36f0: 20 22 73 65 71 6e 6f 22 7d 2c 0a 20 20 20 20 20   "seqno"},.     
3700: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
3710: 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20 20 20  me,  1, 0,      
3720: 20 22 63 69 64 22 7d 2c 0a 20 20 20 20 20 20 20   "cid"},.       
3730: 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65   { OP_ColumnName
3740: 2c 20 20 32 2c 20 31 2c 20 20 20 20 20 20 20 22  ,  2, 1,       "
3750: 6e 61 6d 65 22 7d 2c 0a 20 20 20 20 20 20 7d 3b  name"},.      };
3760: 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20 20  .      int i;.  
3770: 20 20 20 20 70 54 61 62 20 3d 20 70 49 64 78 2d      pTab = pIdx-
3780: 3e 70 54 61 62 6c 65 3b 0a 20 20 20 20 20 20 73  >pTable;.      s
3790: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c  qlite3VdbeAddOpL
37a0: 69 73 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65  ist(v, ArraySize
37b0: 28 74 61 62 6c 65 49 6e 66 6f 50 72 65 66 61 63  (tableInfoPrefac
37c0: 65 29 2c 20 74 61 62 6c 65 49 6e 66 6f 50 72 65  e), tableInfoPre
37d0: 66 61 63 65 29 3b 0a 20 20 20 20 20 20 66 6f 72  face);.      for
37e0: 28 69 3d 30 3b 20 69 3c 70 49 64 78 2d 3e 6e 43  (i=0; i<pIdx->nC
37f0: 6f 6c 75 6d 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20  olumn; i++){.   
3800: 20 20 20 20 20 69 6e 74 20 63 6e 75 6d 20 3d 20       int cnum = 
3810: 70 49 64 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 69  pIdx->aiColumn[i
3820: 5d 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ];.        sqlit
3830: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
3840: 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30 29  P_Integer, i, 0)
3850: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
3860: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
3870: 5f 49 6e 74 65 67 65 72 2c 20 63 6e 75 6d 2c 20  _Integer, cnum, 
3880: 30 29 3b 0a 20 20 20 20 20 20 20 20 61 73 73 65  0);.        asse
3890: 72 74 28 20 70 54 61 62 2d 3e 6e 43 6f 6c 3e 63  rt( pTab->nCol>c
38a0: 6e 75 6d 20 29 3b 0a 20 20 20 20 20 20 20 20 73  num );.        s
38b0: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
38c0: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
38d0: 2c 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 63 6e 75  , pTab->aCol[cnu
38e0: 6d 5d 2e 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20  m].zName, 0);.  
38f0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
3900: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 43 61 6c  eAddOp(v, OP_Cal
3910: 6c 62 61 63 6b 2c 20 33 2c 20 30 29 3b 0a 20 20  lback, 3, 0);.  
3920: 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 65      }.    }.  }e
3930: 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c 69 74  lse..  if( sqlit
3940: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
3950: 20 22 69 6e 64 65 78 5f 6c 69 73 74 22 29 3d 3d   "index_list")==
3960: 30 20 29 7b 0a 20 20 20 20 49 6e 64 65 78 20 2a  0 ){.    Index *
3970: 70 49 64 78 3b 0a 20 20 20 20 54 61 62 6c 65 20  pIdx;.    Table 
3980: 2a 70 54 61 62 3b 0a 20 20 20 20 70 54 61 62 20  *pTab;.    pTab 
3990: 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 54 61 62  = sqlite3FindTab
39a0: 6c 65 28 64 62 2c 20 7a 52 69 67 68 74 2c 20 30  le(db, zRight, 0
39b0: 29 3b 0a 20 20 20 20 69 66 28 20 70 54 61 62 20  );.    if( pTab 
39c0: 29 7b 0a 20 20 20 20 20 20 76 20 3d 20 73 71 6c  ){.      v = sql
39d0: 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72  ite3GetVdbe(pPar
39e0: 73 65 29 3b 0a 20 20 20 20 20 20 70 49 64 78 20  se);.      pIdx 
39f0: 3d 20 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b 0a  = pTab->pIndex;.
3a00: 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 70 54      }.    if( pT
3a10: 61 62 20 26 26 20 70 49 64 78 20 29 7b 0a 20 20  ab && pIdx ){.  
3a20: 20 20 20 20 69 6e 74 20 69 20 3d 20 30 3b 20 0a      int i = 0; .
3a30: 20 20 20 20 20 20 73 74 61 74 69 63 20 56 64 62        static Vdb
3a40: 65 4f 70 4c 69 73 74 20 69 6e 64 65 78 4c 69 73  eOpList indexLis
3a50: 74 50 72 65 66 61 63 65 5b 5d 20 3d 20 7b 0a 20  tPreface[] = {. 
3a60: 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75         { OP_Colu
3a70: 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 30 2c 20 20  mnName,  0, 0,  
3a80: 20 20 20 20 20 22 73 65 71 22 7d 2c 0a 20 20 20       "seq"},.   
3a90: 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e       { OP_Column
3aa0: 4e 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20  Name,  1, 0,    
3ab0: 20 20 20 22 6e 61 6d 65 22 7d 2c 0a 20 20 20 20     "name"},.    
3ac0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3ad0: 61 6d 65 2c 20 20 32 2c 20 31 2c 20 20 20 20 20  ame,  2, 1,     
3ae0: 20 20 22 75 6e 69 71 75 65 22 7d 2c 0a 20 20 20    "unique"},.   
3af0: 20 20 20 7d 3b 0a 0a 20 20 20 20 20 20 73 71 6c     };..      sql
3b00: 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73  ite3VdbeAddOpLis
3b10: 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65 28 69  t(v, ArraySize(i
3b20: 6e 64 65 78 4c 69 73 74 50 72 65 66 61 63 65 29  ndexListPreface)
3b30: 2c 20 69 6e 64 65 78 4c 69 73 74 50 72 65 66 61  , indexListPrefa
3b40: 63 65 29 3b 0a 20 20 20 20 20 20 77 68 69 6c 65  ce);.      while
3b50: 28 70 49 64 78 29 7b 0a 20 20 20 20 20 20 20 20  (pIdx){.        
3b60: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3b70: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
3b80: 69 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  i, 0);.        s
3b90: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
3ba0: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
3bb0: 2c 20 70 49 64 78 2d 3e 7a 4e 61 6d 65 2c 20 30  , pIdx->zName, 0
3bc0: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
3bd0: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
3be0: 50 5f 49 6e 74 65 67 65 72 2c 20 70 49 64 78 2d  P_Integer, pIdx-
3bf0: 3e 6f 6e 45 72 72 6f 72 21 3d 4f 45 5f 4e 6f 6e  >onError!=OE_Non
3c00: 65 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  e, 0);.        s
3c10: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
3c20: 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20  v, OP_Callback, 
3c30: 33 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 2b  3, 0);.        +
3c40: 2b 69 3b 0a 20 20 20 20 20 20 20 20 70 49 64 78  +i;.        pIdx
3c50: 20 3d 20 70 49 64 78 2d 3e 70 4e 65 78 74 3b 0a   = pIdx->pNext;.
3c60: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
3c70: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c  }else..  if( sql
3c80: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
3c90: 74 2c 20 22 66 6f 72 65 69 67 6e 5f 6b 65 79 5f  t, "foreign_key_
3ca0: 6c 69 73 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20  list")==0 ){.   
3cb0: 20 46 4b 65 79 20 2a 70 46 4b 3b 0a 20 20 20 20   FKey *pFK;.    
3cc0: 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a 20 20 20  Table *pTab;.   
3cd0: 20 70 54 61 62 20 3d 20 73 71 6c 69 74 65 33 46   pTab = sqlite3F
3ce0: 69 6e 64 54 61 62 6c 65 28 64 62 2c 20 7a 52 69  indTable(db, zRi
3cf0: 67 68 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28  ght, 0);.    if(
3d00: 20 70 54 61 62 20 29 7b 0a 20 20 20 20 20 20 76   pTab ){.      v
3d10: 20 3d 20 73 71 6c 69 74 65 33 47 65 74 56 64 62   = sqlite3GetVdb
3d20: 65 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20  e(pParse);.     
3d30: 20 70 46 4b 20 3d 20 70 54 61 62 2d 3e 70 46 4b   pFK = pTab->pFK
3d40: 65 79 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  ey;.    }.    if
3d50: 28 20 70 54 61 62 20 26 26 20 70 46 4b 20 29 7b  ( pTab && pFK ){
3d60: 0a 20 20 20 20 20 20 69 6e 74 20 69 20 3d 20 30  .      int i = 0
3d70: 3b 20 0a 20 20 20 20 20 20 73 74 61 74 69 63 20  ; .      static 
3d80: 56 64 62 65 4f 70 4c 69 73 74 20 69 6e 64 65 78  VdbeOpList index
3d90: 4c 69 73 74 50 72 65 66 61 63 65 5b 5d 20 3d 20  ListPreface[] = 
3da0: 7b 0a 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43  {.        { OP_C
3db0: 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 30  olumnName,  0, 0
3dc0: 2c 20 20 20 20 20 20 20 22 69 64 22 7d 2c 0a 20  ,       "id"},. 
3dd0: 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75         { OP_Colu
3de0: 6d 6e 4e 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20  mnName,  1, 0,  
3df0: 20 20 20 20 20 22 73 65 71 22 7d 2c 0a 20 20 20       "seq"},.   
3e00: 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e       { OP_Column
3e10: 4e 61 6d 65 2c 20 20 32 2c 20 30 2c 20 20 20 20  Name,  2, 0,    
3e20: 20 20 20 22 74 61 62 6c 65 22 7d 2c 0a 20 20 20     "table"},.   
3e30: 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e       { OP_Column
3e40: 4e 61 6d 65 2c 20 20 33 2c 20 30 2c 20 20 20 20  Name,  3, 0,    
3e50: 20 20 20 22 66 72 6f 6d 22 7d 2c 0a 20 20 20 20     "from"},.    
3e60: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3e70: 61 6d 65 2c 20 20 34 2c 20 31 2c 20 20 20 20 20  ame,  4, 1,     
3e80: 20 20 22 74 6f 22 7d 2c 0a 20 20 20 20 20 20 7d    "to"},.      }
3e90: 3b 0a 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ;..      sqlite3
3ea0: 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c  VdbeAddOpList(v,
3eb0: 20 41 72 72 61 79 53 69 7a 65 28 69 6e 64 65 78   ArraySize(index
3ec0: 4c 69 73 74 50 72 65 66 61 63 65 29 2c 20 69 6e  ListPreface), in
3ed0: 64 65 78 4c 69 73 74 50 72 65 66 61 63 65 29 3b  dexListPreface);
3ee0: 0a 20 20 20 20 20 20 77 68 69 6c 65 28 70 46 4b  .      while(pFK
3ef0: 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6a  ){.        int j
3f00: 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 6a 3d  ;.        for(j=
3f10: 30 3b 20 6a 3c 70 46 4b 2d 3e 6e 43 6f 6c 3b 20  0; j<pFK->nCol; 
3f20: 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  j++){.          
3f30: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3f40: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
3f50: 69 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20  i, 0);.         
3f60: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
3f70: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
3f80: 20 6a 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   j, 0);.        
3f90: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f 70 33    sqlite3VdbeOp3
3fa0: 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30  (v, OP_String, 0
3fb0: 2c 20 30 2c 20 70 46 4b 2d 3e 7a 54 6f 2c 20 30  , 0, pFK->zTo, 0
3fc0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  );.          sql
3fd0: 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f  ite3VdbeOp3(v, O
3fe0: 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30 2c 0a  P_String, 0, 0,.
3ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4000: 20 20 20 20 20 20 20 20 20 20 20 70 54 61 62 2d             pTab-
4010: 3e 61 43 6f 6c 5b 70 46 4b 2d 3e 61 43 6f 6c 5b  >aCol[pFK->aCol[
4020: 6a 5d 2e 69 46 72 6f 6d 5d 2e 7a 4e 61 6d 65 2c  j].iFrom].zName,
4030: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73   0);.          s
4040: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
4050: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
4060: 2c 20 70 46 4b 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a  , pFK->aCol[j].z
4070: 43 6f 6c 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  Col, 0);.       
4080: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
4090: 64 4f 70 28 76 2c 20 4f 50 5f 43 61 6c 6c 62 61  dOp(v, OP_Callba
40a0: 63 6b 2c 20 35 2c 20 30 29 3b 0a 20 20 20 20 20  ck, 5, 0);.     
40b0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 2b 2b 69     }.        ++i
40c0: 3b 0a 20 20 20 20 20 20 20 20 70 46 4b 20 3d 20  ;.        pFK = 
40d0: 70 46 4b 2d 3e 70 4e 65 78 74 46 72 6f 6d 3b 0a  pFK->pNextFrom;.
40e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
40f0: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c  }else..  if( sql
4100: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
4110: 74 2c 20 22 64 61 74 61 62 61 73 65 5f 6c 69 73  t, "database_lis
4120: 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69 6e  t")==0 ){.    in
4130: 74 20 69 3b 0a 20 20 20 20 73 74 61 74 69 63 20  t i;.    static 
4140: 56 64 62 65 4f 70 4c 69 73 74 20 69 6e 64 65 78  VdbeOpList index
4150: 4c 69 73 74 50 72 65 66 61 63 65 5b 5d 20 3d 20  ListPreface[] = 
4160: 7b 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c  {.      { OP_Col
4170: 75 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 30 2c 20  umnName,  0, 0, 
4180: 20 20 20 20 20 20 22 73 65 71 22 7d 2c 0a 20 20        "seq"},.  
4190: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
41a0: 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20 20  ame,  1, 0,     
41b0: 20 20 22 6e 61 6d 65 22 7d 2c 0a 20 20 20 20 20    "name"},.     
41c0: 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65   { OP_ColumnName
41d0: 2c 20 20 32 2c 20 31 2c 20 20 20 20 20 20 20 22  ,  2, 1,       "
41e0: 66 69 6c 65 22 7d 2c 0a 20 20 20 20 7d 3b 0a 0a  file"},.    };..
41f0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
4200: 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61  ddOpList(v, Arra
4210: 79 53 69 7a 65 28 69 6e 64 65 78 4c 69 73 74 50  ySize(indexListP
4220: 72 65 66 61 63 65 29 2c 20 69 6e 64 65 78 4c 69  reface), indexLi
4230: 73 74 50 72 65 66 61 63 65 29 3b 0a 20 20 20 20  stPreface);.    
4240: 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62 2d 3e 6e  for(i=0; i<db->n
4250: 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  Db; i++){.      
4260: 69 66 28 20 64 62 2d 3e 61 44 62 5b 69 5d 2e 70  if( db->aDb[i].p
4270: 42 74 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  Bt==0 ) continue
4280: 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20  ;.      assert( 
4290: 64 62 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65  db->aDb[i].zName
42a0: 21 3d 30 20 29 3b 0a 20 20 20 20 20 20 73 71 6c  !=0 );.      sql
42b0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
42c0: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20   OP_Integer, i, 
42d0: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
42e0: 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53  3VdbeOp3(v, OP_S
42f0: 74 72 69 6e 67 2c 20 30 2c 20 30 2c 20 64 62 2d  tring, 0, 0, db-
4300: 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 30  >aDb[i].zName, 0
4310: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
4320: 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74  VdbeOp3(v, OP_St
4330: 72 69 6e 67 2c 20 30 2c 20 30 2c 0a 20 20 20 20  ring, 0, 0,.    
4340: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 42 74         sqlite3Bt
4350: 72 65 65 47 65 74 46 69 6c 65 6e 61 6d 65 28 64  reeGetFilename(d
4360: 62 2d 3e 61 44 62 5b 69 5d 2e 70 42 74 29 2c 20  b->aDb[i].pBt), 
4370: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
4380: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
4390: 5f 43 61 6c 6c 62 61 63 6b 2c 20 33 2c 20 30 29  _Callback, 3, 0)
43a0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a  ;.    }.  }else.
43b0: 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20 50 52  ..  /*.  **   PR
43c0: 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 0a  AGMA temp_store.
43d0: 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 74 65    **   PRAGMA te
43e0: 6d 70 5f 73 74 6f 72 65 20 3d 20 22 64 65 66 61  mp_store = "defa
43f0: 75 6c 74 22 7c 22 6d 65 6d 6f 72 79 22 7c 22 66  ult"|"memory"|"f
4400: 69 6c 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52  ile".  **.  ** R
4410: 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74 68 65  eturn or set the
4420: 20 6c 6f 63 61 6c 20 76 61 6c 75 65 20 6f 66 20   local value of 
4430: 74 68 65 20 74 65 6d 70 5f 73 74 6f 72 65 20 66  the temp_store f
4440: 6c 61 67 2e 20 20 43 68 61 6e 67 69 6e 67 0a 20  lag.  Changing. 
4450: 20 2a 2a 20 74 68 65 20 6c 6f 63 61 6c 20 76 61   ** the local va
4460: 6c 75 65 20 64 6f 65 73 20 6e 6f 74 20 6d 61 6b  lue does not mak
4470: 65 20 63 68 61 6e 67 65 73 20 74 6f 20 74 68 65  e changes to the
4480: 20 64 69 73 6b 20 66 69 6c 65 20 61 6e 64 20 74   disk file and t
4490: 68 65 20 64 65 66 61 75 6c 74 0a 20 20 2a 2a 20  he default.  ** 
44a0: 76 61 6c 75 65 20 77 69 6c 6c 20 62 65 20 72 65  value will be re
44b0: 73 74 6f 72 65 64 20 74 68 65 20 6e 65 78 74 20  stored the next 
44c0: 74 69 6d 65 20 74 68 65 20 64 61 74 61 62 61 73  time the databas
44d0: 65 20 69 73 20 6f 70 65 6e 65 64 2e 0a 20 20 2a  e is opened..  *
44e0: 2a 0a 20 20 2a 2a 20 4e 6f 74 65 20 74 68 61 74  *.  ** Note that
44f0: 20 69 74 20 69 73 20 70 6f 73 73 69 62 6c 65 20   it is possible 
4500: 66 6f 72 20 74 68 65 20 6c 69 62 72 61 72 79 20  for the library 
4510: 63 6f 6d 70 69 6c 65 2d 74 69 6d 65 20 6f 70 74  compile-time opt
4520: 69 6f 6e 73 20 74 6f 0a 20 20 2a 2a 20 6f 76 65  ions to.  ** ove
4530: 72 72 69 64 65 20 74 68 69 73 20 73 65 74 74 69  rride this setti
4540: 6e 67 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71  ng.  */.  if( sq
4550: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65  lite3StrICmp(zLe
4560: 66 74 2c 20 22 74 65 6d 70 5f 73 74 6f 72 65 22  ft, "temp_store"
4570: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73 74 61 74  )==0 ){.    stat
4580: 69 63 20 56 64 62 65 4f 70 4c 69 73 74 20 67 65  ic VdbeOpList ge
4590: 74 54 6d 70 44 62 4c 6f 63 5b 5d 20 3d 20 7b 0a  tTmpDbLoc[] = {.
45a0: 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d        { OP_Colum
45b0: 6e 4e 61 6d 65 2c 20 20 30 2c 20 31 2c 20 20 20  nName,  0, 1,   
45c0: 20 20 20 20 20 22 74 65 6d 70 5f 73 74 6f 72 65       "temp_store
45d0: 22 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43  "},.      { OP_C
45e0: 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30  allback,    1, 0
45f0: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
4600: 20 7d 3b 0a 20 20 20 20 69 66 28 20 70 52 69 67   };.    if( pRig
4610: 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a 20  ht->z==pLeft->z 
4620: 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ){.      sqlite3
4630: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
4640: 49 6e 74 65 67 65 72 2c 20 64 62 2d 3e 74 65 6d  Integer, db->tem
4650: 70 5f 73 74 6f 72 65 2c 20 30 29 3b 0a 20 20 20  p_store, 0);.   
4660: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
4670: 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79  dOpList(v, Array
4680: 53 69 7a 65 28 67 65 74 54 6d 70 44 62 4c 6f 63  Size(getTmpDbLoc
4690: 29 2c 20 67 65 74 54 6d 70 44 62 4c 6f 63 29 3b  ), getTmpDbLoc);
46a0: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
46b0: 20 20 63 68 61 6e 67 65 54 65 6d 70 53 74 6f 72    changeTempStor
46c0: 61 67 65 28 70 50 61 72 73 65 2c 20 7a 52 69 67  age(pParse, zRig
46d0: 68 74 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c  ht);.    }.  }el
46e0: 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20  se..  /*.  **   
46f0: 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 74  PRAGMA default_t
4700: 65 6d 70 5f 73 74 6f 72 65 0a 20 20 2a 2a 20 20  emp_store.  **  
4710: 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f   PRAGMA default_
4720: 74 65 6d 70 5f 73 74 6f 72 65 20 3d 20 22 64 65  temp_store = "de
4730: 66 61 75 6c 74 22 7c 22 6d 65 6d 6f 72 79 22 7c  fault"|"memory"|
4740: 22 66 69 6c 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a  "file".  **.  **
4750: 20 52 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74   Return or set t
4760: 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20  he value of the 
4770: 70 65 72 73 69 73 74 65 6e 74 20 74 65 6d 70 5f  persistent temp_
4780: 73 74 6f 72 65 20 66 6c 61 67 2e 20 20 41 6e 79  store flag.  Any
4790: 0a 20 20 2a 2a 20 63 68 61 6e 67 65 20 64 6f 65  .  ** change doe
47a0: 73 20 6e 6f 74 20 74 61 6b 65 20 65 66 66 65 63  s not take effec
47b0: 74 20 75 6e 74 69 6c 20 74 68 65 20 6e 65 78 74  t until the next
47c0: 20 74 69 6d 65 20 74 68 65 20 64 61 74 61 62 61   time the databa
47d0: 73 65 20 69 73 0a 20 20 2a 2a 20 6f 70 65 6e 65  se is.  ** opene
47e0: 64 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 4e 6f 74  d..  **.  ** Not
47f0: 65 20 74 68 61 74 20 69 74 20 69 73 20 70 6f 73  e that it is pos
4800: 73 69 62 6c 65 20 66 6f 72 20 74 68 65 20 6c 69  sible for the li
4810: 62 72 61 72 79 20 63 6f 6d 70 69 6c 65 2d 74 69  brary compile-ti
4820: 6d 65 20 6f 70 74 69 6f 6e 73 20 74 6f 0a 20 20  me options to.  
4830: 2a 2a 20 6f 76 65 72 72 69 64 65 20 74 68 69 73  ** override this
4840: 20 73 65 74 74 69 6e 67 0a 20 20 2a 2f 0a 20 20   setting.  */.  
4850: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
4860: 6d 70 28 7a 4c 65 66 74 2c 20 22 64 65 66 61 75  mp(zLeft, "defau
4870: 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65 22 29 3d  lt_temp_store")=
4880: 3d 30 20 29 7b 0a 20 20 20 20 73 74 61 74 69 63  =0 ){.    static
4890: 20 56 64 62 65 4f 70 4c 69 73 74 20 67 65 74 54   VdbeOpList getT
48a0: 6d 70 44 62 4c 6f 63 5b 5d 20 3d 20 7b 0a 20 20  mpDbLoc[] = {.  
48b0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
48c0: 61 6d 65 2c 20 20 30 2c 20 31 2c 20 20 20 20 20  ame,  0, 1,     
48d0: 20 20 20 22 74 65 6d 70 5f 73 74 6f 72 65 22 7d     "temp_store"}
48e0: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 52 65 61  ,.      { OP_Rea
48f0: 64 43 6f 6f 6b 69 65 2c 20 20 30 2c 20 35 2c 20  dCookie,  0, 5, 
4900: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20         0},.     
4910: 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20   { OP_Callback, 
4920: 20 20 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20     1, 0,        
4930: 30 7d 7d 3b 0a 20 20 20 20 69 66 28 20 70 52 69  0}};.    if( pRi
4940: 67 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a  ght->z==pLeft->z
4950: 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ){.      sqlite
4960: 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76  3VdbeAddOpList(v
4970: 2c 20 41 72 72 61 79 53 69 7a 65 28 67 65 74 54  , ArraySize(getT
4980: 6d 70 44 62 4c 6f 63 29 2c 20 67 65 74 54 6d 70  mpDbLoc), getTmp
4990: 44 62 4c 6f 63 29 3b 0a 20 20 20 20 7d 65 6c 73  DbLoc);.    }els
49a0: 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  e{.      sqlite3
49b0: 42 65 67 69 6e 57 72 69 74 65 4f 70 65 72 61 74  BeginWriteOperat
49c0: 69 6f 6e 28 70 50 61 72 73 65 2c 20 30 2c 20 30  ion(pParse, 0, 0
49d0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
49e0: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
49f0: 49 6e 74 65 67 65 72 2c 20 67 65 74 54 65 6d 70  Integer, getTemp
4a00: 53 74 6f 72 65 28 7a 52 69 67 68 74 29 2c 20 30  Store(zRight), 0
4a10: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
4a20: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
4a30: 53 65 74 43 6f 6f 6b 69 65 2c 20 30 2c 20 35 29  SetCookie, 0, 5)
4a40: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45  ;.      sqlite3E
4a50: 6e 64 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e  ndWriteOperation
4a60: 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 7d 0a  (pParse);.    }.
4a70: 20 20 7d 65 6c 73 65 0a 0a 23 69 66 6e 64 65 66    }else..#ifndef
4a80: 20 4e 44 45 42 55 47 0a 20 20 69 66 28 20 73 71   NDEBUG.  if( sq
4a90: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65  lite3StrICmp(zLe
4aa0: 66 74 2c 20 22 70 61 72 73 65 72 5f 74 72 61 63  ft, "parser_trac
4ab0: 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 65 78  e")==0 ){.    ex
4ac0: 74 65 72 6e 20 76 6f 69 64 20 73 71 6c 69 74 65  tern void sqlite
4ad0: 33 50 61 72 73 65 72 54 72 61 63 65 28 46 49 4c  3ParserTrace(FIL
4ae0: 45 2a 2c 20 63 68 61 72 20 2a 29 3b 0a 20 20 20  E*, char *);.   
4af0: 20 69 66 28 20 67 65 74 42 6f 6f 6c 65 61 6e 28   if( getBoolean(
4b00: 7a 52 69 67 68 74 29 20 29 7b 0a 20 20 20 20 20  zRight) ){.     
4b10: 20 73 71 6c 69 74 65 33 50 61 72 73 65 72 54 72   sqlite3ParserTr
4b20: 61 63 65 28 73 74 64 6f 75 74 2c 20 22 70 61 72  ace(stdout, "par
4b30: 73 65 72 3a 20 22 29 3b 0a 20 20 20 20 7d 65 6c  ser: ");.    }el
4b40: 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  se{.      sqlite
4b50: 33 50 61 72 73 65 72 54 72 61 63 65 28 30 2c 20  3ParserTrace(0, 
4b60: 30 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73  0);.    }.  }els
4b70: 65 0a 23 65 6e 64 69 66 0a 0a 20 20 69 66 28 20  e.#endif..  if( 
4b80: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
4b90: 4c 65 66 74 2c 20 22 69 6e 74 65 67 72 69 74 79  Left, "integrity
4ba0: 5f 63 68 65 63 6b 22 29 3d 3d 30 20 29 7b 0a 20  _check")==0 ){. 
4bb0: 20 20 20 69 6e 74 20 69 2c 20 6a 2c 20 61 64 64     int i, j, add
4bc0: 72 3b 0a 0a 20 20 20 20 2f 2a 20 43 6f 64 65 20  r;..    /* Code 
4bd0: 74 68 61 74 20 69 6e 69 74 69 61 6c 69 7a 65 73  that initializes
4be0: 20 74 68 65 20 69 6e 74 65 67 72 69 74 79 20 63   the integrity c
4bf0: 68 65 63 6b 20 70 72 6f 67 72 61 6d 2e 20 20 53  heck program.  S
4c00: 65 74 20 74 68 65 0a 20 20 20 20 2a 2a 20 65 72  et the.    ** er
4c10: 72 6f 72 20 63 6f 75 6e 74 20 30 0a 20 20 20 20  ror count 0.    
4c20: 2a 2f 0a 20 20 20 20 73 74 61 74 69 63 20 56 64  */.    static Vd
4c30: 62 65 4f 70 4c 69 73 74 20 69 6e 69 74 43 6f 64  beOpList initCod
4c40: 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 7b 20  e[] = {.      { 
4c50: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20 20  OP_Integer,     
4c60: 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c  0, 0,        0},
4c70: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4d 65 6d 53  .      { OP_MemS
4c80: 74 6f 72 65 2c 20 20 20 20 30 2c 20 31 2c 20 20  tore,    0, 1,  
4c90: 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20        0},.      
4ca0: 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c  { OP_ColumnName,
4cb0: 20 20 30 2c 20 31 2c 20 20 20 20 20 20 20 20 22    0, 1,        "
4cc0: 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b 22  integrity_check"
4cd0: 7d 2c 0a 20 20 20 20 7d 3b 0a 0a 20 20 20 20 2f  },.    };..    /
4ce0: 2a 20 43 6f 64 65 20 74 68 61 74 20 61 70 70 65  * Code that appe
4cf0: 61 72 73 20 61 74 20 74 68 65 20 65 6e 64 20 6f  ars at the end o
4d00: 66 20 74 68 65 20 69 6e 74 65 67 72 69 74 79 20  f the integrity 
4d10: 63 68 65 63 6b 2e 20 20 49 66 20 6e 6f 20 65 72  check.  If no er
4d20: 72 6f 72 0a 20 20 20 20 2a 2a 20 6d 65 73 73 61  ror.    ** messa
4d30: 67 65 73 20 68 61 76 65 20 62 65 65 6e 20 67 65  ges have been ge
4d40: 6e 65 72 61 74 65 64 2c 20 6f 75 74 70 75 74 20  nerated, output 
4d50: 4f 4b 2e 20 20 4f 74 68 65 72 77 69 73 65 20 6f  OK.  Otherwise o
4d60: 75 74 70 75 74 20 74 68 65 0a 20 20 20 20 2a 2a  utput the.    **
4d70: 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 0a 20   error message. 
4d80: 20 20 20 2a 2f 0a 20 20 20 20 73 74 61 74 69 63     */.    static
4d90: 20 56 64 62 65 4f 70 4c 69 73 74 20 65 6e 64 43   VdbeOpList endC
4da0: 6f 64 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20  ode[] = {.      
4db0: 7b 20 4f 50 5f 4d 65 6d 4c 6f 61 64 2c 20 20 20  { OP_MemLoad,   
4dc0: 20 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30    0, 0,        0
4dd0: 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 49 6e  },.      { OP_In
4de0: 74 65 67 65 72 2c 20 20 20 20 20 30 2c 20 30 2c  teger,     0, 0,
4df0: 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20          0},.    
4e00: 20 20 7b 20 4f 50 5f 4e 65 2c 20 20 20 20 20 20    { OP_Ne,      
4e10: 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20 20      0, 0,       
4e20: 20 30 7d 2c 20 20 20 20 2f 2a 20 32 20 2a 2f 0a   0},    /* 2 */.
4e30: 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e        { OP_Strin
4e40: 67 2c 20 20 20 20 20 20 30 2c 20 30 2c 20 20 20  g,      0, 0,   
4e50: 20 20 20 20 20 22 6f 6b 22 7d 2c 0a 20 20 20 20       "ok"},.    
4e60: 20 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c    { OP_Callback,
4e70: 20 20 20 20 31 2c 20 30 2c 20 20 20 20 20 20 20      1, 0,       
4e80: 20 30 7d 2c 0a 20 20 20 20 7d 3b 0a 0a 20 20 20   0},.    };..   
4e90: 20 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 74   /* Initialize t
4ea0: 68 65 20 56 44 42 45 20 70 72 6f 67 72 61 6d 20  he VDBE program 
4eb0: 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  */.    sqlite3Vd
4ec0: 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20 41  beAddOpList(v, A
4ed0: 72 72 61 79 53 69 7a 65 28 69 6e 69 74 43 6f 64  rraySize(initCod
4ee0: 65 29 2c 20 69 6e 69 74 43 6f 64 65 29 3b 0a 0a  e), initCode);..
4ef0: 20 20 20 20 2f 2a 20 44 6f 20 61 6e 20 69 6e 74      /* Do an int
4f00: 65 67 72 69 74 79 20 63 68 65 63 6b 20 6f 6e 20  egrity check on 
4f10: 65 61 63 68 20 64 61 74 61 62 61 73 65 20 66 69  each database fi
4f20: 6c 65 20 2a 2f 0a 20 20 20 20 66 6f 72 28 69 3d  le */.    for(i=
4f30: 30 3b 20 69 3c 64 62 2d 3e 6e 44 62 3b 20 69 2b  0; i<db->nDb; i+
4f40: 2b 29 7b 0a 20 20 20 20 20 20 48 61 73 68 45 6c  +){.      HashEl
4f50: 65 6d 20 2a 78 3b 0a 20 20 20 20 20 20 69 6e 74  em *x;.      int
4f60: 20 63 6e 74 20 3d 20 30 3b 0a 0a 20 20 20 20 20   cnt = 0;..     
4f70: 20 2f 2a 20 44 6f 20 61 6e 20 69 6e 74 65 67 72   /* Do an integr
4f80: 69 74 79 20 63 68 65 63 6b 20 6f 66 20 74 68 65  ity check of the
4f90: 20 42 2d 54 72 65 65 0a 20 20 20 20 20 20 2a 2f   B-Tree.      */
4fa0: 0a 20 20 20 20 20 20 66 6f 72 28 78 3d 73 71 6c  .      for(x=sql
4fb0: 69 74 65 48 61 73 68 46 69 72 73 74 28 26 64 62  iteHashFirst(&db
4fc0: 2d 3e 61 44 62 5b 69 5d 2e 74 62 6c 48 61 73 68  ->aDb[i].tblHash
4fd0: 29 3b 20 78 3b 20 78 3d 73 71 6c 69 74 65 48 61  ); x; x=sqliteHa
4fe0: 73 68 4e 65 78 74 28 78 29 29 7b 0a 20 20 20 20  shNext(x)){.    
4ff0: 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 20      Table *pTab 
5000: 3d 20 73 71 6c 69 74 65 48 61 73 68 44 61 74 61  = sqliteHashData
5010: 28 78 29 3b 0a 20 20 20 20 20 20 20 20 49 6e 64  (x);.        Ind
5020: 65 78 20 2a 70 49 64 78 3b 0a 20 20 20 20 20 20  ex *pIdx;.      
5030: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
5040: 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72  Op(v, OP_Integer
5050: 2c 20 70 54 61 62 2d 3e 74 6e 75 6d 2c 20 30 29  , pTab->tnum, 0)
5060: 3b 0a 20 20 20 20 20 20 20 20 63 6e 74 2b 2b 3b  ;.        cnt++;
5070: 0a 20 20 20 20 20 20 20 20 66 6f 72 28 70 49 64  .        for(pId
5080: 78 3d 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b 20  x=pTab->pIndex; 
5090: 70 49 64 78 3b 20 70 49 64 78 3d 70 49 64 78 2d  pIdx; pIdx=pIdx-
50a0: 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 20 20 20  >pNext){.       
50b0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
50c0: 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65  dOp(v, OP_Intege
50d0: 72 2c 20 70 49 64 78 2d 3e 74 6e 75 6d 2c 20 30  r, pIdx->tnum, 0
50e0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 63 6e 74  );.          cnt
50f0: 2b 2b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ++;.        }.  
5100: 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69      }.      sqli
5110: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
5120: 4f 50 5f 49 6e 74 65 67 72 69 74 79 43 6b 2c 20  OP_IntegrityCk, 
5130: 63 6e 74 2c 20 69 29 3b 0a 20 20 20 20 20 20 73  cnt, i);.      s
5140: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
5150: 76 2c 20 4f 50 5f 44 75 70 2c 20 30 2c 20 31 29  v, OP_Dup, 0, 1)
5160: 3b 0a 20 20 20 20 20 20 61 64 64 72 20 3d 20 73  ;.      addr = s
5170: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
5180: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
5190: 2c 20 22 6f 6b 22 2c 20 50 33 5f 53 54 41 54 49  , "ok", P3_STATI
51a0: 43 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  C);.      sqlite
51b0: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
51c0: 5f 45 71 2c 20 30 2c 20 61 64 64 72 2b 36 29 3b  _Eq, 0, addr+6);
51d0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
51e0: 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69  beOp3(v, OP_Stri
51f0: 6e 67 2c 20 30 2c 20 30 2c 0a 20 20 20 20 20 20  ng, 0, 0,.      
5200: 20 20 20 73 71 6c 69 74 65 33 4d 50 72 69 6e 74     sqlite3MPrint
5210: 66 28 22 2a 2a 2a 20 69 6e 20 64 61 74 61 62 61  f("*** in databa
5220: 73 65 20 25 73 20 2a 2a 2a 5c 6e 22 2c 20 64 62  se %s ***\n", db
5230: 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 29 2c  ->aDb[i].zName),
5240: 0a 20 20 20 20 20 20 20 20 20 50 33 5f 44 59 4e  .         P3_DYN
5250: 41 4d 49 43 29 3b 0a 20 20 20 20 20 20 73 71 6c  AMIC);.      sql
5260: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
5270: 20 4f 50 5f 50 75 6c 6c 2c 20 31 2c 20 30 29 3b   OP_Pull, 1, 0);
5280: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
5290: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 43 6f  beAddOp(v, OP_Co
52a0: 6e 63 61 74 2c 20 32 2c 20 31 29 3b 0a 20 20 20  ncat, 2, 1);.   
52b0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
52c0: 64 4f 70 28 76 2c 20 4f 50 5f 43 61 6c 6c 62 61  dOp(v, OP_Callba
52d0: 63 6b 2c 20 31 2c 20 30 29 3b 0a 0a 20 20 20 20  ck, 1, 0);..    
52e0: 20 20 2f 2a 20 4d 61 6b 65 20 73 75 72 65 20 61    /* Make sure a
52f0: 6c 6c 20 74 68 65 20 69 6e 64 69 63 65 73 20 61  ll the indices a
5300: 72 65 20 63 6f 6e 73 74 72 75 63 74 65 64 20 63  re constructed c
5310: 6f 72 72 65 63 74 6c 79 2e 0a 20 20 20 20 20 20  orrectly..      
5320: 2a 2f 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  */.      sqlite3
5330: 43 6f 64 65 56 65 72 69 66 79 53 63 68 65 6d 61  CodeVerifySchema
5340: 28 70 50 61 72 73 65 2c 20 69 29 3b 0a 20 20 20  (pParse, i);.   
5350: 20 20 20 66 6f 72 28 78 3d 73 71 6c 69 74 65 48     for(x=sqliteH
5360: 61 73 68 46 69 72 73 74 28 26 64 62 2d 3e 61 44  ashFirst(&db->aD
5370: 62 5b 69 5d 2e 74 62 6c 48 61 73 68 29 3b 20 78  b[i].tblHash); x
5380: 3b 20 78 3d 73 71 6c 69 74 65 48 61 73 68 4e 65  ; x=sqliteHashNe
5390: 78 74 28 78 29 29 7b 0a 20 20 20 20 20 20 20 20  xt(x)){.        
53a0: 54 61 62 6c 65 20 2a 70 54 61 62 20 3d 20 73 71  Table *pTab = sq
53b0: 6c 69 74 65 48 61 73 68 44 61 74 61 28 78 29 3b  liteHashData(x);
53c0: 0a 20 20 20 20 20 20 20 20 49 6e 64 65 78 20 2a  .        Index *
53d0: 70 49 64 78 3b 0a 20 20 20 20 20 20 20 20 69 6e  pIdx;.        in
53e0: 74 20 6c 6f 6f 70 54 6f 70 3b 0a 0a 20 20 20 20  t loopTop;..    
53f0: 20 20 20 20 69 66 28 20 70 54 61 62 2d 3e 70 49      if( pTab->pI
5400: 6e 64 65 78 3d 3d 30 20 29 20 63 6f 6e 74 69 6e  ndex==0 ) contin
5410: 75 65 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  ue;.        sqli
5420: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
5430: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30  OP_Integer, i, 0
5440: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
5450: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
5460: 50 5f 4f 70 65 6e 52 65 61 64 2c 20 31 2c 20 70  P_OpenRead, 1, p
5470: 54 61 62 2d 3e 74 6e 75 6d 29 3b 0a 20 20 20 20  Tab->tnum);.    
5480: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
5490: 64 64 4f 70 28 76 2c 20 4f 50 5f 53 65 74 4e 75  ddOp(v, OP_SetNu
54a0: 6d 43 6f 6c 75 6d 6e 73 2c 20 31 2c 20 70 54 61  mColumns, 1, pTa
54b0: 62 2d 3e 6e 43 6f 6c 29 3b 0a 20 20 20 20 20 20  b->nCol);.      
54c0: 20 20 66 6f 72 28 6a 3d 30 2c 20 70 49 64 78 3d    for(j=0, pIdx=
54d0: 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b 20 70 49  pTab->pIndex; pI
54e0: 64 78 3b 20 70 49 64 78 3d 70 49 64 78 2d 3e 70  dx; pIdx=pIdx->p
54f0: 4e 65 78 74 2c 20 6a 2b 2b 29 7b 0a 20 20 20 20  Next, j++){.    
5500: 20 20 20 20 20 20 69 66 28 20 70 49 64 78 2d 3e        if( pIdx->
5510: 74 6e 75 6d 3d 3d 30 20 29 20 63 6f 6e 74 69 6e  tnum==0 ) contin
5520: 75 65 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71  ue;.          sq
5530: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
5540: 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 70 49  , OP_Integer, pI
5550: 64 78 2d 3e 69 44 62 2c 20 30 29 3b 0a 20 20 20  dx->iDb, 0);.   
5560: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
5570: 62 65 4f 70 33 28 76 2c 20 4f 50 5f 4f 70 65 6e  beOp3(v, OP_Open
5580: 52 65 61 64 2c 20 6a 2b 32 2c 20 70 49 64 78 2d  Read, j+2, pIdx-
5590: 3e 74 6e 75 6d 2c 20 0a 20 20 20 20 20 20 20 20  >tnum, .        
55a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
55b0: 20 28 63 68 61 72 2a 29 26 70 49 64 78 2d 3e 6b   (char*)&pIdx->k
55c0: 65 79 49 6e 66 6f 2c 20 50 33 5f 4b 45 59 49 4e  eyInfo, P3_KEYIN
55d0: 46 4f 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  FO);.        }. 
55e0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
55f0: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e  beAddOp(v, OP_In
5600: 74 65 67 65 72 2c 20 30 2c 20 30 29 3b 0a 20 20  teger, 0, 0);.  
5610: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
5620: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4d 65 6d  eAddOp(v, OP_Mem
5630: 53 74 6f 72 65 2c 20 31 2c 20 31 29 3b 0a 20 20  Store, 1, 1);.  
5640: 20 20 20 20 20 20 6c 6f 6f 70 54 6f 70 20 3d 20        loopTop = 
5650: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
5660: 28 76 2c 20 4f 50 5f 52 65 77 69 6e 64 2c 20 31  (v, OP_Rewind, 1
5670: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73 71  , 0);.        sq
5680: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
5690: 2c 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20 31 2c  , OP_MemIncr, 1,
56a0: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 66 6f 72   0);.        for
56b0: 28 6a 3d 30 2c 20 70 49 64 78 3d 70 54 61 62 2d  (j=0, pIdx=pTab-
56c0: 3e 70 49 6e 64 65 78 3b 20 70 49 64 78 3b 20 70  >pIndex; pIdx; p
56d0: 49 64 78 3d 70 49 64 78 2d 3e 70 4e 65 78 74 2c  Idx=pIdx->pNext,
56e0: 20 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20   j++){.         
56f0: 20 69 6e 74 20 6b 2c 20 6a 6d 70 32 3b 0a 20 20   int k, jmp2;.  
5700: 20 20 20 20 20 20 20 20 73 74 61 74 69 63 20 56          static V
5710: 64 62 65 4f 70 4c 69 73 74 20 69 64 78 45 72 72  dbeOpList idxErr
5720: 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 20 20 20  [] = {.         
5730: 20 20 20 7b 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c     { OP_MemIncr,
5740: 20 20 20 20 20 30 2c 20 20 30 2c 20 20 30 7d 2c       0,  0,  0},
5750: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f  .            { O
5760: 50 5f 53 74 72 69 6e 67 2c 20 20 20 20 20 20 30  P_String,      0
5770: 2c 20 20 30 2c 20 20 22 72 6f 77 69 64 20 22 7d  ,  0,  "rowid "}
5780: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 20  ,.            { 
5790: 4f 50 5f 52 65 63 6e 6f 2c 20 20 20 20 20 20 20  OP_Recno,       
57a0: 31 2c 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20  1,  0,  0},.    
57b0: 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72          { OP_Str
57c0: 69 6e 67 2c 20 20 20 20 20 20 30 2c 20 20 30 2c  ing,      0,  0,
57d0: 20 20 22 20 6d 69 73 73 69 6e 67 20 66 72 6f 6d    " missing from
57e0: 20 69 6e 64 65 78 20 22 7d 2c 0a 20 20 20 20 20   index "},.     
57f0: 20 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69         { OP_Stri
5800: 6e 67 2c 20 20 20 20 20 20 30 2c 20 20 30 2c 20  ng,      0,  0, 
5810: 20 30 7d 2c 20 20 20 20 2f 2a 20 34 20 2a 2f 0a   0},    /* 4 */.
5820: 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50              { OP
5830: 5f 43 6f 6e 63 61 74 2c 20 20 20 20 20 20 34 2c  _Concat,      4,
5840: 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20    0,  0},.      
5850: 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62        { OP_Callb
5860: 61 63 6b 2c 20 20 20 20 31 2c 20 20 30 2c 20 20  ack,    1,  0,  
5870: 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 7d 3b  0},.          };
5880: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
5890: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
58a0: 50 5f 52 65 63 6e 6f 2c 20 31 2c 20 30 29 3b 0a  P_Recno, 1, 0);.
58b0: 20 20 20 20 20 20 20 20 20 20 66 6f 72 28 6b 3d            for(k=
58c0: 30 3b 20 6b 3c 70 49 64 78 2d 3e 6e 43 6f 6c 75  0; k<pIdx->nColu
58d0: 6d 6e 3b 20 6b 2b 2b 29 7b 0a 20 20 20 20 20 20  mn; k++){.      
58e0: 20 20 20 20 20 20 69 6e 74 20 69 64 78 20 3d 20        int idx = 
58f0: 70 49 64 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 6b  pIdx->aiColumn[k
5900: 5d 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  ];.            i
5910: 66 28 20 69 64 78 3d 3d 70 54 61 62 2d 3e 69 50  f( idx==pTab->iP
5920: 4b 65 79 20 29 7b 0a 20 20 20 20 20 20 20 20 20  Key ){.         
5930: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5940: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 52 65 63 6e  AddOp(v, OP_Recn
5950: 6f 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20 20 20  o, 1, 0);.      
5960: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
5970: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
5980: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
5990: 50 5f 43 6f 6c 75 6d 6e 2c 20 31 2c 20 69 64 78  P_Column, 1, idx
59a0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  );.            }
59b0: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
59c0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
59d0: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4d 61  beAddOp(v, OP_Ma
59e0: 6b 65 49 64 78 4b 65 79 2c 20 70 49 64 78 2d 3e  keIdxKey, pIdx->
59f0: 6e 43 6f 6c 75 6d 6e 2c 20 30 29 3b 0a 20 20 20  nColumn, 0);.   
5a00: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 49 6e         sqlite3In
5a10: 64 65 78 41 66 66 69 6e 69 74 79 53 74 72 28 76  dexAffinityStr(v
5a20: 2c 20 70 49 64 78 29 3b 0a 20 20 20 20 20 20 20  , pIdx);.       
5a30: 20 20 20 6a 6d 70 32 20 3d 20 73 71 6c 69 74 65     jmp2 = sqlite
5a40: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
5a50: 5f 46 6f 75 6e 64 2c 20 6a 2b 32 2c 20 30 29 3b  _Found, j+2, 0);
5a60: 0a 20 20 20 20 20 20 20 20 20 20 61 64 64 72 20  .          addr 
5a70: 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64  = sqlite3VdbeAdd
5a80: 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53  OpList(v, ArrayS
5a90: 69 7a 65 28 69 64 78 45 72 72 29 2c 20 69 64 78  ize(idxErr), idx
5aa0: 45 72 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20  Err);.          
5ab0: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
5ac0: 65 50 33 28 76 2c 20 61 64 64 72 2b 34 2c 20 70  eP3(v, addr+4, p
5ad0: 49 64 78 2d 3e 7a 4e 61 6d 65 2c 20 50 33 5f 53  Idx->zName, P3_S
5ae0: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20  TATIC);.        
5af0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61    sqlite3VdbeCha
5b00: 6e 67 65 50 32 28 76 2c 20 6a 6d 70 32 2c 20 73  ngeP2(v, jmp2, s
5b10: 71 6c 69 74 65 33 56 64 62 65 43 75 72 72 65 6e  qlite3VdbeCurren
5b20: 74 41 64 64 72 28 76 29 29 3b 0a 20 20 20 20 20  tAddr(v));.     
5b30: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 73 71 6c     }.        sql
5b40: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
5b50: 20 4f 50 5f 4e 65 78 74 2c 20 31 2c 20 6c 6f 6f   OP_Next, 1, loo
5b60: 70 54 6f 70 2b 31 29 3b 0a 20 20 20 20 20 20 20  pTop+1);.       
5b70: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
5b80: 67 65 50 32 28 76 2c 20 6c 6f 6f 70 54 6f 70 2c  geP2(v, loopTop,
5b90: 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72 72   sqlite3VdbeCurr
5ba0: 65 6e 74 41 64 64 72 28 76 29 29 3b 0a 20 20 20  entAddr(v));.   
5bb0: 20 20 20 20 20 66 6f 72 28 6a 3d 30 2c 20 70 49       for(j=0, pI
5bc0: 64 78 3d 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b  dx=pTab->pIndex;
5bd0: 20 70 49 64 78 3b 20 70 49 64 78 3d 70 49 64 78   pIdx; pIdx=pIdx
5be0: 2d 3e 70 4e 65 78 74 2c 20 6a 2b 2b 29 7b 0a 20  ->pNext, j++){. 
5bf0: 20 20 20 20 20 20 20 20 20 73 74 61 74 69 63 20           static 
5c00: 56 64 62 65 4f 70 4c 69 73 74 20 63 6e 74 49 64  VdbeOpList cntId
5c10: 78 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 20 20  x[] = {.        
5c20: 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65       { OP_Intege
5c30: 72 2c 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20  r,      0,  0,  
5c40: 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  0},.            
5c50: 20 7b 20 4f 50 5f 4d 65 6d 53 74 6f 72 65 2c 20   { OP_MemStore, 
5c60: 20 20 20 20 32 2c 20 20 31 2c 20 20 30 7d 2c 0a      2,  1,  0},.
5c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f               { O
5c80: 50 5f 52 65 77 69 6e 64 2c 20 20 20 20 20 20 20  P_Rewind,       
5c90: 30 2c 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a 20  0,  0,  0},  /* 
5ca0: 32 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20  2 */.           
5cb0: 20 20 7b 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20    { OP_MemIncr, 
5cc0: 20 20 20 20 20 32 2c 20 20 30 2c 20 20 30 7d 2c       2,  0,  0},
5cd0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20  .             { 
5ce0: 4f 50 5f 4e 65 78 74 2c 20 20 20 20 20 20 20 20  OP_Next,        
5cf0: 20 30 2c 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a   0,  0,  0},  /*
5d00: 20 34 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20   4 */.          
5d10: 20 20 20 7b 20 4f 50 5f 4d 65 6d 4c 6f 61 64 2c     { OP_MemLoad,
5d20: 20 20 20 20 20 20 31 2c 20 20 30 2c 20 20 30 7d        1,  0,  0}
5d30: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  ,.             {
5d40: 20 4f 50 5f 4d 65 6d 4c 6f 61 64 2c 20 20 20 20   OP_MemLoad,    
5d50: 20 20 32 2c 20 20 30 2c 20 20 30 7d 2c 0a 20 20    2,  0,  0},.  
5d60: 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f             { OP_
5d70: 45 71 2c 20 20 20 20 20 20 20 20 20 20 20 30 2c  Eq,           0,
5d80: 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a 20 37 20    0,  0},  /* 7 
5d90: 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  */.             
5da0: 7b 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20 20 20  { OP_MemIncr,   
5db0: 20 20 20 30 2c 20 20 30 2c 20 20 30 7d 2c 0a 20     0,  0,  0},. 
5dc0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50              { OP
5dd0: 5f 53 74 72 69 6e 67 2c 20 20 20 20 20 20 20 30  _String,       0
5de0: 2c 20 20 30 2c 20 20 22 77 72 6f 6e 67 20 23 20  ,  0,  "wrong # 
5df0: 6f 66 20 65 6e 74 72 69 65 73 20 69 6e 20 69 6e  of entries in in
5e00: 64 65 78 20 22 7d 2c 0a 20 20 20 20 20 20 20 20  dex "},.        
5e10: 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67       { OP_String
5e20: 2c 20 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20  ,       0,  0,  
5e30: 30 7d 2c 20 20 2f 2a 20 31 30 20 2a 2f 0a 20 20  0},  /* 10 */.  
5e40: 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f             { OP_
5e50: 43 6f 6e 63 61 74 2c 20 20 20 20 20 20 20 32 2c  Concat,       2,
5e60: 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20    0,  0},.      
5e70: 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c         { OP_Call
5e80: 62 61 63 6b 2c 20 20 20 20 20 31 2c 20 20 30 2c  back,     1,  0,
5e90: 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20    0},.          
5ea0: 7d 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  };.          if(
5eb0: 20 70 49 64 78 2d 3e 74 6e 75 6d 3d 3d 30 20 29   pIdx->tnum==0 )
5ec0: 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20   continue;.     
5ed0: 20 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69       addr = sqli
5ee0: 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74  te3VdbeAddOpList
5ef0: 28 76 2c 20 41 72 72 61 79 53 69 7a 65 28 63 6e  (v, ArraySize(cn
5f00: 74 49 64 78 29 2c 20 63 6e 74 49 64 78 29 3b 0a  tIdx), cntIdx);.
5f10: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
5f20: 33 56 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c  3VdbeChangeP1(v,
5f30: 20 61 64 64 72 2b 32 2c 20 6a 2b 32 29 3b 0a 20   addr+2, j+2);. 
5f40: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
5f50: 56 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c 20  VdbeChangeP2(v, 
5f60: 61 64 64 72 2b 32 2c 20 61 64 64 72 2b 35 29 3b  addr+2, addr+5);
5f70: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
5f80: 65 33 56 64 62 65 43 68 61 6e 67 65 50 31 28 76  e3VdbeChangeP1(v
5f90: 2c 20 61 64 64 72 2b 34 2c 20 6a 2b 32 29 3b 0a  , addr+4, j+2);.
5fa0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
5fb0: 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c  3VdbeChangeP2(v,
5fc0: 20 61 64 64 72 2b 34 2c 20 61 64 64 72 2b 33 29   addr+4, addr+3)
5fd0: 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  ;.          sqli
5fe0: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 32 28  te3VdbeChangeP2(
5ff0: 76 2c 20 61 64 64 72 2b 37 2c 20 61 64 64 72 2b  v, addr+7, addr+
6000: 41 72 72 61 79 53 69 7a 65 28 63 6e 74 49 64 78  ArraySize(cntIdx
6010: 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71  ));.          sq
6020: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
6030: 33 28 76 2c 20 61 64 64 72 2b 31 30 2c 20 70 49  3(v, addr+10, pI
6040: 64 78 2d 3e 7a 4e 61 6d 65 2c 20 50 33 5f 53 54  dx->zName, P3_ST
6050: 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 7d  ATIC);.        }
6060: 0a 20 20 20 20 20 20 7d 20 0a 20 20 20 20 7d 0a  .      } .    }.
6070: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
6080: 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28  e3VdbeAddOpList(
6090: 76 2c 20 41 72 72 61 79 53 69 7a 65 28 65 6e 64  v, ArraySize(end
60a0: 43 6f 64 65 29 2c 20 65 6e 64 43 6f 64 65 29 3b  Code), endCode);
60b0: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
60c0: 43 68 61 6e 67 65 50 32 28 76 2c 20 61 64 64 72  ChangeP2(v, addr
60d0: 2b 32 2c 20 61 64 64 72 2b 41 72 72 61 79 53 69  +2, addr+ArraySi
60e0: 7a 65 28 65 6e 64 43 6f 64 65 29 29 3b 0a 20 20  ze(endCode));.  
60f0: 7d 65 6c 73 65 0a 0a 20 20 7b 7d 0a 20 20 73 71  }else..  {}.  sq
6100: 6c 69 74 65 46 72 65 65 28 7a 4c 65 66 74 29 3b  liteFree(zLeft);
6110: 0a 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a 52  .  sqliteFree(zR
6120: 69 67 68 74 29 3b 0a 7d 0a                       ight);.}.