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

Artifact f436b0f53be47fbc03c661ec7c2b4c5fec14077e:


0000: 2f 2a 0a 2a 2a 20 32 30 30 35 20 4a 75 6c 79 20  /*.** 2005 July 
0010: 38 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68  8.**.** The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65  place of.** a le
0060: 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65  gal notice, here
0070: 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a   is a blessing:.
0080: 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75  **.**    May you
0090: 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74   do good and not
00a0: 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79   evil..**    May
00b0: 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76   you find forgiv
00c0: 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65  eness for yourse
00d0: 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f  lf and forgive o
00e0: 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79  thers..**    May
00f0: 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c   you share freel
0100: 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20  y, never taking 
0110: 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69  more than you gi
0120: 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ve..**.*********
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: 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63 6f  .** This file co
0180: 6e 74 61 69 6e 73 20 63 6f 64 65 20 61 73 73 6f  ntains code asso
0190: 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65 20  ciated with the 
01a0: 41 4e 41 4c 59 5a 45 20 63 6f 6d 6d 61 6e 64 2e  ANALYZE command.
01b0: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 41 4e 41 4c 59  .**.** The ANALY
01c0: 5a 45 20 63 6f 6d 6d 61 6e 64 20 67 61 74 68 65  ZE command gathe
01d0: 72 20 73 74 61 74 69 73 74 69 63 73 20 61 62 6f  r statistics abo
01e0: 75 74 20 74 68 65 20 63 6f 6e 74 65 6e 74 20 6f  ut the content o
01f0: 66 20 74 61 62 6c 65 73 0a 2a 2a 20 61 6e 64 20  f tables.** and 
0200: 69 6e 64 69 63 65 73 2e 20 20 54 68 65 73 65 20  indices.  These 
0210: 73 74 61 74 69 73 74 69 63 73 20 61 72 65 20 6d  statistics are m
0220: 61 64 65 20 61 76 61 69 6c 61 62 6c 65 20 74 6f  ade available to
0230: 20 74 68 65 20 71 75 65 72 79 20 70 6c 61 6e 6e   the query plann
0240: 65 72 0a 2a 2a 20 74 6f 20 68 65 6c 70 20 69 74  er.** to help it
0250: 20 6d 61 6b 65 20 62 65 74 74 65 72 20 64 65 63   make better dec
0260: 69 73 69 6f 6e 73 20 61 62 6f 75 74 20 68 6f 77  isions about how
0270: 20 74 6f 20 70 65 72 66 6f 72 6d 20 71 75 65 72   to perform quer
0280: 69 65 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 66  ies..**.** The f
0290: 6f 6c 6c 6f 77 69 6e 67 20 73 79 73 74 65 6d 20  ollowing system 
02a0: 74 61 62 6c 65 73 20 61 72 65 20 6f 72 20 68 61  tables are or ha
02b0: 76 65 20 62 65 65 6e 20 73 75 70 70 6f 72 74 65  ve been supporte
02c0: 64 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 43 52 45 41  d:.**.**    CREA
02d0: 54 45 20 54 41 42 4c 45 20 73 71 6c 69 74 65 5f  TE TABLE sqlite_
02e0: 73 74 61 74 31 28 74 62 6c 2c 20 69 64 78 2c 20  stat1(tbl, idx, 
02f0: 73 74 61 74 29 3b 0a 2a 2a 20 20 20 20 43 52 45  stat);.**    CRE
0300: 41 54 45 20 54 41 42 4c 45 20 73 71 6c 69 74 65  ATE TABLE sqlite
0310: 5f 73 74 61 74 32 28 74 62 6c 2c 20 69 64 78 2c  _stat2(tbl, idx,
0320: 20 73 61 6d 70 6c 65 6e 6f 2c 20 73 61 6d 70 6c   sampleno, sampl
0330: 65 29 3b 0a 2a 2a 20 20 20 20 43 52 45 41 54 45  e);.**    CREATE
0340: 20 54 41 42 4c 45 20 73 71 6c 69 74 65 5f 73 74   TABLE sqlite_st
0350: 61 74 33 28 74 62 6c 2c 20 69 64 78 2c 20 6e 45  at3(tbl, idx, nE
0360: 71 2c 20 6e 4c 74 2c 20 6e 44 4c 74 2c 20 73 61  q, nLt, nDLt, sa
0370: 6d 70 6c 65 29 3b 0a 2a 2a 0a 2a 2a 20 41 64 64  mple);.**.** Add
0380: 69 74 69 6f 6e 61 6c 20 74 61 62 6c 65 73 20 6d  itional tables m
0390: 69 67 68 74 20 62 65 20 61 64 64 65 64 20 69 6e  ight be added in
03a0: 20 66 75 74 75 72 65 20 72 65 6c 65 61 73 65 73   future releases
03b0: 20 6f 66 20 53 51 4c 69 74 65 2e 0a 2a 2a 20 54   of SQLite..** T
03c0: 68 65 20 73 71 6c 69 74 65 5f 73 74 61 74 32 20  he sqlite_stat2 
03d0: 74 61 62 6c 65 20 69 73 20 6e 6f 74 20 63 72 65  table is not cre
03e0: 61 74 65 64 20 6f 72 20 75 73 65 64 20 75 6e 6c  ated or used unl
03f0: 65 73 73 20 74 68 65 20 53 51 4c 69 74 65 20 76  ess the SQLite v
0400: 65 72 73 69 6f 6e 0a 2a 2a 20 69 73 20 62 65 74  ersion.** is bet
0410: 77 65 65 6e 20 33 2e 36 2e 31 38 20 61 6e 64 20  ween 3.6.18 and 
0420: 33 2e 37 2e 37 2c 20 69 6e 63 6c 75 73 69 76 65  3.7.7, inclusive
0430: 2c 20 61 6e 64 20 75 6e 6c 65 73 73 20 53 51 4c  , and unless SQL
0440: 69 74 65 20 69 73 20 63 6f 6d 70 69 6c 65 64 0a  ite is compiled.
0450: 2a 2a 20 77 69 74 68 20 53 51 4c 49 54 45 5f 45  ** with SQLITE_E
0460: 4e 41 42 4c 45 5f 53 54 41 54 32 2e 20 20 54 68  NABLE_STAT2.  Th
0470: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 32 20 74  e sqlite_stat2 t
0480: 61 62 6c 65 20 69 73 20 64 65 70 72 65 63 61 74  able is deprecat
0490: 65 64 2e 0a 2a 2a 20 54 68 65 20 73 71 6c 69 74  ed..** The sqlit
04a0: 65 5f 73 74 61 74 32 20 74 61 62 6c 65 20 69 73  e_stat2 table is
04b0: 20 73 75 70 65 72 63 65 64 65 64 20 62 79 20 73   superceded by s
04c0: 71 6c 69 74 65 5f 73 74 61 74 33 2c 20 77 68 69  qlite_stat3, whi
04d0: 63 68 20 69 73 20 6f 6e 6c 79 0a 2a 2a 20 63 72  ch is only.** cr
04e0: 65 61 74 65 64 20 61 6e 64 20 75 73 65 64 20 62  eated and used b
04f0: 79 20 53 51 4c 69 74 65 20 76 65 72 73 69 6f 6e  y SQLite version
0500: 73 20 61 66 74 65 72 20 32 30 31 31 2d 30 38 2d  s after 2011-08-
0510: 30 39 20 77 69 74 68 0a 2a 2a 20 53 51 4c 49 54  09 with.** SQLIT
0520: 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 20 64  E_ENABLE_STAT3 d
0530: 65 66 69 6e 65 64 2e 20 20 54 68 65 20 66 75 63  efined.  The fuc
0540: 6e 74 69 6f 6e 61 6c 69 74 79 20 6f 66 20 73 71  ntionality of sq
0550: 6c 69 74 65 5f 73 74 61 74 33 0a 2a 2a 20 69 73  lite_stat3.** is
0560: 20 61 20 73 75 70 65 72 73 65 74 20 6f 66 20 73   a superset of s
0570: 71 6c 69 74 65 5f 73 74 61 74 32 2e 20 20 0a 2a  qlite_stat2.  .*
0580: 2a 0a 2a 2a 20 46 6f 72 6d 61 74 20 6f 66 20 73  *.** Format of s
0590: 71 6c 69 74 65 5f 73 74 61 74 31 3a 0a 2a 2a 0a  qlite_stat1:.**.
05a0: 2a 2a 20 54 68 65 72 65 20 69 73 20 6e 6f 72 6d  ** There is norm
05b0: 61 6c 6c 79 20 6f 6e 65 20 72 6f 77 20 70 65 72  ally one row per
05c0: 20 69 6e 64 65 78 2c 20 77 69 74 68 20 74 68 65   index, with the
05d0: 20 69 6e 64 65 78 20 69 64 65 6e 74 69 66 69 65   index identifie
05e0: 64 20 62 79 20 74 68 65 0a 2a 2a 20 6e 61 6d 65  d by the.** name
05f0: 20 69 6e 20 74 68 65 20 69 64 78 20 63 6f 6c 75   in the idx colu
0600: 6d 6e 2e 20 20 54 68 65 20 74 62 6c 20 63 6f 6c  mn.  The tbl col
0610: 75 6d 6e 20 69 73 20 74 68 65 20 6e 61 6d 65 20  umn is the name 
0620: 6f 66 20 74 68 65 20 74 61 62 6c 65 20 74 6f 0a  of the table to.
0630: 2a 2a 20 77 68 69 63 68 20 74 68 65 20 69 6e 64  ** which the ind
0640: 65 78 20 62 65 6c 6f 6e 67 73 2e 20 20 49 6e 20  ex belongs.  In 
0650: 65 61 63 68 20 73 75 63 68 20 72 6f 77 2c 20 74  each such row, t
0660: 68 65 20 73 74 61 74 20 63 6f 6c 75 6d 6e 20 77  he stat column w
0670: 69 6c 6c 20 62 65 0a 2a 2a 20 61 20 73 74 72 69  ill be.** a stri
0680: 6e 67 20 63 6f 6e 73 69 73 74 69 6e 67 20 6f 66  ng consisting of
0690: 20 61 20 6c 69 73 74 20 6f 66 20 69 6e 74 65 67   a list of integ
06a0: 65 72 73 2e 20 20 54 68 65 20 66 69 72 73 74 20  ers.  The first 
06b0: 69 6e 74 65 67 65 72 20 69 6e 20 74 68 69 73 0a  integer in this.
06c0: 2a 2a 20 6c 69 73 74 20 69 73 20 74 68 65 20 6e  ** list is the n
06d0: 75 6d 62 65 72 20 6f 66 20 72 6f 77 73 20 69 6e  umber of rows in
06e0: 20 74 68 65 20 69 6e 64 65 78 20 61 6e 64 20 69   the index and i
06f0: 6e 20 74 68 65 20 74 61 62 6c 65 2e 20 20 54 68  n the table.  Th
0700: 65 20 73 65 63 6f 6e 64 0a 2a 2a 20 69 6e 74 65  e second.** inte
0710: 67 65 72 20 69 73 20 74 68 65 20 61 76 65 72 61  ger is the avera
0720: 67 65 20 6e 75 6d 62 65 72 20 6f 66 20 72 6f 77  ge number of row
0730: 73 20 69 6e 20 74 68 65 20 69 6e 64 65 78 20 74  s in the index t
0740: 68 61 74 20 68 61 76 65 20 74 68 65 20 73 61 6d  hat have the sam
0750: 65 0a 2a 2a 20 76 61 6c 75 65 20 69 6e 20 74 68  e.** value in th
0760: 65 20 66 69 72 73 74 20 63 6f 6c 75 6d 6e 20 6f  e first column o
0770: 66 20 74 68 65 20 69 6e 64 65 78 2e 20 20 54 68  f the index.  Th
0780: 65 20 74 68 69 72 64 20 69 6e 74 65 67 65 72 20  e third integer 
0790: 69 73 20 74 68 65 20 61 76 65 72 61 67 65 0a 2a  is the average.*
07a0: 2a 20 6e 75 6d 62 65 72 20 6f 66 20 72 6f 77 73  * number of rows
07b0: 20 69 6e 20 74 68 65 20 69 6e 64 65 78 20 74 68   in the index th
07c0: 61 74 20 68 61 76 65 20 74 68 65 20 73 61 6d 65  at have the same
07d0: 20 76 61 6c 75 65 20 66 6f 72 20 74 68 65 20 66   value for the f
07e0: 69 72 73 74 20 74 77 6f 0a 2a 2a 20 63 6f 6c 75  irst two.** colu
07f0: 6d 6e 73 2e 20 20 54 68 65 20 4e 2d 74 68 20 69  mns.  The N-th i
0800: 6e 74 65 67 65 72 20 28 66 6f 72 20 4e 3e 31 29  nteger (for N>1)
0810: 20 69 73 20 74 68 65 20 61 76 65 72 61 67 65 20   is the average 
0820: 6e 75 6d 62 65 72 20 6f 66 20 72 6f 77 73 20 69  number of rows i
0830: 6e 20 0a 2a 2a 20 74 68 65 20 69 6e 64 65 78 20  n .** the index 
0840: 77 68 69 63 68 20 68 61 76 65 20 74 68 65 20 73  which have the s
0850: 61 6d 65 20 76 61 6c 75 65 20 66 6f 72 20 74 68  ame value for th
0860: 65 20 66 69 72 73 74 20 4e 2d 31 20 63 6f 6c 75  e first N-1 colu
0870: 6d 6e 73 2e 20 20 46 6f 72 0a 2a 2a 20 61 20 4b  mns.  For.** a K
0880: 2d 63 6f 6c 75 6d 6e 20 69 6e 64 65 78 2c 20 74  -column index, t
0890: 68 65 72 65 20 77 69 6c 6c 20 62 65 20 4b 2b 31  here will be K+1
08a0: 20 69 6e 74 65 67 65 72 73 20 69 6e 20 74 68 65   integers in the
08b0: 20 73 74 61 74 20 63 6f 6c 75 6d 6e 2e 20 20 49   stat column.  I
08c0: 66 0a 2a 2a 20 74 68 65 20 69 6e 64 65 78 20 69  f.** the index i
08d0: 73 20 75 6e 69 71 75 65 2c 20 74 68 65 6e 20 74  s unique, then t
08e0: 68 65 20 6c 61 73 74 20 69 6e 74 65 67 65 72 20  he last integer 
08f0: 77 69 6c 6c 20 62 65 20 31 2e 0a 2a 2a 0a 2a 2a  will be 1..**.**
0900: 20 54 68 65 20 6c 69 73 74 20 6f 66 20 69 6e 74   The list of int
0910: 65 67 65 72 73 20 69 6e 20 74 68 65 20 73 74 61  egers in the sta
0920: 74 20 63 6f 6c 75 6d 6e 20 63 61 6e 20 6f 70 74  t column can opt
0930: 69 6f 6e 61 6c 6c 79 20 62 65 20 66 6f 6c 6c 6f  ionally be follo
0940: 77 65 64 0a 2a 2a 20 62 79 20 74 68 65 20 6b 65  wed.** by the ke
0950: 79 77 6f 72 64 20 22 75 6e 6f 72 64 65 72 65 64  yword "unordered
0960: 22 2e 20 20 54 68 65 20 22 75 6e 6f 72 64 65 72  ".  The "unorder
0970: 65 64 22 20 6b 65 79 77 6f 72 64 2c 20 69 66 20  ed" keyword, if 
0980: 69 74 20 69 73 20 70 72 65 73 65 6e 74 2c 0a 2a  it is present,.*
0990: 2a 20 6d 75 73 74 20 62 65 20 73 65 70 61 72 61  * must be separa
09a0: 74 65 64 20 66 72 6f 6d 20 74 68 65 20 6c 61 73  ted from the las
09b0: 74 20 69 6e 74 65 67 65 72 20 62 79 20 61 20 73  t integer by a s
09c0: 69 6e 67 6c 65 20 73 70 61 63 65 2e 20 20 49 66  ingle space.  If
09d0: 20 74 68 65 0a 2a 2a 20 22 75 6e 6f 72 64 65 72   the.** "unorder
09e0: 65 64 22 20 6b 65 79 77 6f 72 64 20 69 73 20 70  ed" keyword is p
09f0: 72 65 73 65 6e 74 2c 20 74 68 65 6e 20 74 68 65  resent, then the
0a00: 20 71 75 65 72 79 20 70 6c 61 6e 6e 65 72 20 61   query planner a
0a10: 73 73 75 6d 65 73 20 74 68 61 74 0a 2a 2a 20 74  ssumes that.** t
0a20: 68 65 20 69 6e 64 65 78 20 69 73 20 75 6e 6f 72  he index is unor
0a30: 64 65 72 65 64 20 61 6e 64 20 77 69 6c 6c 20 6e  dered and will n
0a40: 6f 74 20 75 73 65 20 74 68 65 20 69 6e 64 65 78  ot use the index
0a50: 20 66 6f 72 20 61 20 72 61 6e 67 65 20 71 75 65   for a range que
0a60: 72 79 2e 0a 2a 2a 20 0a 2a 2a 20 49 66 20 74 68  ry..** .** If th
0a70: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 31 2e 69  e sqlite_stat1.i
0a80: 64 78 20 63 6f 6c 75 6d 6e 20 69 73 20 4e 55 4c  dx column is NUL
0a90: 4c 2c 20 74 68 65 6e 20 74 68 65 20 73 71 6c 69  L, then the sqli
0aa0: 74 65 5f 73 74 61 74 31 2e 73 74 61 74 0a 2a 2a  te_stat1.stat.**
0ab0: 20 63 6f 6c 75 6d 6e 20 63 6f 6e 74 61 69 6e 73   column contains
0ac0: 20 61 20 73 69 6e 67 6c 65 20 69 6e 74 65 67 65   a single intege
0ad0: 72 20 77 68 69 63 68 20 69 73 20 74 68 65 20 28  r which is the (
0ae0: 65 73 74 69 6d 61 74 65 64 29 20 6e 75 6d 62 65  estimated) numbe
0af0: 72 20 6f 66 0a 2a 2a 20 72 6f 77 73 20 69 6e 20  r of.** rows in 
0b00: 74 68 65 20 74 61 62 6c 65 20 69 64 65 6e 74 69  the table identi
0b10: 66 69 65 64 20 62 79 20 73 71 6c 69 74 65 5f 73  fied by sqlite_s
0b20: 74 61 74 31 2e 74 62 6c 2e 0a 2a 2a 0a 2a 2a 20  tat1.tbl..**.** 
0b30: 46 6f 72 6d 61 74 20 6f 66 20 73 71 6c 69 74 65  Format of sqlite
0b40: 5f 73 74 61 74 32 3a 0a 2a 2a 0a 2a 2a 20 54 68  _stat2:.**.** Th
0b50: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 32 20 69  e sqlite_stat2 i
0b60: 73 20 6f 6e 6c 79 20 63 72 65 61 74 65 64 20 61  s only created a
0b70: 6e 64 20 69 73 20 6f 6e 6c 79 20 75 73 65 64 20  nd is only used 
0b80: 69 66 20 53 51 4c 69 74 65 20 69 73 20 63 6f 6d  if SQLite is com
0b90: 70 69 6c 65 64 0a 2a 2a 20 77 69 74 68 20 53 51  piled.** with SQ
0ba0: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54  LITE_ENABLE_STAT
0bb0: 32 20 61 6e 64 20 69 66 20 74 68 65 20 53 51 4c  2 and if the SQL
0bc0: 69 74 65 20 76 65 72 73 69 6f 6e 20 6e 75 6d 62  ite version numb
0bd0: 65 72 20 69 73 20 62 65 74 77 65 65 6e 0a 2a 2a  er is between.**
0be0: 20 33 2e 36 2e 31 38 20 61 6e 64 20 33 2e 37 2e   3.6.18 and 3.7.
0bf0: 37 2e 20 20 54 68 65 20 22 73 74 61 74 32 22 20  7.  The "stat2" 
0c00: 74 61 62 6c 65 20 63 6f 6e 74 61 69 6e 73 20 61  table contains a
0c10: 64 64 69 74 69 6f 6e 61 6c 20 69 6e 66 6f 72 6d  dditional inform
0c20: 61 74 69 6f 6e 0a 2a 2a 20 61 62 6f 75 74 20 74  ation.** about t
0c30: 68 65 20 64 69 73 74 72 69 62 75 74 69 6f 6e 20  he distribution 
0c40: 6f 66 20 6b 65 79 73 20 77 69 74 68 69 6e 20 61  of keys within a
0c50: 6e 20 69 6e 64 65 78 2e 20 20 54 68 65 20 69 6e  n index.  The in
0c60: 64 65 78 20 69 73 20 69 64 65 6e 74 69 66 69 65  dex is identifie
0c70: 64 20 62 79 0a 2a 2a 20 74 68 65 20 22 69 64 78  d by.** the "idx
0c80: 22 20 63 6f 6c 75 6d 6e 20 61 6e 64 20 74 68 65  " column and the
0c90: 20 22 74 62 6c 22 20 63 6f 6c 75 6d 6e 20 69 73   "tbl" column is
0ca0: 20 74 68 65 20 6e 61 6d 65 20 6f 66 20 74 68 65   the name of the
0cb0: 20 74 61 62 6c 65 20 74 6f 20 77 68 69 63 68 0a   table to which.
0cc0: 2a 2a 20 74 68 65 20 69 6e 64 65 78 20 62 65 6c  ** the index bel
0cd0: 6f 6e 67 73 2e 20 20 54 68 65 72 65 20 61 72 65  ongs.  There are
0ce0: 20 75 73 75 61 6c 6c 79 20 31 30 20 72 6f 77 73   usually 10 rows
0cf0: 20 69 6e 20 74 68 65 20 73 71 6c 69 74 65 5f 73   in the sqlite_s
0d00: 74 61 74 32 0a 2a 2a 20 74 61 62 6c 65 20 66 6f  tat2.** table fo
0d10: 72 20 65 61 63 68 20 69 6e 64 65 78 2e 0a 2a 2a  r each index..**
0d20: 0a 2a 2a 20 54 68 65 20 73 71 6c 69 74 65 5f 73  .** The sqlite_s
0d30: 74 61 74 32 20 65 6e 74 72 69 65 73 20 66 6f 72  tat2 entries for
0d40: 20 61 6e 20 69 6e 64 65 78 20 74 68 61 74 20 68   an index that h
0d50: 61 76 65 20 73 61 6d 70 6c 65 6e 6f 20 62 65 74  ave sampleno bet
0d60: 77 65 65 6e 20 30 20 61 6e 64 20 39 0a 2a 2a 20  ween 0 and 9.** 
0d70: 69 6e 63 6c 75 73 69 76 65 20 61 72 65 20 73 61  inclusive are sa
0d80: 6d 70 6c 65 73 20 6f 66 20 74 68 65 20 6c 65 66  mples of the lef
0d90: 74 2d 6d 6f 73 74 20 6b 65 79 20 76 61 6c 75 65  t-most key value
0da0: 20 69 6e 20 74 68 65 20 69 6e 64 65 78 20 74 61   in the index ta
0db0: 6b 65 6e 20 61 74 0a 2a 2a 20 65 76 65 6e 6c 79  ken at.** evenly
0dc0: 20 73 70 61 63 65 64 20 70 6f 69 6e 74 73 20 61   spaced points a
0dd0: 6c 6f 6e 67 20 74 68 65 20 69 6e 64 65 78 2e 20  long the index. 
0de0: 20 4c 65 74 20 74 68 65 20 6e 75 6d 62 65 72 20   Let the number 
0df0: 6f 66 20 73 61 6d 70 6c 65 73 20 62 65 20 53 0a  of samples be S.
0e00: 2a 2a 20 28 31 30 20 69 6e 20 74 68 65 20 73 74  ** (10 in the st
0e10: 61 6e 64 61 72 64 20 62 75 69 6c 64 29 20 61 6e  andard build) an
0e20: 64 20 6c 65 74 20 43 20 62 65 20 74 68 65 20 6e  d let C be the n
0e30: 75 6d 62 65 72 20 6f 66 20 72 6f 77 73 20 69 6e  umber of rows in
0e40: 20 74 68 65 20 69 6e 64 65 78 2e 0a 2a 2a 20 54   the index..** T
0e50: 68 65 6e 20 74 68 65 20 73 61 6d 70 6c 65 64 20  hen the sampled 
0e60: 72 6f 77 73 20 61 72 65 20 67 69 76 65 6e 20 62  rows are given b
0e70: 79 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 72 6f 77  y:.**.**     row
0e80: 6e 75 6d 62 65 72 20 3d 20 28 69 2a 43 2a 32 20  number = (i*C*2 
0e90: 2b 20 43 29 2f 28 53 2a 32 29 0a 2a 2a 0a 2a 2a  + C)/(S*2).**.**
0ea0: 20 46 6f 72 20 69 20 62 65 74 77 65 65 6e 20 30   For i between 0
0eb0: 20 61 6e 64 20 53 2d 31 2e 20 20 43 6f 6e 63 65   and S-1.  Conce
0ec0: 70 74 75 61 6c 6c 79 2c 20 74 68 65 20 69 6e 64  ptually, the ind
0ed0: 65 78 20 73 70 61 63 65 20 69 73 20 64 69 76 69  ex space is divi
0ee0: 64 65 64 20 69 6e 74 6f 0a 2a 2a 20 53 20 75 6e  ded into.** S un
0ef0: 69 66 6f 72 6d 20 62 75 63 6b 65 74 73 20 61 6e  iform buckets an
0f00: 64 20 74 68 65 20 73 61 6d 70 6c 65 73 20 61 72  d the samples ar
0f10: 65 20 74 68 65 20 6d 69 64 64 6c 65 20 72 6f 77  e the middle row
0f20: 20 66 72 6f 6d 20 65 61 63 68 20 62 75 63 6b 65   from each bucke
0f30: 74 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 66 6f 72  t..**.** The for
0f40: 6d 61 74 20 66 6f 72 20 73 71 6c 69 74 65 5f 73  mat for sqlite_s
0f50: 74 61 74 32 20 69 73 20 72 65 63 6f 72 64 65 64  tat2 is recorded
0f60: 20 68 65 72 65 20 66 6f 72 20 6c 65 67 61 63 79   here for legacy
0f70: 20 72 65 66 65 72 65 6e 63 65 2e 20 20 54 68 69   reference.  Thi
0f80: 73 0a 2a 2a 20 76 65 72 73 69 6f 6e 20 6f 66 20  s.** version of 
0f90: 53 51 4c 69 74 65 20 64 6f 65 73 20 6e 6f 74 20  SQLite does not 
0fa0: 73 75 70 70 6f 72 74 20 73 71 6c 69 74 65 5f 73  support sqlite_s
0fb0: 74 61 74 32 2e 20 20 49 74 20 6e 65 69 74 68 65  tat2.  It neithe
0fc0: 72 20 72 65 61 64 73 20 6e 6f 72 0a 2a 2a 20 77  r reads nor.** w
0fd0: 72 69 74 65 73 20 74 68 65 20 73 71 6c 69 74 65  rites the sqlite
0fe0: 5f 73 74 61 74 32 20 74 61 62 6c 65 2e 20 20 54  _stat2 table.  T
0ff0: 68 69 73 20 76 65 72 73 69 6f 6e 20 6f 66 20 53  his version of S
1000: 51 4c 69 74 65 20 6f 6e 6c 79 20 73 75 70 70 6f  QLite only suppo
1010: 72 74 73 0a 2a 2a 20 73 71 6c 69 74 65 5f 73 74  rts.** sqlite_st
1020: 61 74 33 2e 0a 2a 2a 0a 2a 2a 20 46 6f 72 6d 61  at3..**.** Forma
1030: 74 20 66 6f 72 20 73 71 6c 69 74 65 5f 73 74 61  t for sqlite_sta
1040: 74 33 3a 0a 2a 2a 0a 2a 2a 20 54 68 65 20 73 71  t3:.**.** The sq
1050: 6c 69 74 65 5f 73 74 61 74 33 20 69 73 20 61 6e  lite_stat3 is an
1060: 20 65 6e 68 61 6e 63 65 6d 65 6e 74 20 74 6f 20   enhancement to 
1070: 73 71 6c 69 74 65 5f 73 74 61 74 32 2e 20 20 41  sqlite_stat2.  A
1080: 20 6e 65 77 20 6e 61 6d 65 20 69 73 0a 2a 2a 20   new name is.** 
1090: 75 73 65 64 20 74 6f 20 61 76 6f 69 64 20 63 6f  used to avoid co
10a0: 6d 70 61 74 69 62 69 6c 69 74 79 20 70 72 6f 62  mpatibility prob
10b0: 6c 65 6d 73 2e 20 20 0a 2a 2a 0a 2a 2a 20 54 68  lems.  .**.** Th
10c0: 65 20 66 6f 72 6d 61 74 20 6f 66 20 74 68 65 20  e format of the 
10d0: 73 71 6c 69 74 65 5f 73 74 61 74 33 20 74 61 62  sqlite_stat3 tab
10e0: 6c 65 20 69 73 20 73 69 6d 69 6c 61 72 20 74 6f  le is similar to
10f0: 20 74 68 65 20 66 6f 72 6d 61 74 20 66 6f 72 0a   the format for.
1100: 2a 2a 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74  ** the sqlite_st
1110: 61 74 32 20 74 61 62 6c 65 2c 20 77 69 74 68 20  at2 table, with 
1120: 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 63 68  the following ch
1130: 61 6e 67 65 73 3a 20 20 28 31 29 0a 2a 2a 20 54  anges:  (1).** T
1140: 68 65 20 73 61 6d 70 6c 65 6e 6f 20 63 6f 6c 75  he sampleno colu
1150: 6d 6e 20 69 73 20 72 65 6d 6f 76 65 64 2e 20 20  mn is removed.  
1160: 28 32 29 20 45 76 65 72 79 20 73 61 6d 70 6c 65  (2) Every sample
1170: 20 68 61 73 20 6e 45 71 2c 20 6e 4c 74 2c 20 61   has nEq, nLt, a
1180: 6e 64 20 6e 44 4c 74 0a 2a 2a 20 63 6f 6c 75 6d  nd nDLt.** colum
1190: 6e 73 20 77 68 69 63 68 20 68 6f 6c 64 20 74 68  ns which hold th
11a0: 65 20 61 70 70 72 6f 78 69 6d 61 74 65 20 6e 75  e approximate nu
11b0: 6d 62 65 72 20 6f 66 20 72 6f 77 73 20 69 6e 20  mber of rows in 
11c0: 74 68 65 20 74 61 62 6c 65 20 74 68 61 74 0a 2a  the table that.*
11d0: 2a 20 65 78 61 63 74 6c 79 20 6d 61 74 63 68 20  * exactly match 
11e0: 74 68 65 20 73 61 6d 70 6c 65 2c 20 74 68 65 20  the sample, the 
11f0: 61 70 70 72 6f 78 69 6d 61 74 65 20 6e 75 6d 62  approximate numb
1200: 65 72 20 6f 66 20 72 6f 77 73 20 77 69 74 68 20  er of rows with 
1210: 76 61 6c 75 65 73 0a 2a 2a 20 6c 65 73 73 20 74  values.** less t
1220: 68 61 6e 20 74 68 65 20 73 61 6d 70 6c 65 2c 20  han the sample, 
1230: 61 6e 64 20 74 68 65 20 61 70 70 72 6f 78 69 6d  and the approxim
1240: 61 74 65 20 6e 75 6d 62 65 72 20 6f 66 20 64 69  ate number of di
1250: 73 74 69 6e 63 74 20 6b 65 79 20 76 61 6c 75 65  stinct key value
1260: 73 0a 2a 2a 20 6c 65 73 73 20 74 68 61 6e 20 74  s.** less than t
1270: 68 65 20 73 61 6d 70 6c 65 2c 20 72 65 73 70 65  he sample, respe
1280: 63 74 69 76 65 6c 79 2e 20 20 28 33 29 20 54 68  ctively.  (3) Th
1290: 65 20 6e 75 6d 62 65 72 20 6f 66 20 73 61 6d 70  e number of samp
12a0: 6c 65 73 20 63 61 6e 20 76 61 72 79 20 0a 2a 2a  les can vary .**
12b0: 20 66 72 6f 6d 20 6f 6e 65 20 74 61 62 6c 65 20   from one table 
12c0: 74 6f 20 74 68 65 20 6e 65 78 74 3b 20 74 68 65  to the next; the
12d0: 20 73 61 6d 70 6c 65 20 63 6f 75 6e 74 20 64 6f   sample count do
12e0: 65 73 20 6e 6f 74 20 68 61 76 65 20 74 6f 20 62  es not have to b
12f0: 65 20 0a 2a 2a 20 65 78 61 63 74 6c 79 20 31 30  e .** exactly 10
1300: 20 61 73 20 69 74 20 69 73 20 77 69 74 68 20 73   as it is with s
1310: 71 6c 69 74 65 5f 73 74 61 74 32 2e 0a 2a 2a 0a  qlite_stat2..**.
1320: 2a 2a 20 54 68 65 20 41 4e 41 4c 59 5a 45 20 63  ** The ANALYZE c
1330: 6f 6d 6d 61 6e 64 20 77 69 6c 6c 20 74 79 70 69  ommand will typi
1340: 63 61 6c 6c 79 20 67 65 6e 65 72 61 74 65 20 73  cally generate s
1350: 71 6c 69 74 65 5f 73 74 61 74 33 20 74 61 62 6c  qlite_stat3 tabl
1360: 65 73 0a 2a 2a 20 74 68 61 74 20 63 6f 6e 74 61  es.** that conta
1370: 69 6e 20 62 65 74 77 65 65 6e 20 31 30 20 61 6e  in between 10 an
1380: 64 20 34 30 20 73 61 6d 70 6c 65 73 20 77 68 69  d 40 samples whi
1390: 63 68 20 61 72 65 20 64 69 73 74 72 69 62 75 74  ch are distribut
13a0: 65 64 20 61 63 72 6f 73 73 0a 2a 2a 20 74 68 65  ed across.** the
13b0: 20 6b 65 79 20 73 70 61 63 65 2c 20 74 68 6f 75   key space, thou
13c0: 67 68 20 6e 6f 74 20 75 6e 69 66 6f 72 6d 6c 79  gh not uniformly
13d0: 2c 20 61 6e 64 20 77 68 69 63 68 20 69 6e 63 6c  , and which incl
13e0: 75 64 65 20 73 61 6d 70 6c 65 73 20 77 69 74 68  ude samples with
13f0: 0a 2a 2a 20 6c 61 72 67 65 73 74 20 70 6f 73 73  .** largest poss
1400: 69 62 6c 65 20 6e 45 71 20 76 61 6c 75 65 73 2e  ible nEq values.
1410: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  .*/.#ifndef SQLI
1420: 54 45 5f 4f 4d 49 54 5f 41 4e 41 4c 59 5a 45 0a  TE_OMIT_ANALYZE.
1430: 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65  #include "sqlite
1440: 49 6e 74 2e 68 22 0a 0a 2f 2a 0a 2a 2a 20 54 68  Int.h"../*.** Th
1450: 69 73 20 72 6f 75 74 69 6e 65 20 67 65 6e 65 72  is routine gener
1460: 61 74 65 73 20 63 6f 64 65 20 74 68 61 74 20 6f  ates code that o
1470: 70 65 6e 73 20 74 68 65 20 73 71 6c 69 74 65 5f  pens the sqlite_
1480: 73 74 61 74 31 20 74 61 62 6c 65 20 66 6f 72 0a  stat1 table for.
1490: 2a 2a 20 77 72 69 74 69 6e 67 20 77 69 74 68 20  ** writing with 
14a0: 63 75 72 73 6f 72 20 69 53 74 61 74 43 75 72 2e  cursor iStatCur.
14b0: 20 49 66 20 74 68 65 20 6c 69 62 72 61 72 79 20   If the library 
14c0: 77 61 73 20 62 75 69 6c 74 20 77 69 74 68 20 74  was built with t
14d0: 68 65 0a 2a 2a 20 53 51 4c 49 54 45 5f 45 4e 41  he.** SQLITE_ENA
14e0: 42 4c 45 5f 53 54 41 54 32 20 6d 61 63 72 6f 20  BLE_STAT2 macro 
14f0: 64 65 66 69 6e 65 64 2c 20 74 68 65 6e 20 74 68  defined, then th
1500: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 32 20 74  e sqlite_stat2 t
1510: 61 62 6c 65 20 69 73 0a 2a 2a 20 6f 70 65 6e 65  able is.** opene
1520: 64 20 66 6f 72 20 77 72 69 74 69 6e 67 20 75 73  d for writing us
1530: 69 6e 67 20 63 75 72 73 6f 72 20 28 69 53 74 61  ing cursor (iSta
1540: 74 43 75 72 2b 31 29 0a 2a 2a 0a 2a 2a 20 49 66  tCur+1).**.** If
1550: 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74 61 74   the sqlite_stat
1560: 31 20 74 61 62 6c 65 73 20 64 6f 65 73 20 6e 6f  1 tables does no
1570: 74 20 70 72 65 76 69 6f 75 73 6c 79 20 65 78 69  t previously exi
1580: 73 74 2c 20 69 74 20 69 73 20 63 72 65 61 74 65  st, it is create
1590: 64 2e 0a 2a 2a 20 53 69 6d 69 6c 61 72 6c 79 2c  d..** Similarly,
15a0: 20 69 66 20 74 68 65 20 73 71 6c 69 74 65 5f 73   if the sqlite_s
15b0: 74 61 74 32 20 74 61 62 6c 65 20 64 6f 65 73 20  tat2 table does 
15c0: 6e 6f 74 20 65 78 69 73 74 20 61 6e 64 20 74 68  not exist and th
15d0: 65 20 6c 69 62 72 61 72 79 0a 2a 2a 20 69 73 20  e library.** is 
15e0: 63 6f 6d 70 69 6c 65 64 20 77 69 74 68 20 53 51  compiled with SQ
15f0: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54  LITE_ENABLE_STAT
1600: 32 20 64 65 66 69 6e 65 64 2c 20 69 74 20 69 73  2 defined, it is
1610: 20 63 72 65 61 74 65 64 2e 20 0a 2a 2a 0a 2a 2a   created. .**.**
1620: 20 41 72 67 75 6d 65 6e 74 20 7a 57 68 65 72 65   Argument zWhere
1630: 20 6d 61 79 20 62 65 20 61 20 70 6f 69 6e 74 65   may be a pointe
1640: 72 20 74 6f 20 61 20 62 75 66 66 65 72 20 63 6f  r to a buffer co
1650: 6e 74 61 69 6e 69 6e 67 20 61 20 74 61 62 6c 65  ntaining a table
1660: 20 6e 61 6d 65 2c 0a 2a 2a 20 6f 72 20 69 74 20   name,.** or it 
1670: 6d 61 79 20 62 65 20 61 20 4e 55 4c 4c 20 70 6f  may be a NULL po
1680: 69 6e 74 65 72 2e 20 49 66 20 69 74 20 69 73 20  inter. If it is 
1690: 6e 6f 74 20 4e 55 4c 4c 2c 20 74 68 65 6e 20 61  not NULL, then a
16a0: 6c 6c 20 65 6e 74 72 69 65 73 20 69 6e 0a 2a 2a  ll entries in.**
16b0: 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74 61 74   the sqlite_stat
16c0: 31 20 61 6e 64 20 28 69 66 20 61 70 70 6c 69 63  1 and (if applic
16d0: 61 62 6c 65 29 20 73 71 6c 69 74 65 5f 73 74 61  able) sqlite_sta
16e0: 74 32 20 74 61 62 6c 65 73 20 61 73 73 6f 63 69  t2 tables associ
16f0: 61 74 65 64 0a 2a 2a 20 77 69 74 68 20 74 68 65  ated.** with the
1700: 20 6e 61 6d 65 64 20 74 61 62 6c 65 20 61 72 65   named table are
1710: 20 64 65 6c 65 74 65 64 2e 20 49 66 20 7a 57 68   deleted. If zWh
1720: 65 72 65 3d 3d 30 2c 20 74 68 65 6e 20 63 6f 64  ere==0, then cod
1730: 65 20 69 73 20 67 65 6e 65 72 61 74 65 64 0a 2a  e is generated.*
1740: 2a 20 74 6f 20 64 65 6c 65 74 65 20 61 6c 6c 20  * to delete all 
1750: 73 74 61 74 20 74 61 62 6c 65 20 65 6e 74 72 69  stat table entri
1760: 65 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  es..*/.static vo
1770: 69 64 20 6f 70 65 6e 53 74 61 74 54 61 62 6c 65  id openStatTable
1780: 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73  (.  Parse *pPars
1790: 65 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20 50  e,          /* P
17a0: 61 72 73 69 6e 67 20 63 6f 6e 74 65 78 74 20 2a  arsing context *
17b0: 2f 0a 20 20 69 6e 74 20 69 44 62 2c 20 20 20 20  /.  int iDb,    
17c0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
17d0: 68 65 20 64 61 74 61 62 61 73 65 20 77 65 20 61  he database we a
17e0: 72 65 20 6c 6f 6f 6b 69 6e 67 20 69 6e 20 2a 2f  re looking in */
17f0: 0a 20 20 69 6e 74 20 69 53 74 61 74 43 75 72 2c  .  int iStatCur,
1800: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 70             /* Op
1810: 65 6e 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74  en the sqlite_st
1820: 61 74 31 20 74 61 62 6c 65 20 6f 6e 20 74 68 69  at1 table on thi
1830: 73 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20 63 6f  s cursor */.  co
1840: 6e 73 74 20 63 68 61 72 20 2a 7a 57 68 65 72 65  nst char *zWhere
1850: 2c 20 20 20 20 20 2f 2a 20 44 65 6c 65 74 65 20  ,     /* Delete 
1860: 65 6e 74 72 69 65 73 20 66 6f 72 20 74 68 69 73  entries for this
1870: 20 74 61 62 6c 65 20 6f 72 20 69 6e 64 65 78 20   table or index 
1880: 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  */.  const char 
1890: 2a 7a 57 68 65 72 65 54 79 70 65 20 20 2f 2a 20  *zWhereType  /* 
18a0: 45 69 74 68 65 72 20 22 74 62 6c 22 20 6f 72 20  Either "tbl" or 
18b0: 22 69 64 78 22 20 2a 2f 0a 29 7b 0a 20 20 73 74  "idx" */.){.  st
18c0: 61 74 69 63 20 63 6f 6e 73 74 20 73 74 72 75 63  atic const struc
18d0: 74 20 7b 0a 20 20 20 20 63 6f 6e 73 74 20 63 68  t {.    const ch
18e0: 61 72 20 2a 7a 4e 61 6d 65 3b 0a 20 20 20 20 63  ar *zName;.    c
18f0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 43 6f 6c 73  onst char *zCols
1900: 3b 0a 20 20 7d 20 61 54 61 62 6c 65 5b 5d 20 3d  ;.  } aTable[] =
1910: 20 7b 0a 20 20 20 20 7b 20 22 73 71 6c 69 74 65   {.    { "sqlite
1920: 5f 73 74 61 74 31 22 2c 20 22 74 62 6c 2c 69 64  _stat1", "tbl,id
1930: 78 2c 73 74 61 74 22 20 7d 2c 0a 23 69 66 64 65  x,stat" },.#ifde
1940: 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f  f SQLITE_ENABLE_
1950: 53 54 41 54 33 0a 20 20 20 20 7b 20 22 73 71 6c  STAT3.    { "sql
1960: 69 74 65 5f 73 74 61 74 33 22 2c 20 22 74 62 6c  ite_stat3", "tbl
1970: 2c 69 64 78 2c 6e 65 71 2c 6e 6c 74 2c 6e 64 6c  ,idx,neq,nlt,ndl
1980: 74 2c 73 61 6d 70 6c 65 22 20 7d 2c 0a 23 65 6e  t,sample" },.#en
1990: 64 69 66 0a 20 20 7d 3b 0a 20 20 73 74 61 74 69  dif.  };.  stati
19a0: 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 61 7a  c const char *az
19b0: 54 6f 44 72 6f 70 5b 5d 20 3d 20 7b 20 0a 20 20  ToDrop[] = { .  
19c0: 20 20 22 73 71 6c 69 74 65 5f 73 74 61 74 32 22    "sqlite_stat2"
19d0: 2c 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  ,.#ifndef SQLITE
19e0: 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 0a 20 20  _ENABLE_STAT3.  
19f0: 20 20 22 73 71 6c 69 74 65 5f 73 74 61 74 33 22    "sqlite_stat3"
1a00: 2c 0a 23 65 6e 64 69 66 0a 20 20 7d 3b 0a 0a 20  ,.#endif.  };.. 
1a10: 20 69 6e 74 20 61 52 6f 6f 74 5b 5d 20 3d 20 7b   int aRoot[] = {
1a20: 30 2c 20 30 7d 3b 0a 20 20 75 38 20 61 43 72 65  0, 0};.  u8 aCre
1a30: 61 74 65 54 62 6c 5b 5d 20 3d 20 7b 30 2c 20 30  ateTbl[] = {0, 0
1a40: 7d 3b 0a 0a 20 20 69 6e 74 20 69 3b 0a 20 20 73  };..  int i;.  s
1a50: 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70 50 61  qlite3 *db = pPa
1a60: 72 73 65 2d 3e 64 62 3b 0a 20 20 44 62 20 2a 70  rse->db;.  Db *p
1a70: 44 62 3b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20  Db;.  Vdbe *v = 
1a80: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
1a90: 50 61 72 73 65 29 3b 0a 20 20 69 66 28 20 76 3d  Parse);.  if( v=
1aa0: 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20 20 61  =0 ) return;.  a
1ab0: 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 42 74  ssert( sqlite3Bt
1ac0: 72 65 65 48 6f 6c 64 73 41 6c 6c 4d 75 74 65 78  reeHoldsAllMutex
1ad0: 65 73 28 64 62 29 20 29 3b 0a 20 20 61 73 73 65  es(db) );.  asse
1ae0: 72 74 28 20 73 71 6c 69 74 65 33 56 64 62 65 44  rt( sqlite3VdbeD
1af0: 62 28 76 29 3d 3d 64 62 20 29 3b 0a 20 20 70 44  b(v)==db );.  pD
1b00: 62 20 3d 20 26 64 62 2d 3e 61 44 62 5b 69 44 62  b = &db->aDb[iDb
1b10: 5d 3b 0a 0a 20 20 2f 2a 20 44 72 6f 70 20 61 6c  ];..  /* Drop al
1b20: 6c 20 73 74 61 74 69 73 74 69 63 73 20 74 61 62  l statistics tab
1b30: 6c 65 73 20 74 68 61 74 20 74 68 69 73 20 76 65  les that this ve
1b40: 72 73 69 6f 6e 20 6f 66 20 53 51 4c 69 74 65 20  rsion of SQLite 
1b50: 64 6f 65 73 20 6e 6f 74 0a 20 20 2a 2a 20 75 6e  does not.  ** un
1b60: 64 65 72 73 74 61 6e 64 2e 0a 20 20 2a 2f 0a 20  derstand..  */. 
1b70: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 41 72 72 61   for(i=0; i<Arra
1b80: 79 53 69 7a 65 28 61 7a 54 6f 44 72 6f 70 29 3b  ySize(azToDrop);
1b90: 20 69 2b 2b 29 7b 0a 20 20 20 20 54 61 62 6c 65   i++){.    Table
1ba0: 20 2a 70 54 61 62 20 3d 20 73 71 6c 69 74 65 33   *pTab = sqlite3
1bb0: 46 69 6e 64 54 61 62 6c 65 28 64 62 2c 20 61 7a  FindTable(db, az
1bc0: 54 6f 44 72 6f 70 5b 69 5d 2c 20 70 44 62 2d 3e  ToDrop[i], pDb->
1bd0: 7a 4e 61 6d 65 29 3b 0a 20 20 20 20 69 66 28 20  zName);.    if( 
1be0: 70 54 61 62 20 29 20 73 71 6c 69 74 65 33 43 6f  pTab ) sqlite3Co
1bf0: 64 65 44 72 6f 70 54 61 62 6c 65 28 70 50 61 72  deDropTable(pPar
1c00: 73 65 2c 20 70 54 61 62 2c 20 69 44 62 2c 20 30  se, pTab, iDb, 0
1c10: 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 43 72 65  );.  }..  /* Cre
1c20: 61 74 65 20 6e 65 77 20 73 74 61 74 69 73 74 69  ate new statisti
1c30: 63 20 74 61 62 6c 65 73 20 69 66 20 74 68 65 79  c tables if they
1c40: 20 64 6f 20 6e 6f 74 20 65 78 69 73 74 2c 20 6f   do not exist, o
1c50: 72 20 63 6c 65 61 72 20 74 68 65 6d 0a 20 20 2a  r clear them.  *
1c60: 2a 20 69 66 20 74 68 65 79 20 64 6f 20 61 6c 72  * if they do alr
1c70: 65 61 64 79 20 65 78 69 73 74 2e 0a 20 20 2a 2f  eady exist..  */
1c80: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 41 72  .  for(i=0; i<Ar
1c90: 72 61 79 53 69 7a 65 28 61 54 61 62 6c 65 29 3b  raySize(aTable);
1ca0: 20 69 2b 2b 29 7b 0a 20 20 20 20 63 6f 6e 73 74   i++){.    const
1cb0: 20 63 68 61 72 20 2a 7a 54 61 62 20 3d 20 61 54   char *zTab = aT
1cc0: 61 62 6c 65 5b 69 5d 2e 7a 4e 61 6d 65 3b 0a 20  able[i].zName;. 
1cd0: 20 20 20 54 61 62 6c 65 20 2a 70 53 74 61 74 3b     Table *pStat;
1ce0: 0a 20 20 20 20 69 66 28 20 28 70 53 74 61 74 20  .    if( (pStat 
1cf0: 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 54 61 62  = sqlite3FindTab
1d00: 6c 65 28 64 62 2c 20 7a 54 61 62 2c 20 70 44 62  le(db, zTab, pDb
1d10: 2d 3e 7a 4e 61 6d 65 29 29 3d 3d 30 20 29 7b 0a  ->zName))==0 ){.
1d20: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 73 71 6c        /* The sql
1d30: 69 74 65 5f 73 74 61 74 5b 31 32 5d 20 74 61 62  ite_stat[12] tab
1d40: 6c 65 20 64 6f 65 73 20 6e 6f 74 20 65 78 69 73  le does not exis
1d50: 74 2e 20 43 72 65 61 74 65 20 69 74 2e 20 4e 6f  t. Create it. No
1d60: 74 65 20 74 68 61 74 20 61 20 0a 20 20 20 20 20  te that a .     
1d70: 20 2a 2a 20 73 69 64 65 2d 65 66 66 65 63 74 20   ** side-effect 
1d80: 6f 66 20 74 68 65 20 43 52 45 41 54 45 20 54 41  of the CREATE TA
1d90: 42 4c 45 20 73 74 61 74 65 6d 65 6e 74 20 69 73  BLE statement is
1da0: 20 74 6f 20 6c 65 61 76 65 20 74 68 65 20 72 6f   to leave the ro
1db0: 6f 74 70 61 67 65 20 0a 20 20 20 20 20 20 2a 2a  otpage .      **
1dc0: 20 6f 66 20 74 68 65 20 6e 65 77 20 74 61 62 6c   of the new tabl
1dd0: 65 20 69 6e 20 72 65 67 69 73 74 65 72 20 70 50  e in register pP
1de0: 61 72 73 65 2d 3e 72 65 67 52 6f 6f 74 2e 20 54  arse->regRoot. T
1df0: 68 69 73 20 69 73 20 69 6d 70 6f 72 74 61 6e 74  his is important
1e00: 20 0a 20 20 20 20 20 20 2a 2a 20 62 65 63 61 75   .      ** becau
1e10: 73 65 20 74 68 65 20 4f 70 65 6e 57 72 69 74 65  se the OpenWrite
1e20: 20 6f 70 63 6f 64 65 20 62 65 6c 6f 77 20 77 69   opcode below wi
1e30: 6c 6c 20 62 65 20 6e 65 65 64 69 6e 67 20 69 74  ll be needing it
1e40: 2e 20 2a 2f 0a 20 20 20 20 20 20 73 71 6c 69 74  . */.      sqlit
1e50: 65 33 4e 65 73 74 65 64 50 61 72 73 65 28 70 50  e3NestedParse(pP
1e60: 61 72 73 65 2c 0a 20 20 20 20 20 20 20 20 20 20  arse,.          
1e70: 22 43 52 45 41 54 45 20 54 41 42 4c 45 20 25 51  "CREATE TABLE %Q
1e80: 2e 25 73 28 25 73 29 22 2c 20 70 44 62 2d 3e 7a  .%s(%s)", pDb->z
1e90: 4e 61 6d 65 2c 20 7a 54 61 62 2c 20 61 54 61 62  Name, zTab, aTab
1ea0: 6c 65 5b 69 5d 2e 7a 43 6f 6c 73 0a 20 20 20 20  le[i].zCols.    
1eb0: 20 20 29 3b 0a 20 20 20 20 20 20 61 52 6f 6f 74    );.      aRoot
1ec0: 5b 69 5d 20 3d 20 70 50 61 72 73 65 2d 3e 72 65  [i] = pParse->re
1ed0: 67 52 6f 6f 74 3b 0a 20 20 20 20 20 20 61 43 72  gRoot;.      aCr
1ee0: 65 61 74 65 54 62 6c 5b 69 5d 20 3d 20 31 3b 0a  eateTbl[i] = 1;.
1ef0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
1f00: 20 2f 2a 20 54 68 65 20 74 61 62 6c 65 20 61 6c   /* The table al
1f10: 72 65 61 64 79 20 65 78 69 73 74 73 2e 20 49 66  ready exists. If
1f20: 20 7a 57 68 65 72 65 20 69 73 20 6e 6f 74 20 4e   zWhere is not N
1f30: 55 4c 4c 2c 20 64 65 6c 65 74 65 20 61 6c 6c 20  ULL, delete all 
1f40: 65 6e 74 72 69 65 73 20 0a 20 20 20 20 20 20 2a  entries .      *
1f50: 2a 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74  * associated wit
1f60: 68 20 74 68 65 20 74 61 62 6c 65 20 7a 57 68 65  h the table zWhe
1f70: 72 65 2e 20 49 66 20 7a 57 68 65 72 65 20 69 73  re. If zWhere is
1f80: 20 4e 55 4c 4c 2c 20 64 65 6c 65 74 65 20 74 68   NULL, delete th
1f90: 65 0a 20 20 20 20 20 20 2a 2a 20 65 6e 74 69 72  e.      ** entir
1fa0: 65 20 63 6f 6e 74 65 6e 74 73 20 6f 66 20 74 68  e contents of th
1fb0: 65 20 74 61 62 6c 65 2e 20 2a 2f 0a 20 20 20 20  e table. */.    
1fc0: 20 20 61 52 6f 6f 74 5b 69 5d 20 3d 20 70 53 74    aRoot[i] = pSt
1fd0: 61 74 2d 3e 74 6e 75 6d 3b 0a 20 20 20 20 20 20  at->tnum;.      
1fe0: 73 71 6c 69 74 65 33 54 61 62 6c 65 4c 6f 63 6b  sqlite3TableLock
1ff0: 28 70 50 61 72 73 65 2c 20 69 44 62 2c 20 61 52  (pParse, iDb, aR
2000: 6f 6f 74 5b 69 5d 2c 20 31 2c 20 7a 54 61 62 29  oot[i], 1, zTab)
2010: 3b 0a 20 20 20 20 20 20 69 66 28 20 7a 57 68 65  ;.      if( zWhe
2020: 72 65 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71  re ){.        sq
2030: 6c 69 74 65 33 4e 65 73 74 65 64 50 61 72 73 65  lite3NestedParse
2040: 28 70 50 61 72 73 65 2c 0a 20 20 20 20 20 20 20  (pParse,.       
2050: 20 20 20 20 22 44 45 4c 45 54 45 20 46 52 4f 4d      "DELETE FROM
2060: 20 25 51 2e 25 73 20 57 48 45 52 45 20 25 73 3d   %Q.%s WHERE %s=
2070: 25 51 22 2c 20 70 44 62 2d 3e 7a 4e 61 6d 65 2c  %Q", pDb->zName,
2080: 20 7a 54 61 62 2c 20 7a 57 68 65 72 65 54 79 70   zTab, zWhereTyp
2090: 65 2c 20 7a 57 68 65 72 65 0a 20 20 20 20 20 20  e, zWhere.      
20a0: 20 20 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65    );.      }else
20b0: 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65  {.        /* The
20c0: 20 73 71 6c 69 74 65 5f 73 74 61 74 5b 31 32 5d   sqlite_stat[12]
20d0: 20 74 61 62 6c 65 20 61 6c 72 65 61 64 79 20 65   table already e
20e0: 78 69 73 74 73 2e 20 20 44 65 6c 65 74 65 20 61  xists.  Delete a
20f0: 6c 6c 20 72 6f 77 73 2e 20 2a 2f 0a 20 20 20 20  ll rows. */.    
2100: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
2110: 64 64 4f 70 32 28 76 2c 20 4f 50 5f 43 6c 65 61  ddOp2(v, OP_Clea
2120: 72 2c 20 61 52 6f 6f 74 5b 69 5d 2c 20 69 44 62  r, aRoot[i], iDb
2130: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
2140: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 4f 70 65 6e 20  .  }..  /* Open 
2150: 74 68 65 20 73 71 6c 69 74 65 5f 73 74 61 74 5b  the sqlite_stat[
2160: 31 33 5d 20 74 61 62 6c 65 73 20 66 6f 72 20 77  13] tables for w
2170: 72 69 74 69 6e 67 2e 20 2a 2f 0a 20 20 66 6f 72  riting. */.  for
2180: 28 69 3d 30 3b 20 69 3c 41 72 72 61 79 53 69 7a  (i=0; i<ArraySiz
2190: 65 28 61 54 61 62 6c 65 29 3b 20 69 2b 2b 29 7b  e(aTable); i++){
21a0: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
21b0: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4f 70 65  AddOp3(v, OP_Ope
21c0: 6e 57 72 69 74 65 2c 20 69 53 74 61 74 43 75 72  nWrite, iStatCur
21d0: 2b 69 2c 20 61 52 6f 6f 74 5b 69 5d 2c 20 69 44  +i, aRoot[i], iD
21e0: 62 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  b);.    sqlite3V
21f0: 64 62 65 43 68 61 6e 67 65 50 34 28 76 2c 20 2d  dbeChangeP4(v, -
2200: 31 2c 20 28 63 68 61 72 20 2a 29 33 2c 20 50 34  1, (char *)3, P4
2210: 5f 49 4e 54 33 32 29 3b 0a 20 20 20 20 73 71 6c  _INT32);.    sql
2220: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 35  ite3VdbeChangeP5
2230: 28 76 2c 20 61 43 72 65 61 74 65 54 62 6c 5b 69  (v, aCreateTbl[i
2240: 5d 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a  ]);.  }.}../*.**
2250: 20 52 65 63 6f 6d 6d 65 6e 64 65 64 20 6e 75 6d   Recommended num
2260: 62 65 72 20 6f 66 20 73 61 6d 70 6c 65 73 20 66  ber of samples f
2270: 6f 72 20 73 71 6c 69 74 65 5f 73 74 61 74 33 0a  or sqlite_stat3.
2280: 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  */.#ifndef SQLIT
2290: 45 5f 53 54 41 54 33 5f 53 41 4d 50 4c 45 53 0a  E_STAT3_SAMPLES.
22a0: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
22b0: 53 54 41 54 33 5f 53 41 4d 50 4c 45 53 20 32 34  STAT3_SAMPLES 24
22c0: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54  .#endif../*.** T
22d0: 68 72 65 65 20 53 51 4c 20 66 75 6e 63 74 69 6f  hree SQL functio
22e0: 6e 73 20 2d 20 73 74 61 74 33 5f 69 6e 69 74 28  ns - stat3_init(
22f0: 29 2c 20 73 74 61 74 33 5f 70 75 73 68 28 29 2c  ), stat3_push(),
2300: 20 61 6e 64 20 73 74 61 74 33 5f 70 6f 70 28 29   and stat3_pop()
2310: 20 2d 0a 2a 2a 20 73 68 61 72 65 20 61 6e 20 69   -.** share an i
2320: 6e 73 74 61 6e 63 65 20 6f 66 20 74 68 65 20 66  nstance of the f
2330: 6f 6c 6c 6f 77 69 6e 67 20 73 74 72 75 63 74 75  ollowing structu
2340: 72 65 20 74 6f 20 68 6f 6c 64 20 74 68 65 69 72  re to hold their
2350: 20 73 74 61 74 65 0a 2a 2a 20 69 6e 66 6f 72 6d   state.** inform
2360: 61 74 69 6f 6e 2e 0a 2a 2f 0a 74 79 70 65 64 65  ation..*/.typede
2370: 66 20 73 74 72 75 63 74 20 53 74 61 74 33 41 63  f struct Stat3Ac
2380: 63 75 6d 20 53 74 61 74 33 41 63 63 75 6d 3b 0a  cum Stat3Accum;.
2390: 73 74 72 75 63 74 20 53 74 61 74 33 41 63 63 75  struct Stat3Accu
23a0: 6d 20 7b 0a 20 20 74 52 6f 77 63 6e 74 20 6e 52  m {.  tRowcnt nR
23b0: 6f 77 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  ow;             
23c0: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 72 6f 77  /* Number of row
23d0: 73 20 69 6e 20 74 68 65 20 65 6e 74 69 72 65 20  s in the entire 
23e0: 74 61 62 6c 65 20 2a 2f 0a 20 20 74 52 6f 77 63  table */.  tRowc
23f0: 6e 74 20 6e 50 53 61 6d 70 6c 65 3b 20 20 20 20  nt nPSample;    
2400: 20 20 20 20 20 2f 2a 20 48 6f 77 20 6f 66 74 65       /* How ofte
2410: 6e 20 74 6f 20 64 6f 20 61 20 70 65 72 69 6f 64  n to do a period
2420: 69 63 20 73 61 6d 70 6c 65 20 2a 2f 0a 20 20 69  ic sample */.  i
2430: 6e 74 20 69 4d 69 6e 3b 20 20 20 20 20 20 20 20  nt iMin;        
2440: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 6e 64 65           /* Inde
2450: 78 20 6f 66 20 65 6e 74 72 79 20 77 69 74 68 20  x of entry with 
2460: 6d 69 6e 69 6d 75 6d 20 6e 45 71 20 61 6e 64 20  minimum nEq and 
2470: 68 61 73 68 20 2a 2f 0a 20 20 69 6e 74 20 6d 78  hash */.  int mx
2480: 53 61 6d 70 6c 65 3b 20 20 20 20 20 20 20 20 20  Sample;         
2490: 20 20 20 20 2f 2a 20 4d 61 78 69 6d 75 6d 20 6e      /* Maximum n
24a0: 75 6d 62 65 72 20 6f 66 20 73 61 6d 70 6c 65 73  umber of samples
24b0: 20 74 6f 20 61 63 63 75 6d 75 6c 61 74 65 20 2a   to accumulate *
24c0: 2f 0a 20 20 69 6e 74 20 6e 53 61 6d 70 6c 65 3b  /.  int nSample;
24d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
24e0: 20 43 75 72 72 65 6e 74 20 6e 75 6d 62 65 72 20   Current number 
24f0: 6f 66 20 73 61 6d 70 6c 65 73 20 2a 2f 0a 20 20  of samples */.  
2500: 75 33 32 20 69 50 72 6e 3b 20 20 20 20 20 20 20  u32 iPrn;       
2510: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 50 73 65            /* Pse
2520: 75 64 6f 2d 72 61 6e 64 6f 6d 20 6e 75 6d 62 65  udo-random numbe
2530: 72 20 75 73 65 64 20 66 6f 72 20 73 61 6d 70 6c  r used for sampl
2540: 69 6e 67 20 2a 2f 0a 20 20 73 74 72 75 63 74 20  ing */.  struct 
2550: 53 74 61 74 33 53 61 6d 70 6c 65 20 7b 0a 20 20  Stat3Sample {.  
2560: 20 20 69 36 34 20 69 52 6f 77 69 64 3b 20 20 20    i64 iRowid;   
2570: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
2580: 52 6f 77 69 64 20 69 6e 20 6d 61 69 6e 20 74 61  Rowid in main ta
2590: 62 6c 65 20 6f 66 20 74 68 65 20 6b 65 79 20 2a  ble of the key *
25a0: 2f 0a 20 20 20 20 74 52 6f 77 63 6e 74 20 6e 45  /.    tRowcnt nE
25b0: 71 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  q;              
25c0: 20 2f 2a 20 73 71 6c 69 74 65 5f 73 74 61 74 33   /* sqlite_stat3
25d0: 2e 6e 45 71 20 2a 2f 0a 20 20 20 20 74 52 6f 77  .nEq */.    tRow
25e0: 63 6e 74 20 6e 4c 74 3b 20 20 20 20 20 20 20 20  cnt nLt;        
25f0: 20 20 20 20 20 20 20 2f 2a 20 73 71 6c 69 74 65         /* sqlite
2600: 5f 73 74 61 74 33 2e 6e 4c 74 20 2a 2f 0a 20 20  _stat3.nLt */.  
2610: 20 20 74 52 6f 77 63 6e 74 20 6e 44 4c 74 3b 20    tRowcnt nDLt; 
2620: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
2630: 73 71 6c 69 74 65 5f 73 74 61 74 33 2e 6e 44 4c  sqlite_stat3.nDL
2640: 74 20 2a 2f 0a 20 20 20 20 75 38 20 69 73 50 53  t */.    u8 isPS
2650: 61 6d 70 6c 65 3b 20 20 20 20 20 20 20 20 20 20  ample;          
2660: 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20 61      /* True if a
2670: 20 70 65 72 69 6f 64 69 63 20 73 61 6d 70 6c 65   periodic sample
2680: 20 2a 2f 0a 20 20 20 20 75 33 32 20 69 48 61 73   */.    u32 iHas
2690: 68 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  h;              
26a0: 20 20 20 2f 2a 20 54 69 65 62 72 65 61 6b 65 72     /* Tiebreaker
26b0: 20 68 61 73 68 20 2a 2f 0a 20 20 7d 20 2a 61 3b   hash */.  } *a;
26c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
26d0: 20 20 20 20 20 2f 2a 20 41 6e 20 61 72 72 61 79       /* An array
26e0: 20 6f 66 20 73 61 6d 70 6c 65 73 20 2a 2f 0a 7d   of samples */.}
26f0: 3b 0a 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  ;..#ifdef SQLITE
2700: 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 0a 2f 2a  _ENABLE_STAT3./*
2710: 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e 74 61 74 69  .** Implementati
2720: 6f 6e 20 6f 66 20 74 68 65 20 73 74 61 74 33 5f  on of the stat3_
2730: 69 6e 69 74 28 43 2c 53 29 20 53 51 4c 20 66 75  init(C,S) SQL fu
2740: 6e 63 74 69 6f 6e 2e 20 20 54 68 65 20 74 77 6f  nction.  The two
2750: 20 70 61 72 61 6d 65 74 65 72 73 0a 2a 2a 20 61   parameters.** a
2760: 72 65 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  re the number of
2770: 20 72 6f 77 73 20 69 6e 20 74 68 65 20 74 61 62   rows in the tab
2780: 6c 65 20 6f 72 20 69 6e 64 65 78 20 28 43 29 20  le or index (C) 
2790: 61 6e 64 20 74 68 65 20 6e 75 6d 62 65 72 20 6f  and the number o
27a0: 66 20 73 61 6d 70 6c 65 73 0a 2a 2a 20 74 6f 20  f samples.** to 
27b0: 61 63 63 75 6d 75 6c 61 74 65 20 28 53 29 2e 0a  accumulate (S)..
27c0: 2a 2a 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69  **.** This routi
27d0: 6e 65 20 61 6c 6c 6f 63 61 74 65 73 20 74 68 65  ne allocates the
27e0: 20 53 74 61 74 33 41 63 63 75 6d 20 6f 62 6a 65   Stat3Accum obje
27f0: 63 74 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 72 65  ct..**.** The re
2800: 74 75 72 6e 20 76 61 6c 75 65 20 69 73 20 74 68  turn value is th
2810: 65 20 53 74 61 74 33 41 63 63 75 6d 20 6f 62 6a  e Stat3Accum obj
2820: 65 63 74 20 28 50 29 2e 0a 2a 2f 0a 73 74 61 74  ect (P)..*/.stat
2830: 69 63 20 76 6f 69 64 20 73 74 61 74 33 49 6e 69  ic void stat3Ini
2840: 74 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e  t(.  sqlite3_con
2850: 74 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a 20  text *context,. 
2860: 20 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71 6c   int argc,.  sql
2870: 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72 67  ite3_value **arg
2880: 76 0a 29 7b 0a 20 20 53 74 61 74 33 41 63 63 75  v.){.  Stat3Accu
2890: 6d 20 2a 70 3b 0a 20 20 74 52 6f 77 63 6e 74 20  m *p;.  tRowcnt 
28a0: 6e 52 6f 77 3b 0a 20 20 69 6e 74 20 6d 78 53 61  nRow;.  int mxSa
28b0: 6d 70 6c 65 3b 0a 20 20 69 6e 74 20 6e 3b 0a 0a  mple;.  int n;..
28c0: 20 20 55 4e 55 53 45 44 5f 50 41 52 41 4d 45 54    UNUSED_PARAMET
28d0: 45 52 28 61 72 67 63 29 3b 0a 20 20 6e 52 6f 77  ER(argc);.  nRow
28e0: 20 3d 20 28 74 52 6f 77 63 6e 74 29 73 71 6c 69   = (tRowcnt)sqli
28f0: 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28  te3_value_int64(
2900: 61 72 67 76 5b 30 5d 29 3b 0a 20 20 6d 78 53 61  argv[0]);.  mxSa
2910: 6d 70 6c 65 20 3d 20 73 71 6c 69 74 65 33 5f 76  mple = sqlite3_v
2920: 61 6c 75 65 5f 69 6e 74 28 61 72 67 76 5b 31 5d  alue_int(argv[1]
2930: 29 3b 0a 20 20 6e 20 3d 20 73 69 7a 65 6f 66 28  );.  n = sizeof(
2940: 2a 70 29 20 2b 20 73 69 7a 65 6f 66 28 70 2d 3e  *p) + sizeof(p->
2950: 61 5b 30 5d 29 2a 6d 78 53 61 6d 70 6c 65 3b 0a  a[0])*mxSample;.
2960: 20 20 70 20 3d 20 73 71 6c 69 74 65 33 5f 6d 61    p = sqlite3_ma
2970: 6c 6c 6f 63 28 20 6e 20 29 3b 0a 20 20 69 66 28  lloc( n );.  if(
2980: 20 70 3d 3d 30 20 29 7b 0a 20 20 20 20 73 71 6c   p==0 ){.    sql
2990: 69 74 65 33 5f 72 65 73 75 6c 74 5f 65 72 72 6f  ite3_result_erro
29a0: 72 5f 6e 6f 6d 65 6d 28 63 6f 6e 74 65 78 74 29  r_nomem(context)
29b0: 3b 0a 20 20 20 20 72 65 74 75 72 6e 3b 0a 20 20  ;.    return;.  
29c0: 7d 0a 20 20 6d 65 6d 73 65 74 28 70 2c 20 30 2c  }.  memset(p, 0,
29d0: 20 6e 29 3b 0a 20 20 70 2d 3e 61 20 3d 20 28 73   n);.  p->a = (s
29e0: 74 72 75 63 74 20 53 74 61 74 33 53 61 6d 70 6c  truct Stat3Sampl
29f0: 65 2a 29 26 70 5b 31 5d 3b 0a 20 20 70 2d 3e 6e  e*)&p[1];.  p->n
2a00: 52 6f 77 20 3d 20 6e 52 6f 77 3b 0a 20 20 70 2d  Row = nRow;.  p-
2a10: 3e 6d 78 53 61 6d 70 6c 65 20 3d 20 6d 78 53 61  >mxSample = mxSa
2a20: 6d 70 6c 65 3b 0a 20 20 70 2d 3e 6e 50 53 61 6d  mple;.  p->nPSam
2a30: 70 6c 65 20 3d 20 70 2d 3e 6e 52 6f 77 2f 28 6d  ple = p->nRow/(m
2a40: 78 53 61 6d 70 6c 65 2f 33 2b 31 29 20 2b 20 31  xSample/3+1) + 1
2a50: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 72 61 6e 64  ;.  sqlite3_rand
2a60: 6f 6d 6e 65 73 73 28 73 69 7a 65 6f 66 28 70 2d  omness(sizeof(p-
2a70: 3e 69 50 72 6e 29 2c 20 26 70 2d 3e 69 50 72 6e  >iPrn), &p->iPrn
2a80: 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73  );.  sqlite3_res
2a90: 75 6c 74 5f 62 6c 6f 62 28 63 6f 6e 74 65 78 74  ult_blob(context
2aa0: 2c 20 70 2c 20 73 69 7a 65 6f 66 28 70 29 2c 20  , p, sizeof(p), 
2ab0: 73 71 6c 69 74 65 33 5f 66 72 65 65 29 3b 0a 7d  sqlite3_free);.}
2ac0: 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20 46 75  .static const Fu
2ad0: 6e 63 44 65 66 20 73 74 61 74 33 49 6e 69 74 46  ncDef stat3InitF
2ae0: 75 6e 63 64 65 66 20 3d 20 7b 0a 20 20 32 2c 20  uncdef = {.  2, 
2af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2b00: 2a 20 6e 41 72 67 20 2a 2f 0a 20 20 53 51 4c 49  * nArg */.  SQLI
2b10: 54 45 5f 55 54 46 38 2c 20 20 20 20 20 20 2f 2a  TE_UTF8,      /*
2b20: 20 69 50 72 65 66 45 6e 63 20 2a 2f 0a 20 20 30   iPrefEnc */.  0
2b30: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
2b40: 20 2f 2a 20 66 6c 61 67 73 20 2a 2f 0a 20 20 30   /* flags */.  0
2b50: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
2b60: 20 2f 2a 20 70 55 73 65 72 44 61 74 61 20 2a 2f   /* pUserData */
2b70: 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20  .  0,           
2b80: 20 20 20 20 20 2f 2a 20 70 4e 65 78 74 20 2a 2f       /* pNext */
2b90: 0a 20 20 73 74 61 74 33 49 6e 69 74 2c 20 20 20  .  stat3Init,   
2ba0: 20 20 20 20 20 2f 2a 20 78 46 75 6e 63 20 2a 2f       /* xFunc */
2bb0: 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20  .  0,           
2bc0: 20 20 20 20 20 2f 2a 20 78 53 74 65 70 20 2a 2f       /* xStep */
2bd0: 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20  .  0,           
2be0: 20 20 20 20 20 2f 2a 20 78 46 69 6e 61 6c 69 7a       /* xFinaliz
2bf0: 65 20 2a 2f 0a 20 20 22 73 74 61 74 33 5f 69 6e  e */.  "stat3_in
2c00: 69 74 22 2c 20 20 20 20 20 2f 2a 20 7a 4e 61 6d  it",     /* zNam
2c10: 65 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20  e */.  0,       
2c20: 20 20 20 20 20 20 20 20 20 2f 2a 20 70 48 61 73           /* pHas
2c30: 68 20 2a 2f 0a 20 20 30 20 20 20 20 20 20 20 20  h */.  0        
2c40: 20 20 20 20 20 20 20 20 20 2f 2a 20 70 44 65 73           /* pDes
2c50: 74 72 75 63 74 6f 72 20 2a 2f 0a 7d 3b 0a 0a 0a  tructor */.};...
2c60: 2f 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e 74 61  /*.** Implementa
2c70: 74 69 6f 6e 20 6f 66 20 74 68 65 20 73 74 61 74  tion of the stat
2c80: 33 5f 70 75 73 68 28 6e 45 71 2c 6e 4c 74 2c 6e  3_push(nEq,nLt,n
2c90: 44 4c 74 2c 72 6f 77 69 64 2c 50 29 20 53 51 4c  DLt,rowid,P) SQL
2ca0: 20 66 75 6e 63 74 69 6f 6e 2e 20 20 54 68 65 0a   function.  The.
2cb0: 2a 2a 20 61 72 67 75 6d 65 6e 74 73 20 64 65 73  ** arguments des
2cc0: 63 72 69 62 65 20 61 20 73 69 6e 67 6c 65 20 6b  cribe a single k
2cd0: 65 79 20 69 6e 73 74 61 6e 63 65 2e 20 20 54 68  ey instance.  Th
2ce0: 69 73 20 72 6f 75 74 69 6e 65 20 6d 61 6b 65 73  is routine makes
2cf0: 20 74 68 65 20 0a 2a 2a 20 64 65 63 69 73 69 6f   the .** decisio
2d00: 6e 20 61 62 6f 75 74 20 77 68 65 74 68 65 72 20  n about whether 
2d10: 6f 72 20 6e 6f 74 20 74 6f 20 72 65 74 61 69 6e  or not to retain
2d20: 20 74 68 69 73 20 6b 65 79 20 66 6f 72 20 74 68   this key for th
2d30: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 33 0a 2a  e sqlite_stat3.*
2d40: 2a 20 74 61 62 6c 65 2e 0a 2a 2a 0a 2a 2a 20 54  * table..**.** T
2d50: 68 65 20 72 65 74 75 72 6e 20 76 61 6c 75 65 20  he return value 
2d60: 69 73 20 4e 55 4c 4c 2e 0a 2a 2f 0a 73 74 61 74  is NULL..*/.stat
2d70: 69 63 20 76 6f 69 64 20 73 74 61 74 33 50 75 73  ic void stat3Pus
2d80: 68 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e  h(.  sqlite3_con
2d90: 74 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a 20  text *context,. 
2da0: 20 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71 6c   int argc,.  sql
2db0: 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72 67  ite3_value **arg
2dc0: 76 0a 29 7b 0a 20 20 53 74 61 74 33 41 63 63 75  v.){.  Stat3Accu
2dd0: 6d 20 2a 70 20 3d 20 28 53 74 61 74 33 41 63 63  m *p = (Stat3Acc
2de0: 75 6d 2a 29 73 71 6c 69 74 65 33 5f 76 61 6c 75  um*)sqlite3_valu
2df0: 65 5f 62 6c 6f 62 28 61 72 67 76 5b 34 5d 29 3b  e_blob(argv[4]);
2e00: 0a 20 20 74 52 6f 77 63 6e 74 20 6e 45 71 20 3d  .  tRowcnt nEq =
2e10: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69   sqlite3_value_i
2e20: 6e 74 36 34 28 61 72 67 76 5b 30 5d 29 3b 0a 20  nt64(argv[0]);. 
2e30: 20 74 52 6f 77 63 6e 74 20 6e 4c 74 20 3d 20 73   tRowcnt nLt = s
2e40: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74  qlite3_value_int
2e50: 36 34 28 61 72 67 76 5b 31 5d 29 3b 0a 20 20 74  64(argv[1]);.  t
2e60: 52 6f 77 63 6e 74 20 6e 44 4c 74 20 3d 20 73 71  Rowcnt nDLt = sq
2e70: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36  lite3_value_int6
2e80: 34 28 61 72 67 76 5b 32 5d 29 3b 0a 20 20 69 36  4(argv[2]);.  i6
2e90: 34 20 72 6f 77 69 64 20 3d 20 73 71 6c 69 74 65  4 rowid = sqlite
2ea0: 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28 61 72  3_value_int64(ar
2eb0: 67 76 5b 33 5d 29 3b 0a 20 20 75 38 20 69 73 50  gv[3]);.  u8 isP
2ec0: 53 61 6d 70 6c 65 20 3d 20 30 3b 0a 20 20 75 38  Sample = 0;.  u8
2ed0: 20 64 6f 49 6e 73 65 72 74 20 3d 20 30 3b 0a 20   doInsert = 0;. 
2ee0: 20 69 6e 74 20 69 4d 69 6e 20 3d 20 70 2d 3e 69   int iMin = p->i
2ef0: 4d 69 6e 3b 0a 20 20 73 74 72 75 63 74 20 53 74  Min;.  struct St
2f00: 61 74 33 53 61 6d 70 6c 65 20 2a 70 53 61 6d 70  at3Sample *pSamp
2f10: 6c 65 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 75  le;.  int i;.  u
2f20: 33 32 20 68 3b 0a 0a 20 20 55 4e 55 53 45 44 5f  32 h;..  UNUSED_
2f30: 50 41 52 41 4d 45 54 45 52 28 63 6f 6e 74 65 78  PARAMETER(contex
2f40: 74 29 3b 0a 20 20 55 4e 55 53 45 44 5f 50 41 52  t);.  UNUSED_PAR
2f50: 41 4d 45 54 45 52 28 61 72 67 63 29 3b 0a 20 20  AMETER(argc);.  
2f60: 69 66 28 20 6e 45 71 3d 3d 30 20 29 20 72 65 74  if( nEq==0 ) ret
2f70: 75 72 6e 3b 0a 20 20 68 20 3d 20 70 2d 3e 69 50  urn;.  h = p->iP
2f80: 72 6e 20 3d 20 70 2d 3e 69 50 72 6e 2a 31 31 30  rn = p->iPrn*110
2f90: 33 35 31 35 32 34 35 20 2b 20 31 32 33 34 35 3b  3515245 + 12345;
2fa0: 0a 20 20 69 66 28 20 28 6e 4c 74 2f 70 2d 3e 6e  .  if( (nLt/p->n
2fb0: 50 53 61 6d 70 6c 65 29 21 3d 28 28 6e 45 71 2b  PSample)!=((nEq+
2fc0: 6e 4c 74 29 2f 70 2d 3e 6e 50 53 61 6d 70 6c 65  nLt)/p->nPSample
2fd0: 29 20 29 7b 0a 20 20 20 20 64 6f 49 6e 73 65 72  ) ){.    doInser
2fe0: 74 20 3d 20 69 73 50 53 61 6d 70 6c 65 20 3d 20  t = isPSample = 
2ff0: 31 3b 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 70  1;.  }else if( p
3000: 2d 3e 6e 53 61 6d 70 6c 65 3c 70 2d 3e 6d 78 53  ->nSample<p->mxS
3010: 61 6d 70 6c 65 20 29 7b 0a 20 20 20 20 64 6f 49  ample ){.    doI
3020: 6e 73 65 72 74 20 3d 20 31 3b 0a 20 20 7d 65 6c  nsert = 1;.  }el
3030: 73 65 7b 0a 20 20 20 20 69 66 28 20 6e 45 71 3e  se{.    if( nEq>
3040: 70 2d 3e 61 5b 69 4d 69 6e 5d 2e 6e 45 71 20 7c  p->a[iMin].nEq |
3050: 7c 20 28 6e 45 71 3d 3d 70 2d 3e 61 5b 69 4d 69  | (nEq==p->a[iMi
3060: 6e 5d 2e 6e 45 71 20 26 26 20 68 3e 70 2d 3e 61  n].nEq && h>p->a
3070: 5b 69 4d 69 6e 5d 2e 69 48 61 73 68 29 20 29 7b  [iMin].iHash) ){
3080: 0a 20 20 20 20 20 20 64 6f 49 6e 73 65 72 74 20  .      doInsert 
3090: 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  = 1;.    }.  }. 
30a0: 20 69 66 28 20 21 64 6f 49 6e 73 65 72 74 20 29   if( !doInsert )
30b0: 20 72 65 74 75 72 6e 3b 0a 20 20 69 66 28 20 70   return;.  if( p
30c0: 2d 3e 6e 53 61 6d 70 6c 65 3d 3d 70 2d 3e 6d 78  ->nSample==p->mx
30d0: 53 61 6d 70 6c 65 20 29 7b 0a 20 20 20 20 69 66  Sample ){.    if
30e0: 28 20 69 4d 69 6e 3c 70 2d 3e 6e 53 61 6d 70 6c  ( iMin<p->nSampl
30f0: 65 20 29 7b 0a 20 20 20 20 20 20 6d 65 6d 63 70  e ){.      memcp
3100: 79 28 26 70 2d 3e 61 5b 69 4d 69 6e 5d 2c 20 26  y(&p->a[iMin], &
3110: 70 2d 3e 61 5b 69 4d 69 6e 2b 31 5d 2c 20 73 69  p->a[iMin+1], si
3120: 7a 65 6f 66 28 70 2d 3e 61 5b 30 5d 29 2a 28 70  zeof(p->a[0])*(p
3130: 2d 3e 6e 53 61 6d 70 6c 65 2d 69 4d 69 6e 29 29  ->nSample-iMin))
3140: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70 53 61 6d  ;.    }.    pSam
3150: 70 6c 65 20 3d 20 26 70 2d 3e 61 5b 70 2d 3e 6e  ple = &p->a[p->n
3160: 53 61 6d 70 6c 65 2d 31 5d 3b 0a 20 20 7d 65 6c  Sample-1];.  }el
3170: 73 65 7b 0a 20 20 20 20 70 53 61 6d 70 6c 65 20  se{.    pSample 
3180: 3d 20 26 70 2d 3e 61 5b 70 2d 3e 6e 53 61 6d 70  = &p->a[p->nSamp
3190: 6c 65 2b 2b 5d 3b 0a 20 20 7d 0a 20 20 70 53 61  le++];.  }.  pSa
31a0: 6d 70 6c 65 2d 3e 69 52 6f 77 69 64 20 3d 20 72  mple->iRowid = r
31b0: 6f 77 69 64 3b 0a 20 20 70 53 61 6d 70 6c 65 2d  owid;.  pSample-
31c0: 3e 6e 45 71 20 3d 20 6e 45 71 3b 0a 20 20 70 53  >nEq = nEq;.  pS
31d0: 61 6d 70 6c 65 2d 3e 6e 4c 74 20 3d 20 6e 4c 74  ample->nLt = nLt
31e0: 3b 0a 20 20 70 53 61 6d 70 6c 65 2d 3e 6e 44 4c  ;.  pSample->nDL
31f0: 74 20 3d 20 6e 44 4c 74 3b 0a 20 20 70 53 61 6d  t = nDLt;.  pSam
3200: 70 6c 65 2d 3e 69 48 61 73 68 20 3d 20 68 3b 0a  ple->iHash = h;.
3210: 20 20 70 53 61 6d 70 6c 65 2d 3e 69 73 50 53 61    pSample->isPSa
3220: 6d 70 6c 65 20 3d 20 69 73 50 53 61 6d 70 6c 65  mple = isPSample
3230: 3b 0a 0a 20 20 2f 2a 20 46 69 6e 64 20 74 68 65  ;..  /* Find the
3240: 20 6e 65 77 20 6d 69 6e 69 6d 75 6d 20 2a 2f 0a   new minimum */.
3250: 20 20 69 66 28 20 70 2d 3e 6e 53 61 6d 70 6c 65    if( p->nSample
3260: 3d 3d 70 2d 3e 6d 78 53 61 6d 70 6c 65 20 29 7b  ==p->mxSample ){
3270: 0a 20 20 20 20 70 53 61 6d 70 6c 65 20 3d 20 70  .    pSample = p
3280: 2d 3e 61 3b 0a 20 20 20 20 69 20 3d 20 30 3b 0a  ->a;.    i = 0;.
3290: 20 20 20 20 77 68 69 6c 65 28 20 70 53 61 6d 70      while( pSamp
32a0: 6c 65 2d 3e 69 73 50 53 61 6d 70 6c 65 20 29 7b  le->isPSample ){
32b0: 0a 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20  .      i++;.    
32c0: 20 20 70 53 61 6d 70 6c 65 2b 2b 3b 0a 20 20 20    pSample++;.   
32d0: 20 20 20 61 73 73 65 72 74 28 20 69 3c 70 2d 3e     assert( i<p->
32e0: 6e 53 61 6d 70 6c 65 20 29 3b 0a 20 20 20 20 7d  nSample );.    }
32f0: 0a 20 20 20 20 6e 45 71 20 3d 20 70 53 61 6d 70  .    nEq = pSamp
3300: 6c 65 2d 3e 6e 45 71 3b 0a 20 20 20 20 68 20 3d  le->nEq;.    h =
3310: 20 70 53 61 6d 70 6c 65 2d 3e 69 48 61 73 68 3b   pSample->iHash;
3320: 0a 20 20 20 20 69 4d 69 6e 20 3d 20 69 3b 0a 20  .    iMin = i;. 
3330: 20 20 20 66 6f 72 28 69 2b 2b 2c 20 70 53 61 6d     for(i++, pSam
3340: 70 6c 65 2b 2b 3b 20 69 3c 70 2d 3e 6e 53 61 6d  ple++; i<p->nSam
3350: 70 6c 65 3b 20 69 2b 2b 2c 20 70 53 61 6d 70 6c  ple; i++, pSampl
3360: 65 2b 2b 29 7b 0a 20 20 20 20 20 20 69 66 28 20  e++){.      if( 
3370: 70 53 61 6d 70 6c 65 2d 3e 69 73 50 53 61 6d 70  pSample->isPSamp
3380: 6c 65 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20  le ) continue;. 
3390: 20 20 20 20 20 69 66 28 20 70 53 61 6d 70 6c 65       if( pSample
33a0: 2d 3e 6e 45 71 3c 6e 45 71 0a 20 20 20 20 20 20  ->nEq<nEq.      
33b0: 20 7c 7c 20 28 70 53 61 6d 70 6c 65 2d 3e 6e 45   || (pSample->nE
33c0: 71 3d 3d 6e 45 71 20 26 26 20 70 53 61 6d 70 6c  q==nEq && pSampl
33d0: 65 2d 3e 69 48 61 73 68 3c 68 29 0a 20 20 20 20  e->iHash<h).    
33e0: 20 20 29 7b 0a 20 20 20 20 20 20 20 20 69 4d 69    ){.        iMi
33f0: 6e 20 3d 20 69 3b 0a 20 20 20 20 20 20 20 20 6e  n = i;.        n
3400: 45 71 20 3d 20 70 53 61 6d 70 6c 65 2d 3e 6e 45  Eq = pSample->nE
3410: 71 3b 0a 20 20 20 20 20 20 20 20 68 20 3d 20 70  q;.        h = p
3420: 53 61 6d 70 6c 65 2d 3e 69 48 61 73 68 3b 0a 20  Sample->iHash;. 
3430: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20       }.    }.   
3440: 20 70 2d 3e 69 4d 69 6e 20 3d 20 69 4d 69 6e 3b   p->iMin = iMin;
3450: 0a 20 20 7d 0a 7d 0a 73 74 61 74 69 63 20 63 6f  .  }.}.static co
3460: 6e 73 74 20 46 75 6e 63 44 65 66 20 73 74 61 74  nst FuncDef stat
3470: 33 50 75 73 68 46 75 6e 63 64 65 66 20 3d 20 7b  3PushFuncdef = {
3480: 0a 20 20 35 2c 20 20 20 20 20 20 20 20 20 20 20  .  5,           
3490: 20 20 20 20 20 2f 2a 20 6e 41 72 67 20 2a 2f 0a       /* nArg */.
34a0: 20 20 53 51 4c 49 54 45 5f 55 54 46 38 2c 20 20    SQLITE_UTF8,  
34b0: 20 20 20 20 2f 2a 20 69 50 72 65 66 45 6e 63 20      /* iPrefEnc 
34c0: 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20  */.  0,         
34d0: 20 20 20 20 20 20 20 2f 2a 20 66 6c 61 67 73 20         /* flags 
34e0: 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20  */.  0,         
34f0: 20 20 20 20 20 20 20 2f 2a 20 70 55 73 65 72 44         /* pUserD
3500: 61 74 61 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20  ata */.  0,     
3510: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 70 4e             /* pN
3520: 65 78 74 20 2a 2f 0a 20 20 73 74 61 74 33 50 75  ext */.  stat3Pu
3530: 73 68 2c 20 20 20 20 20 20 20 20 2f 2a 20 78 46  sh,        /* xF
3540: 75 6e 63 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20  unc */.  0,     
3550: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 53             /* xS
3560: 74 65 70 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20  tep */.  0,     
3570: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 46             /* xF
3580: 69 6e 61 6c 69 7a 65 20 2a 2f 0a 20 20 22 73 74  inalize */.  "st
3590: 61 74 33 5f 70 75 73 68 22 2c 20 20 20 20 20 2f  at3_push",     /
35a0: 2a 20 7a 4e 61 6d 65 20 2a 2f 0a 20 20 30 2c 20  * zName */.  0, 
35b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
35c0: 2a 20 70 48 61 73 68 20 2a 2f 0a 20 20 30 20 20  * pHash */.  0  
35d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
35e0: 2a 20 70 44 65 73 74 72 75 63 74 6f 72 20 2a 2f  * pDestructor */
35f0: 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 49 6d 70 6c 65  .};../*.** Imple
3600: 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 20 74 68 65  mentation of the
3610: 20 73 74 61 74 33 5f 67 65 74 28 50 2c 4e 2c 2e   stat3_get(P,N,.
3620: 2e 2e 29 20 53 51 4c 20 66 75 6e 63 74 69 6f 6e  ..) SQL function
3630: 2e 20 20 54 68 69 73 20 72 6f 75 74 69 6e 65 20  .  This routine 
3640: 69 73 0a 2a 2a 20 75 73 65 64 20 74 6f 20 71 75  is.** used to qu
3650: 65 72 79 20 74 68 65 20 72 65 73 75 6c 74 73 2e  ery the results.
3660: 20 20 43 6f 6e 74 65 6e 74 20 69 73 20 72 65 74    Content is ret
3670: 75 72 6e 65 64 20 66 6f 72 20 74 68 65 20 4e 74  urned for the Nt
3680: 68 20 73 71 6c 69 74 65 5f 73 74 61 74 33 0a 2a  h sqlite_stat3.*
3690: 2a 20 72 6f 77 20 77 68 65 72 65 20 4e 20 69 73  * row where N is
36a0: 20 62 65 74 77 65 65 6e 20 30 20 61 6e 64 20 53   between 0 and S
36b0: 2d 31 20 61 6e 64 20 53 20 69 73 20 74 68 65 20  -1 and S is the 
36c0: 6e 75 6d 62 65 72 20 6f 66 20 73 61 6d 70 6c 65  number of sample
36d0: 73 2e 20 20 54 68 65 0a 2a 2a 20 76 61 6c 75 65  s.  The.** value
36e0: 20 72 65 74 75 72 6e 65 64 20 64 65 70 65 6e 64   returned depend
36f0: 73 20 6f 6e 20 74 68 65 20 6e 75 6d 62 65 72 20  s on the number 
3700: 6f 66 20 61 72 67 75 6d 65 6e 74 73 2e 0a 2a 2a  of arguments..**
3710: 0a 2a 2a 20 20 20 61 72 67 63 3d 3d 32 20 20 20  .**   argc==2   
3720: 20 72 65 73 75 6c 74 3a 20 20 72 6f 77 69 64 0a   result:  rowid.
3730: 2a 2a 20 20 20 61 72 67 63 3d 3d 33 20 20 20 20  **   argc==3    
3740: 72 65 73 75 6c 74 3a 20 20 6e 45 71 0a 2a 2a 20  result:  nEq.** 
3750: 20 20 61 72 67 63 3d 3d 34 20 20 20 20 72 65 73    argc==4    res
3760: 75 6c 74 3a 20 20 6e 4c 74 0a 2a 2a 20 20 20 61  ult:  nLt.**   a
3770: 72 67 63 3d 3d 35 20 20 20 20 72 65 73 75 6c 74  rgc==5    result
3780: 3a 20 20 6e 44 4c 74 0a 2a 2f 0a 73 74 61 74 69  :  nDLt.*/.stati
3790: 63 20 76 6f 69 64 20 73 74 61 74 33 47 65 74 28  c void stat3Get(
37a0: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65  .  sqlite3_conte
37b0: 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a 20 20 69  xt *context,.  i
37c0: 6e 74 20 61 72 67 63 2c 0a 20 20 73 71 6c 69 74  nt argc,.  sqlit
37d0: 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72 67 76 0a  e3_value **argv.
37e0: 29 7b 0a 20 20 69 6e 74 20 6e 20 3d 20 73 71 6c  ){.  int n = sql
37f0: 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 28 61  ite3_value_int(a
3800: 72 67 76 5b 31 5d 29 3b 0a 20 20 53 74 61 74 33  rgv[1]);.  Stat3
3810: 41 63 63 75 6d 20 2a 70 20 3d 20 28 53 74 61 74  Accum *p = (Stat
3820: 33 41 63 63 75 6d 2a 29 73 71 6c 69 74 65 33 5f  3Accum*)sqlite3_
3830: 76 61 6c 75 65 5f 62 6c 6f 62 28 61 72 67 76 5b  value_blob(argv[
3840: 30 5d 29 3b 0a 0a 20 20 61 73 73 65 72 74 28 20  0]);..  assert( 
3850: 70 21 3d 30 20 29 3b 0a 20 20 69 66 28 20 70 2d  p!=0 );.  if( p-
3860: 3e 6e 53 61 6d 70 6c 65 3c 3d 6e 20 29 20 72 65  >nSample<=n ) re
3870: 74 75 72 6e 3b 0a 20 20 73 77 69 74 63 68 28 20  turn;.  switch( 
3880: 61 72 67 63 20 29 7b 0a 20 20 20 20 63 61 73 65  argc ){.    case
3890: 20 32 3a 20 73 71 6c 69 74 65 33 5f 72 65 73 75   2: sqlite3_resu
38a0: 6c 74 5f 69 6e 74 36 34 28 63 6f 6e 74 65 78 74  lt_int64(context
38b0: 2c 20 70 2d 3e 61 5b 6e 5d 2e 69 52 6f 77 69 64  , p->a[n].iRowid
38c0: 29 3b 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61  ); break;.    ca
38d0: 73 65 20 33 3a 20 73 71 6c 69 74 65 33 5f 72 65  se 3: sqlite3_re
38e0: 73 75 6c 74 5f 69 6e 74 36 34 28 63 6f 6e 74 65  sult_int64(conte
38f0: 78 74 2c 20 70 2d 3e 61 5b 6e 5d 2e 6e 45 71 29  xt, p->a[n].nEq)
3900: 3b 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20  ;    break;.    
3910: 63 61 73 65 20 34 3a 20 73 71 6c 69 74 65 33 5f  case 4: sqlite3_
3920: 72 65 73 75 6c 74 5f 69 6e 74 36 34 28 63 6f 6e  result_int64(con
3930: 74 65 78 74 2c 20 70 2d 3e 61 5b 6e 5d 2e 6e 4c  text, p->a[n].nL
3940: 74 29 3b 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  t);    break;.  
3950: 20 20 63 61 73 65 20 35 3a 20 73 71 6c 69 74 65    case 5: sqlite
3960: 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 28 63  3_result_int64(c
3970: 6f 6e 74 65 78 74 2c 20 70 2d 3e 61 5b 6e 5d 2e  ontext, p->a[n].
3980: 6e 44 4c 74 29 3b 20 20 20 62 72 65 61 6b 3b 0a  nDLt);   break;.
3990: 20 20 7d 0a 7d 0a 73 74 61 74 69 63 20 63 6f 6e    }.}.static con
39a0: 73 74 20 46 75 6e 63 44 65 66 20 73 74 61 74 33  st FuncDef stat3
39b0: 47 65 74 46 75 6e 63 64 65 66 20 3d 20 7b 0a 20  GetFuncdef = {. 
39c0: 20 2d 31 2c 20 20 20 20 20 20 20 20 20 20 20 20   -1,            
39d0: 20 20 20 2f 2a 20 6e 41 72 67 20 2a 2f 0a 20 20     /* nArg */.  
39e0: 53 51 4c 49 54 45 5f 55 54 46 38 2c 20 20 20 20  SQLITE_UTF8,    
39f0: 20 20 2f 2a 20 69 50 72 65 66 45 6e 63 20 2a 2f    /* iPrefEnc */
3a00: 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20  .  0,           
3a10: 20 20 20 20 20 2f 2a 20 66 6c 61 67 73 20 2a 2f       /* flags */
3a20: 0a 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20  .  0,           
3a30: 20 20 20 20 20 2f 2a 20 70 55 73 65 72 44 61 74       /* pUserDat
3a40: 61 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20  a */.  0,       
3a50: 20 20 20 20 20 20 20 20 20 2f 2a 20 70 4e 65 78           /* pNex
3a60: 74 20 2a 2f 0a 20 20 73 74 61 74 33 47 65 74 2c  t */.  stat3Get,
3a70: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 46 75 6e           /* xFun
3a80: 63 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20  c */.  0,       
3a90: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 53 74 65           /* xSte
3aa0: 70 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20  p */.  0,       
3ab0: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 46 69 6e           /* xFin
3ac0: 61 6c 69 7a 65 20 2a 2f 0a 20 20 22 73 74 61 74  alize */.  "stat
3ad0: 33 5f 67 65 74 22 2c 20 20 20 20 20 2f 2a 20 7a  3_get",     /* z
3ae0: 4e 61 6d 65 20 2a 2f 0a 20 20 30 2c 20 20 20 20  Name */.  0,    
3af0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 70              /* p
3b00: 48 61 73 68 20 2a 2f 0a 20 20 30 20 20 20 20 20  Hash */.  0     
3b10: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 70              /* p
3b20: 44 65 73 74 72 75 63 74 6f 72 20 2a 2f 0a 7d 3b  Destructor */.};
3b30: 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54  .#endif /* SQLIT
3b40: 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 20 2a  E_ENABLE_STAT3 *
3b50: 2f 0a 0a 0a 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65  /...../*.** Gene
3b60: 72 61 74 65 20 63 6f 64 65 20 74 6f 20 64 6f 20  rate code to do 
3b70: 61 6e 20 61 6e 61 6c 79 73 69 73 20 6f 66 20 61  an analysis of a
3b80: 6c 6c 20 69 6e 64 69 63 65 73 20 61 73 73 6f 63  ll indices assoc
3b90: 69 61 74 65 64 20 77 69 74 68 0a 2a 2a 20 61 20  iated with.** a 
3ba0: 73 69 6e 67 6c 65 20 74 61 62 6c 65 2e 0a 2a 2f  single table..*/
3bb0: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 61 6e 61  .static void ana
3bc0: 6c 79 7a 65 4f 6e 65 54 61 62 6c 65 28 0a 20 20  lyzeOneTable(.  
3bd0: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 20  Parse *pParse,  
3be0: 20 2f 2a 20 50 61 72 73 65 72 20 63 6f 6e 74 65   /* Parser conte
3bf0: 78 74 20 2a 2f 0a 20 20 54 61 62 6c 65 20 2a 70  xt */.  Table *p
3c00: 54 61 62 2c 20 20 20 20 20 2f 2a 20 54 61 62 6c  Tab,     /* Tabl
3c10: 65 20 77 68 6f 73 65 20 69 6e 64 69 63 65 73 20  e whose indices 
3c20: 61 72 65 20 74 6f 20 62 65 20 61 6e 61 6c 79 7a  are to be analyz
3c30: 65 64 20 2a 2f 0a 20 20 49 6e 64 65 78 20 2a 70  ed */.  Index *p
3c40: 4f 6e 6c 79 49 64 78 2c 20 2f 2a 20 49 66 20 6e  OnlyIdx, /* If n
3c50: 6f 74 20 4e 55 4c 4c 2c 20 6f 6e 6c 79 20 61 6e  ot NULL, only an
3c60: 61 6c 79 7a 65 20 74 68 69 73 20 6f 6e 65 20 69  alyze this one i
3c70: 6e 64 65 78 20 2a 2f 0a 20 20 69 6e 74 20 69 53  ndex */.  int iS
3c80: 74 61 74 43 75 72 2c 20 20 20 20 2f 2a 20 49 6e  tatCur,    /* In
3c90: 64 65 78 20 6f 66 20 56 64 62 65 43 75 72 73 6f  dex of VdbeCurso
3ca0: 72 20 74 68 61 74 20 77 72 69 74 65 73 20 74 68  r that writes th
3cb0: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 31 20 74  e sqlite_stat1 t
3cc0: 61 62 6c 65 20 2a 2f 0a 20 20 69 6e 74 20 69 4d  able */.  int iM
3cd0: 65 6d 20 20 20 20 20 20 20 20 20 2f 2a 20 41 76  em         /* Av
3ce0: 61 69 6c 61 62 6c 65 20 6d 65 6d 6f 72 79 20 6c  ailable memory l
3cf0: 6f 63 61 74 69 6f 6e 73 20 62 65 67 69 6e 20 68  ocations begin h
3d00: 65 72 65 20 2a 2f 0a 29 7b 0a 20 20 73 71 6c 69  ere */.){.  sqli
3d10: 74 65 33 20 2a 64 62 20 3d 20 70 50 61 72 73 65  te3 *db = pParse
3d20: 2d 3e 64 62 3b 20 20 20 20 2f 2a 20 44 61 74 61  ->db;    /* Data
3d30: 62 61 73 65 20 68 61 6e 64 6c 65 20 2a 2f 0a 20  base handle */. 
3d40: 20 49 6e 64 65 78 20 2a 70 49 64 78 3b 20 20 20   Index *pIdx;   
3d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
3d60: 20 41 6e 20 69 6e 64 65 78 20 74 6f 20 62 65 69   An index to bei
3d70: 6e 67 20 61 6e 61 6c 79 7a 65 64 20 2a 2f 0a 20  ng analyzed */. 
3d80: 20 69 6e 74 20 69 49 64 78 43 75 72 3b 20 20 20   int iIdxCur;   
3d90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
3da0: 20 43 75 72 73 6f 72 20 6f 70 65 6e 20 6f 6e 20   Cursor open on 
3db0: 69 6e 64 65 78 20 62 65 69 6e 67 20 61 6e 61 6c  index being anal
3dc0: 79 7a 65 64 20 2a 2f 0a 20 20 56 64 62 65 20 2a  yzed */.  Vdbe *
3dd0: 76 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  v;              
3de0: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 76 69         /* The vi
3df0: 72 74 75 61 6c 20 6d 61 63 68 69 6e 65 20 62 65  rtual machine be
3e00: 69 6e 67 20 62 75 69 6c 74 20 75 70 20 2a 2f 0a  ing built up */.
3e10: 20 20 69 6e 74 20 69 3b 20 20 20 20 20 20 20 20    int i;        
3e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3e30: 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74 65 72 20 2a  * Loop counter *
3e40: 2f 0a 20 20 69 6e 74 20 74 6f 70 4f 66 4c 6f 6f  /.  int topOfLoo
3e50: 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  p;              
3e60: 20 2f 2a 20 54 68 65 20 74 6f 70 20 6f 66 20 74   /* The top of t
3e70: 68 65 20 6c 6f 6f 70 20 2a 2f 0a 20 20 69 6e 74  he loop */.  int
3e80: 20 65 6e 64 4f 66 4c 6f 6f 70 3b 20 20 20 20 20   endOfLoop;     
3e90: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65            /* The
3ea0: 20 65 6e 64 20 6f 66 20 74 68 65 20 6c 6f 6f 70   end of the loop
3eb0: 20 2a 2f 0a 20 20 69 6e 74 20 6a 5a 65 72 6f 52   */.  int jZeroR
3ec0: 6f 77 73 20 3d 20 2d 31 3b 20 20 20 20 20 20 20  ows = -1;       
3ed0: 20 20 20 2f 2a 20 4a 75 6d 70 20 66 72 6f 6d 20     /* Jump from 
3ee0: 68 65 72 65 20 69 66 20 6e 75 6d 62 65 72 20 6f  here if number o
3ef0: 66 20 72 6f 77 73 20 69 73 20 7a 65 72 6f 20 2a  f rows is zero *
3f00: 2f 0a 20 20 69 6e 74 20 69 44 62 3b 20 20 20 20  /.  int iDb;    
3f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3f20: 20 2f 2a 20 49 6e 64 65 78 20 6f 66 20 64 61 74   /* Index of dat
3f30: 61 62 61 73 65 20 63 6f 6e 74 61 69 6e 69 6e 67  abase containing
3f40: 20 70 54 61 62 20 2a 2f 0a 20 20 69 6e 74 20 72   pTab */.  int r
3f50: 65 67 54 61 62 6e 61 6d 65 20 3d 20 69 4d 65 6d  egTabname = iMem
3f60: 2b 2b 3b 20 20 20 20 20 2f 2a 20 52 65 67 69 73  ++;     /* Regis
3f70: 74 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74  ter containing t
3f80: 61 62 6c 65 20 6e 61 6d 65 20 2a 2f 0a 20 20 69  able name */.  i
3f90: 6e 74 20 72 65 67 49 64 78 6e 61 6d 65 20 3d 20  nt regIdxname = 
3fa0: 69 4d 65 6d 2b 2b 3b 20 20 20 20 20 2f 2a 20 52  iMem++;     /* R
3fb0: 65 67 69 73 74 65 72 20 63 6f 6e 74 61 69 6e 69  egister containi
3fc0: 6e 67 20 69 6e 64 65 78 20 6e 61 6d 65 20 2a 2f  ng index name */
3fd0: 0a 20 20 69 6e 74 20 72 65 67 53 74 61 74 31 20  .  int regStat1 
3fe0: 3d 20 69 4d 65 6d 2b 2b 3b 20 20 20 20 20 20 20  = iMem++;       
3ff0: 2f 2a 20 54 68 65 20 73 74 61 74 20 63 6f 6c 75  /* The stat colu
4000: 6d 6e 20 6f 66 20 73 71 6c 69 74 65 5f 73 74 61  mn of sqlite_sta
4010: 74 31 20 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c  t1 */.#ifdef SQL
4020: 49 54 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33  ITE_ENABLE_STAT3
4030: 0a 20 20 69 6e 74 20 72 65 67 4e 75 6d 45 71 20  .  int regNumEq 
4040: 3d 20 72 65 67 53 74 61 74 31 3b 20 20 20 20 20  = regStat1;     
4050: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 69 6e 73  /* Number of ins
4060: 74 61 6e 63 65 73 2e 20 20 53 61 6d 65 20 61 73  tances.  Same as
4070: 20 72 65 67 53 74 61 74 31 20 2a 2f 0a 20 20 69   regStat1 */.  i
4080: 6e 74 20 72 65 67 4e 75 6d 4c 74 20 3d 20 69 4d  nt regNumLt = iM
4090: 65 6d 2b 2b 3b 20 20 20 20 20 20 20 2f 2a 20 4e  em++;       /* N
40a0: 75 6d 62 65 72 20 6f 66 20 6b 65 79 73 20 6c 65  umber of keys le
40b0: 73 73 20 74 68 61 6e 20 72 65 67 53 61 6d 70 6c  ss than regSampl
40c0: 65 20 2a 2f 0a 20 20 69 6e 74 20 72 65 67 4e 75  e */.  int regNu
40d0: 6d 44 4c 74 20 3d 20 69 4d 65 6d 2b 2b 3b 20 20  mDLt = iMem++;  
40e0: 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66      /* Number of
40f0: 20 64 69 73 74 69 6e 63 74 20 6b 65 79 73 20 6c   distinct keys l
4100: 65 73 73 20 74 68 61 6e 20 72 65 67 53 61 6d 70  ess than regSamp
4110: 6c 65 20 2a 2f 0a 20 20 69 6e 74 20 72 65 67 53  le */.  int regS
4120: 61 6d 70 6c 65 20 3d 20 69 4d 65 6d 2b 2b 3b 20  ample = iMem++; 
4130: 20 20 20 20 20 2f 2a 20 54 68 65 20 6e 65 78 74       /* The next
4140: 20 73 61 6d 70 6c 65 20 76 61 6c 75 65 20 2a 2f   sample value */
4150: 0a 20 20 69 6e 74 20 72 65 67 52 6f 77 69 64 20  .  int regRowid 
4160: 3d 20 72 65 67 53 61 6d 70 6c 65 3b 20 20 20 20  = regSample;    
4170: 2f 2a 20 52 6f 77 69 64 20 6f 66 20 61 20 73 61  /* Rowid of a sa
4180: 6d 70 6c 65 20 2a 2f 0a 20 20 69 6e 74 20 72 65  mple */.  int re
4190: 67 41 63 63 75 6d 20 3d 20 69 4d 65 6d 2b 2b 3b  gAccum = iMem++;
41a0: 20 20 20 20 20 20 20 2f 2a 20 52 65 67 69 73 74         /* Regist
41b0: 65 72 20 74 6f 20 68 6f 6c 64 20 53 74 61 74 33  er to hold Stat3
41c0: 41 63 63 75 6d 20 6f 62 6a 65 63 74 20 2a 2f 0a  Accum object */.
41d0: 20 20 69 6e 74 20 72 65 67 4c 6f 6f 70 20 3d 20    int regLoop = 
41e0: 69 4d 65 6d 2b 2b 3b 20 20 20 20 20 20 20 20 2f  iMem++;        /
41f0: 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74 65 72 20 2a  * Loop counter *
4200: 2f 0a 20 20 69 6e 74 20 72 65 67 43 6f 75 6e 74  /.  int regCount
4210: 20 3d 20 69 4d 65 6d 2b 2b 3b 20 20 20 20 20 20   = iMem++;      
4220: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 72 6f   /* Number of ro
4230: 77 73 20 69 6e 20 74 68 65 20 74 61 62 6c 65 20  ws in the table 
4240: 6f 72 20 69 6e 64 65 78 20 2a 2f 0a 20 20 69 6e  or index */.  in
4250: 74 20 72 65 67 54 65 6d 70 31 20 3d 20 69 4d 65  t regTemp1 = iMe
4260: 6d 2b 2b 3b 20 20 20 20 20 20 20 2f 2a 20 49 6e  m++;       /* In
4270: 74 65 72 6d 65 64 69 61 74 65 20 72 65 67 69 73  termediate regis
4280: 74 65 72 20 2a 2f 0a 20 20 69 6e 74 20 72 65 67  ter */.  int reg
4290: 54 65 6d 70 32 20 3d 20 69 4d 65 6d 2b 2b 3b 20  Temp2 = iMem++; 
42a0: 20 20 20 20 20 20 2f 2a 20 49 6e 74 65 72 6d 65        /* Interme
42b0: 64 69 61 74 65 20 72 65 67 69 73 74 65 72 20 2a  diate register *
42c0: 2f 0a 20 20 69 6e 74 20 6f 6e 63 65 20 3d 20 31  /.  int once = 1
42d0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
42e0: 20 2f 2a 20 4f 6e 65 2d 74 69 6d 65 20 69 6e 69   /* One-time ini
42f0: 74 69 61 6c 69 7a 61 74 69 6f 6e 20 2a 2f 0a 20  tialization */. 
4300: 20 69 6e 74 20 73 68 6f 72 74 4a 75 6d 70 20 3d   int shortJump =
4310: 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a   0;           /*
4320: 20 49 6e 73 74 72 75 63 74 69 6f 6e 20 61 64 64   Instruction add
4330: 72 65 73 73 20 2a 2f 0a 20 20 69 6e 74 20 69 54  ress */.  int iT
4340: 61 62 43 75 72 20 3d 20 70 50 61 72 73 65 2d 3e  abCur = pParse->
4350: 6e 54 61 62 2b 2b 3b 20 2f 2a 20 54 61 62 6c 65  nTab++; /* Table
4360: 20 63 75 72 73 6f 72 20 2a 2f 0a 23 65 6e 64 69   cursor */.#endi
4370: 66 0a 20 20 69 6e 74 20 72 65 67 43 6f 6c 20 3d  f.  int regCol =
4380: 20 69 4d 65 6d 2b 2b 3b 20 20 20 20 20 20 20 20   iMem++;        
4390: 20 2f 2a 20 43 6f 6e 74 65 6e 74 20 6f 66 20 61   /* Content of a
43a0: 20 63 6f 6c 75 6d 6e 20 69 6e 20 61 6e 61 6c 79   column in analy
43b0: 7a 65 64 20 74 61 62 6c 65 20 2a 2f 0a 20 20 69  zed table */.  i
43c0: 6e 74 20 72 65 67 52 65 63 20 3d 20 69 4d 65 6d  nt regRec = iMem
43d0: 2b 2b 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 52  ++;         /* R
43e0: 65 67 69 73 74 65 72 20 68 6f 6c 64 69 6e 67 20  egister holding 
43f0: 63 6f 6d 70 6c 65 74 65 64 20 72 65 63 6f 72 64  completed record
4400: 20 2a 2f 0a 20 20 69 6e 74 20 72 65 67 54 65 6d   */.  int regTem
4410: 70 20 3d 20 69 4d 65 6d 2b 2b 3b 20 20 20 20 20  p = iMem++;     
4420: 20 20 20 2f 2a 20 54 65 6d 70 6f 72 61 72 79 20     /* Temporary 
4430: 75 73 65 20 72 65 67 69 73 74 65 72 20 2a 2f 0a  use register */.
4440: 20 20 69 6e 74 20 72 65 67 4e 65 77 52 6f 77 69    int regNewRowi
4450: 64 20 3d 20 69 4d 65 6d 2b 2b 3b 20 20 20 20 2f  d = iMem++;    /
4460: 2a 20 52 6f 77 69 64 20 66 6f 72 20 74 68 65 20  * Rowid for the 
4470: 69 6e 73 65 72 74 65 64 20 72 65 63 6f 72 64 20  inserted record 
4480: 2a 2f 0a 0a 0a 20 20 76 20 3d 20 73 71 6c 69 74  */...  v = sqlit
4490: 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73 65  e3GetVdbe(pParse
44a0: 29 3b 0a 20 20 69 66 28 20 76 3d 3d 30 20 7c 7c  );.  if( v==0 ||
44b0: 20 4e 45 56 45 52 28 70 54 61 62 3d 3d 30 29 20   NEVER(pTab==0) 
44c0: 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 3b 0a 20  ){.    return;. 
44d0: 20 7d 0a 20 20 69 66 28 20 70 54 61 62 2d 3e 74   }.  if( pTab->t
44e0: 6e 75 6d 3d 3d 30 20 29 7b 0a 20 20 20 20 2f 2a  num==0 ){.    /*
44f0: 20 44 6f 20 6e 6f 74 20 67 61 74 68 65 72 20 73   Do not gather s
4500: 74 61 74 69 73 74 69 63 73 20 6f 6e 20 76 69 65  tatistics on vie
4510: 77 73 20 6f 72 20 76 69 72 74 75 61 6c 20 74 61  ws or virtual ta
4520: 62 6c 65 73 20 2a 2f 0a 20 20 20 20 72 65 74 75  bles */.    retu
4530: 72 6e 3b 0a 20 20 7d 0a 20 20 69 66 28 20 6d 65  rn;.  }.  if( me
4540: 6d 63 6d 70 28 70 54 61 62 2d 3e 7a 4e 61 6d 65  mcmp(pTab->zName
4550: 2c 20 22 73 71 6c 69 74 65 5f 22 2c 20 37 29 3d  , "sqlite_", 7)=
4560: 3d 30 20 29 7b 0a 20 20 20 20 2f 2a 20 44 6f 20  =0 ){.    /* Do 
4570: 6e 6f 74 20 67 61 74 68 65 72 20 73 74 61 74 69  not gather stati
4580: 73 74 69 63 73 20 6f 6e 20 73 79 73 74 65 6d 20  stics on system 
4590: 74 61 62 6c 65 73 20 2a 2f 0a 20 20 20 20 72 65  tables */.    re
45a0: 74 75 72 6e 3b 0a 20 20 7d 0a 20 20 61 73 73 65  turn;.  }.  asse
45b0: 72 74 28 20 73 71 6c 69 74 65 33 42 74 72 65 65  rt( sqlite3Btree
45c0: 48 6f 6c 64 73 41 6c 6c 4d 75 74 65 78 65 73 28  HoldsAllMutexes(
45d0: 64 62 29 20 29 3b 0a 20 20 69 44 62 20 3d 20 73  db) );.  iDb = s
45e0: 71 6c 69 74 65 33 53 63 68 65 6d 61 54 6f 49 6e  qlite3SchemaToIn
45f0: 64 65 78 28 64 62 2c 20 70 54 61 62 2d 3e 70 53  dex(db, pTab->pS
4600: 63 68 65 6d 61 29 3b 0a 20 20 61 73 73 65 72 74  chema);.  assert
4610: 28 20 69 44 62 3e 3d 30 20 29 3b 0a 20 20 61 73  ( iDb>=0 );.  as
4620: 73 65 72 74 28 20 73 71 6c 69 74 65 33 53 63 68  sert( sqlite3Sch
4630: 65 6d 61 4d 75 74 65 78 48 65 6c 64 28 64 62 2c  emaMutexHeld(db,
4640: 20 69 44 62 2c 20 30 29 20 29 3b 0a 23 69 66 6e   iDb, 0) );.#ifn
4650: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
4660: 41 55 54 48 4f 52 49 5a 41 54 49 4f 4e 0a 20 20  AUTHORIZATION.  
4670: 69 66 28 20 73 71 6c 69 74 65 33 41 75 74 68 43  if( sqlite3AuthC
4680: 68 65 63 6b 28 70 50 61 72 73 65 2c 20 53 51 4c  heck(pParse, SQL
4690: 49 54 45 5f 41 4e 41 4c 59 5a 45 2c 20 70 54 61  ITE_ANALYZE, pTa
46a0: 62 2d 3e 7a 4e 61 6d 65 2c 20 30 2c 0a 20 20 20  b->zName, 0,.   
46b0: 20 20 20 64 62 2d 3e 61 44 62 5b 69 44 62 5d 2e     db->aDb[iDb].
46c0: 7a 4e 61 6d 65 20 29 20 29 7b 0a 20 20 20 20 72  zName ) ){.    r
46d0: 65 74 75 72 6e 3b 0a 20 20 7d 0a 23 65 6e 64 69  eturn;.  }.#endi
46e0: 66 0a 0a 20 20 2f 2a 20 45 73 74 61 62 6c 69 73  f..  /* Establis
46f0: 68 20 61 20 72 65 61 64 2d 6c 6f 63 6b 20 6f 6e  h a read-lock on
4700: 20 74 68 65 20 74 61 62 6c 65 20 61 74 20 74 68   the table at th
4710: 65 20 73 68 61 72 65 64 2d 63 61 63 68 65 20 6c  e shared-cache l
4720: 65 76 65 6c 2e 20 2a 2f 0a 20 20 73 71 6c 69 74  evel. */.  sqlit
4730: 65 33 54 61 62 6c 65 4c 6f 63 6b 28 70 50 61 72  e3TableLock(pPar
4740: 73 65 2c 20 69 44 62 2c 20 70 54 61 62 2d 3e 74  se, iDb, pTab->t
4750: 6e 75 6d 2c 20 30 2c 20 70 54 61 62 2d 3e 7a 4e  num, 0, pTab->zN
4760: 61 6d 65 29 3b 0a 0a 20 20 69 49 64 78 43 75 72  ame);..  iIdxCur
4770: 20 3d 20 70 50 61 72 73 65 2d 3e 6e 54 61 62 2b   = pParse->nTab+
4780: 2b 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65  +;.  sqlite3Vdbe
4790: 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72  AddOp4(v, OP_Str
47a0: 69 6e 67 38 2c 20 30 2c 20 72 65 67 54 61 62 6e  ing8, 0, regTabn
47b0: 61 6d 65 2c 20 30 2c 20 70 54 61 62 2d 3e 7a 4e  ame, 0, pTab->zN
47c0: 61 6d 65 2c 20 30 29 3b 0a 20 20 66 6f 72 28 70  ame, 0);.  for(p
47d0: 49 64 78 3d 70 54 61 62 2d 3e 70 49 6e 64 65 78  Idx=pTab->pIndex
47e0: 3b 20 70 49 64 78 3b 20 70 49 64 78 3d 70 49 64  ; pIdx; pIdx=pId
47f0: 78 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 69  x->pNext){.    i
4800: 6e 74 20 6e 43 6f 6c 3b 0a 20 20 20 20 4b 65 79  nt nCol;.    Key
4810: 49 6e 66 6f 20 2a 70 4b 65 79 3b 0a 20 20 20 20  Info *pKey;.    
4820: 69 6e 74 20 61 64 64 72 49 66 4e 6f 74 20 3d 20  int addrIfNot = 
4830: 30 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  0;           /* 
4840: 61 64 64 72 65 73 73 20 6f 66 20 4f 50 5f 49 66  address of OP_If
4850: 4e 6f 74 20 2a 2f 0a 20 20 20 20 69 6e 74 20 2a  Not */.    int *
4860: 61 43 68 6e 67 41 64 64 72 3b 20 20 20 20 20 20  aChngAddr;      
4870: 20 20 20 20 20 20 20 20 2f 2a 20 41 72 72 61 79          /* Array
4880: 20 6f 66 20 6a 75 6d 70 20 69 6e 73 74 72 75 63   of jump instruc
4890: 74 69 6f 6e 20 61 64 64 72 65 73 73 65 73 20 2a  tion addresses *
48a0: 2f 0a 0a 20 20 20 20 69 66 28 20 70 4f 6e 6c 79  /..    if( pOnly
48b0: 49 64 78 20 26 26 20 70 4f 6e 6c 79 49 64 78 21  Idx && pOnlyIdx!
48c0: 3d 70 49 64 78 20 29 20 63 6f 6e 74 69 6e 75 65  =pIdx ) continue
48d0: 3b 0a 20 20 20 20 56 64 62 65 4e 6f 6f 70 43 6f  ;.    VdbeNoopCo
48e0: 6d 6d 65 6e 74 28 28 76 2c 20 22 42 65 67 69 6e  mment((v, "Begin
48f0: 20 61 6e 61 6c 79 73 69 73 20 6f 66 20 25 73 22   analysis of %s"
4900: 2c 20 70 49 64 78 2d 3e 7a 4e 61 6d 65 29 29 3b  , pIdx->zName));
4910: 0a 20 20 20 20 6e 43 6f 6c 20 3d 20 70 49 64 78  .    nCol = pIdx
4920: 2d 3e 6e 43 6f 6c 75 6d 6e 3b 0a 20 20 20 20 70  ->nColumn;.    p
4930: 4b 65 79 20 3d 20 73 71 6c 69 74 65 33 49 6e 64  Key = sqlite3Ind
4940: 65 78 4b 65 79 69 6e 66 6f 28 70 50 61 72 73 65  exKeyinfo(pParse
4950: 2c 20 70 49 64 78 29 3b 0a 20 20 20 20 69 66 28  , pIdx);.    if(
4960: 20 69 4d 65 6d 2b 31 2b 28 6e 43 6f 6c 2a 32 29   iMem+1+(nCol*2)
4970: 3e 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20 29 7b  >pParse->nMem ){
4980: 0a 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e  .      pParse->n
4990: 4d 65 6d 20 3d 20 69 4d 65 6d 2b 31 2b 28 6e 43  Mem = iMem+1+(nC
49a0: 6f 6c 2a 32 29 3b 0a 20 20 20 20 7d 0a 20 20 20  ol*2);.    }.   
49b0: 20 61 43 68 6e 67 41 64 64 72 20 3d 20 73 71 6c   aChngAddr = sql
49c0: 69 74 65 33 44 62 4d 61 6c 6c 6f 63 52 61 77 28  ite3DbMallocRaw(
49d0: 64 62 2c 20 73 69 7a 65 6f 66 28 69 6e 74 29 2a  db, sizeof(int)*
49e0: 70 49 64 78 2d 3e 6e 43 6f 6c 75 6d 6e 29 3b 0a  pIdx->nColumn);.
49f0: 20 20 20 20 69 66 28 20 61 43 68 6e 67 41 64 64      if( aChngAdd
4a00: 72 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b  r==0 ) continue;
4a10: 0a 0a 20 20 20 20 2f 2a 20 4f 70 65 6e 20 61 20  ..    /* Open a 
4a20: 63 75 72 73 6f 72 20 74 6f 20 74 68 65 20 69 6e  cursor to the in
4a30: 64 65 78 20 74 6f 20 62 65 20 61 6e 61 6c 79 7a  dex to be analyz
4a40: 65 64 2e 20 2a 2f 0a 20 20 20 20 61 73 73 65 72  ed. */.    asser
4a50: 74 28 20 69 44 62 3d 3d 73 71 6c 69 74 65 33 53  t( iDb==sqlite3S
4a60: 63 68 65 6d 61 54 6f 49 6e 64 65 78 28 64 62 2c  chemaToIndex(db,
4a70: 20 70 49 64 78 2d 3e 70 53 63 68 65 6d 61 29 20   pIdx->pSchema) 
4a80: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
4a90: 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 4f  beAddOp4(v, OP_O
4aa0: 70 65 6e 52 65 61 64 2c 20 69 49 64 78 43 75 72  penRead, iIdxCur
4ab0: 2c 20 70 49 64 78 2d 3e 74 6e 75 6d 2c 20 69 44  , pIdx->tnum, iD
4ac0: 62 2c 0a 20 20 20 20 20 20 20 20 28 63 68 61 72  b,.        (char
4ad0: 20 2a 29 70 4b 65 79 2c 20 50 34 5f 4b 45 59 49   *)pKey, P4_KEYI
4ae0: 4e 46 4f 5f 48 41 4e 44 4f 46 46 29 3b 0a 20 20  NFO_HANDOFF);.  
4af0: 20 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28 28 76    VdbeComment((v
4b00: 2c 20 22 25 73 22 2c 20 70 49 64 78 2d 3e 7a 4e  , "%s", pIdx->zN
4b10: 61 6d 65 29 29 3b 0a 0a 20 20 20 20 2f 2a 20 50  ame));..    /* P
4b20: 6f 70 75 6c 61 74 65 20 74 68 65 20 72 65 67 69  opulate the regi
4b30: 73 74 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20  ster containing 
4b40: 74 68 65 20 69 6e 64 65 78 20 6e 61 6d 65 2e 20  the index name. 
4b50: 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  */.    sqlite3Vd
4b60: 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53  beAddOp4(v, OP_S
4b70: 74 72 69 6e 67 38 2c 20 30 2c 20 72 65 67 49 64  tring8, 0, regId
4b80: 78 6e 61 6d 65 2c 20 30 2c 20 70 49 64 78 2d 3e  xname, 0, pIdx->
4b90: 7a 4e 61 6d 65 2c 20 30 29 3b 0a 0a 23 69 66 64  zName, 0);..#ifd
4ba0: 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45  ef SQLITE_ENABLE
4bb0: 5f 53 54 41 54 33 0a 20 20 20 20 69 66 28 20 6f  _STAT3.    if( o
4bc0: 6e 63 65 20 29 7b 0a 20 20 20 20 20 20 6f 6e 63  nce ){.      onc
4bd0: 65 20 3d 20 30 3b 0a 20 20 20 20 20 20 73 71 6c  e = 0;.      sql
4be0: 69 74 65 33 4f 70 65 6e 54 61 62 6c 65 28 70 50  ite3OpenTable(pP
4bf0: 61 72 73 65 2c 20 69 54 61 62 43 75 72 2c 20 69  arse, iTabCur, i
4c00: 44 62 2c 20 70 54 61 62 2c 20 4f 50 5f 4f 70 65  Db, pTab, OP_Ope
4c10: 6e 52 65 61 64 29 3b 0a 20 20 20 20 7d 0a 20 20  nRead);.    }.  
4c20: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
4c30: 4f 70 32 28 76 2c 20 4f 50 5f 43 6f 75 6e 74 2c  Op2(v, OP_Count,
4c40: 20 69 49 64 78 43 75 72 2c 20 72 65 67 43 6f 75   iIdxCur, regCou
4c50: 6e 74 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  nt);.    sqlite3
4c60: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
4c70: 5f 49 6e 74 65 67 65 72 2c 20 53 51 4c 49 54 45  _Integer, SQLITE
4c80: 5f 53 54 41 54 33 5f 53 41 4d 50 4c 45 53 2c 20  _STAT3_SAMPLES, 
4c90: 72 65 67 54 65 6d 70 31 29 3b 0a 20 20 20 20 73  regTemp1);.    s
4ca0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
4cb0: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
4cc0: 30 2c 20 72 65 67 4e 75 6d 45 71 29 3b 0a 20 20  0, regNumEq);.  
4cd0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
4ce0: 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65  Op2(v, OP_Intege
4cf0: 72 2c 20 30 2c 20 72 65 67 4e 75 6d 4c 74 29 3b  r, 0, regNumLt);
4d00: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
4d10: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74  AddOp2(v, OP_Int
4d20: 65 67 65 72 2c 20 2d 31 2c 20 72 65 67 4e 75 6d  eger, -1, regNum
4d30: 44 4c 74 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  DLt);.    sqlite
4d40: 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f  3VdbeAddOp4(v, O
4d50: 50 5f 46 75 6e 63 74 69 6f 6e 2c 20 31 2c 20 72  P_Function, 1, r
4d60: 65 67 43 6f 75 6e 74 2c 20 72 65 67 41 63 63 75  egCount, regAccu
4d70: 6d 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  m,.             
4d80: 20 20 20 20 20 20 20 20 20 28 63 68 61 72 2a 29           (char*)
4d90: 26 73 74 61 74 33 49 6e 69 74 46 75 6e 63 64 65  &stat3InitFuncde
4da0: 66 2c 20 50 34 5f 46 55 4e 43 44 45 46 29 3b 0a  f, P4_FUNCDEF);.
4db0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43      sqlite3VdbeC
4dc0: 68 61 6e 67 65 50 35 28 76 2c 20 32 29 3b 0a 23  hangeP5(v, 2);.#
4dd0: 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f  endif /* SQLITE_
4de0: 45 4e 41 42 4c 45 5f 53 54 41 54 33 20 2a 2f 0a  ENABLE_STAT3 */.
4df0: 0a 20 20 20 20 2f 2a 20 54 68 65 20 62 6c 6f 63  .    /* The bloc
4e00: 6b 20 6f 66 20 6d 65 6d 6f 72 79 20 63 65 6c 6c  k of memory cell
4e10: 73 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 68 65  s initialized he
4e20: 72 65 20 69 73 20 75 73 65 64 20 61 73 20 66 6f  re is used as fo
4e30: 6c 6c 6f 77 73 2e 0a 20 20 20 20 2a 2a 0a 20 20  llows..    **.  
4e40: 20 20 2a 2a 20 20 20 20 69 4d 65 6d 3a 20 20 20    **    iMem:   
4e50: 20 20 20 20 20 20 20 20 20 20 20 20 20 0a 20 20               .  
4e60: 20 20 2a 2a 20 20 20 20 20 20 20 20 54 68 65 20    **        The 
4e70: 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20  total number of 
4e80: 72 6f 77 73 20 69 6e 20 74 68 65 20 74 61 62 6c  rows in the tabl
4e90: 65 2e 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a  e..    **.    **
4ea0: 20 20 20 20 69 4d 65 6d 2b 31 20 2e 2e 20 69 4d      iMem+1 .. iM
4eb0: 65 6d 2b 6e 43 6f 6c 3a 20 0a 20 20 20 20 2a 2a  em+nCol: .    **
4ec0: 20 20 20 20 20 20 20 20 4e 75 6d 62 65 72 20 6f          Number o
4ed0: 66 20 64 69 73 74 69 6e 63 74 20 65 6e 74 72 69  f distinct entri
4ee0: 65 73 20 69 6e 20 69 6e 64 65 78 20 63 6f 6e 73  es in index cons
4ef0: 69 64 65 72 69 6e 67 20 74 68 65 20 0a 20 20 20  idering the .   
4f00: 20 2a 2a 20 20 20 20 20 20 20 20 6c 65 66 74 2d   **        left-
4f10: 6d 6f 73 74 20 4e 20 63 6f 6c 75 6d 6e 73 20 6f  most N columns o
4f20: 6e 6c 79 2c 20 77 68 65 72 65 20 4e 20 69 73 20  nly, where N is 
4f30: 62 65 74 77 65 65 6e 20 31 20 61 6e 64 20 6e 43  between 1 and nC
4f40: 6f 6c 2c 20 0a 20 20 20 20 2a 2a 20 20 20 20 20  ol, .    **     
4f50: 20 20 20 69 6e 63 6c 75 73 69 76 65 2e 0a 20 20     inclusive..  
4f60: 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 20 20 20 69    **.    **    i
4f70: 4d 65 6d 2b 6e 43 6f 6c 2b 31 20 2e 2e 20 4d 65  Mem+nCol+1 .. Me
4f80: 6d 2b 32 2a 6e 43 6f 6c 3a 20 20 0a 20 20 20 20  m+2*nCol:  .    
4f90: 2a 2a 20 20 20 20 20 20 20 20 50 72 65 76 69 6f  **        Previo
4fa0: 75 73 20 76 61 6c 75 65 20 6f 66 20 69 6e 64 65  us value of inde
4fb0: 78 65 64 20 63 6f 6c 75 6d 6e 73 2c 20 66 72 6f  xed columns, fro
4fc0: 6d 20 6c 65 66 74 20 74 6f 20 72 69 67 68 74 2e  m left to right.
4fd0: 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 43  .    **.    ** C
4fe0: 65 6c 6c 73 20 69 4d 65 6d 20 74 68 72 6f 75 67  ells iMem throug
4ff0: 68 20 69 4d 65 6d 2b 6e 43 6f 6c 20 61 72 65 20  h iMem+nCol are 
5000: 69 6e 69 74 69 61 6c 69 7a 65 64 20 74 6f 20 30  initialized to 0
5010: 2e 20 54 68 65 20 6f 74 68 65 72 73 20 61 72 65  . The others are
5020: 20 0a 20 20 20 20 2a 2a 20 69 6e 69 74 69 61 6c   .    ** initial
5030: 69 7a 65 64 20 74 6f 20 63 6f 6e 74 61 69 6e 20  ized to contain 
5040: 61 6e 20 53 51 4c 20 4e 55 4c 4c 2e 0a 20 20 20  an SQL NULL..   
5050: 20 2a 2f 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b   */.    for(i=0;
5060: 20 69 3c 3d 6e 43 6f 6c 3b 20 69 2b 2b 29 7b 0a   i<=nCol; i++){.
5070: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
5080: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e  eAddOp2(v, OP_In
5090: 74 65 67 65 72 2c 20 30 2c 20 69 4d 65 6d 2b 69  teger, 0, iMem+i
50a0: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 66 6f 72  );.    }.    for
50b0: 28 69 3d 30 3b 20 69 3c 6e 43 6f 6c 3b 20 69 2b  (i=0; i<nCol; i+
50c0: 2b 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  +){.      sqlite
50d0: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
50e0: 50 5f 4e 75 6c 6c 2c 20 30 2c 20 69 4d 65 6d 2b  P_Null, 0, iMem+
50f0: 6e 43 6f 6c 2b 69 2b 31 29 3b 0a 20 20 20 20 7d  nCol+i+1);.    }
5100: 0a 0a 20 20 20 20 2f 2a 20 53 74 61 72 74 20 74  ..    /* Start t
5110: 68 65 20 61 6e 61 6c 79 73 69 73 20 6c 6f 6f 70  he analysis loop
5120: 2e 20 54 68 69 73 20 6c 6f 6f 70 20 72 75 6e 73  . This loop runs
5130: 20 74 68 72 6f 75 67 68 20 61 6c 6c 20 74 68 65   through all the
5140: 20 65 6e 74 72 69 65 73 20 69 6e 0a 20 20 20 20   entries in.    
5150: 2a 2a 20 74 68 65 20 69 6e 64 65 78 20 62 2d 74  ** the index b-t
5160: 72 65 65 2e 20 20 2a 2f 0a 20 20 20 20 65 6e 64  ree.  */.    end
5170: 4f 66 4c 6f 6f 70 20 3d 20 73 71 6c 69 74 65 33  OfLoop = sqlite3
5180: 56 64 62 65 4d 61 6b 65 4c 61 62 65 6c 28 76 29  VdbeMakeLabel(v)
5190: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
51a0: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65  eAddOp2(v, OP_Re
51b0: 77 69 6e 64 2c 20 69 49 64 78 43 75 72 2c 20 65  wind, iIdxCur, e
51c0: 6e 64 4f 66 4c 6f 6f 70 29 3b 0a 20 20 20 20 74  ndOfLoop);.    t
51d0: 6f 70 4f 66 4c 6f 6f 70 20 3d 20 73 71 6c 69 74  opOfLoop = sqlit
51e0: 65 33 56 64 62 65 43 75 72 72 65 6e 74 41 64 64  e3VdbeCurrentAdd
51f0: 72 28 76 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  r(v);.    sqlite
5200: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
5210: 50 5f 41 64 64 49 6d 6d 2c 20 69 4d 65 6d 2c 20  P_AddImm, iMem, 
5220: 31 29 3b 20 20 2f 2a 20 49 6e 63 72 65 6d 65 6e  1);  /* Incremen
5230: 74 20 72 6f 77 20 63 6f 75 6e 74 65 72 20 2a 2f  t row counter */
5240: 0a 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69  ..    for(i=0; i
5250: 3c 6e 43 6f 6c 3b 20 69 2b 2b 29 7b 0a 20 20 20  <nCol; i++){.   
5260: 20 20 20 43 6f 6c 6c 53 65 71 20 2a 70 43 6f 6c     CollSeq *pCol
5270: 6c 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  l;.      sqlite3
5280: 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50  VdbeAddOp3(v, OP
5290: 5f 43 6f 6c 75 6d 6e 2c 20 69 49 64 78 43 75 72  _Column, iIdxCur
52a0: 2c 20 69 2c 20 72 65 67 43 6f 6c 29 3b 0a 20 20  , i, regCol);.  
52b0: 20 20 20 20 69 66 28 20 69 3d 3d 30 20 29 7b 0a      if( i==0 ){.
52c0: 20 20 20 20 20 20 20 20 2f 2a 20 41 6c 77 61 79          /* Alway
52d0: 73 20 72 65 63 6f 72 64 20 74 68 65 20 76 65 72  s record the ver
52e0: 79 20 66 69 72 73 74 20 72 6f 77 20 2a 2f 0a 20  y first row */. 
52f0: 20 20 20 20 20 20 20 61 64 64 72 49 66 4e 6f 74         addrIfNot
5300: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64   = sqlite3VdbeAd
5310: 64 4f 70 31 28 76 2c 20 4f 50 5f 49 66 4e 6f 74  dOp1(v, OP_IfNot
5320: 2c 20 69 4d 65 6d 2b 31 29 3b 0a 20 20 20 20 20  , iMem+1);.     
5330: 20 7d 0a 20 20 20 20 20 20 61 73 73 65 72 74 28   }.      assert(
5340: 20 70 49 64 78 2d 3e 61 7a 43 6f 6c 6c 21 3d 30   pIdx->azColl!=0
5350: 20 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74   );.      assert
5360: 28 20 70 49 64 78 2d 3e 61 7a 43 6f 6c 6c 5b 69  ( pIdx->azColl[i
5370: 5d 21 3d 30 20 29 3b 0a 20 20 20 20 20 20 70 43  ]!=0 );.      pC
5380: 6f 6c 6c 20 3d 20 73 71 6c 69 74 65 33 4c 6f 63  oll = sqlite3Loc
5390: 61 74 65 43 6f 6c 6c 53 65 71 28 70 50 61 72 73  ateCollSeq(pPars
53a0: 65 2c 20 70 49 64 78 2d 3e 61 7a 43 6f 6c 6c 5b  e, pIdx->azColl[
53b0: 69 5d 29 3b 0a 20 20 20 20 20 20 61 43 68 6e 67  i]);.      aChng
53c0: 41 64 64 72 5b 69 5d 20 3d 20 73 71 6c 69 74 65  Addr[i] = sqlite
53d0: 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f  3VdbeAddOp4(v, O
53e0: 50 5f 4e 65 2c 20 72 65 67 43 6f 6c 2c 20 30 2c  P_Ne, regCol, 0,
53f0: 20 69 4d 65 6d 2b 6e 43 6f 6c 2b 69 2b 31 2c 0a   iMem+nCol+i+1,.
5400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5420: 20 20 20 20 20 20 28 63 68 61 72 2a 29 70 43 6f        (char*)pCo
5430: 6c 6c 2c 20 50 34 5f 43 4f 4c 4c 53 45 51 29 3b  ll, P4_COLLSEQ);
5440: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
5450: 62 65 43 68 61 6e 67 65 50 35 28 76 2c 20 53 51  beChangeP5(v, SQ
5460: 4c 49 54 45 5f 4e 55 4c 4c 45 51 29 3b 0a 20 20  LITE_NULLEQ);.  
5470: 20 20 20 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28      VdbeComment(
5480: 28 76 2c 20 22 6a 75 6d 70 20 69 66 20 63 6f 6c  (v, "jump if col
5490: 75 6d 6e 20 25 64 20 63 68 61 6e 67 65 64 22 2c  umn %d changed",
54a0: 20 69 29 29 3b 0a 23 69 66 64 65 66 20 53 51 4c   i));.#ifdef SQL
54b0: 49 54 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33  ITE_ENABLE_STAT3
54c0: 0a 20 20 20 20 20 20 69 66 28 20 69 3d 3d 30 20  .      if( i==0 
54d0: 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ){.        sqlit
54e0: 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20  e3VdbeAddOp2(v, 
54f0: 4f 50 5f 41 64 64 49 6d 6d 2c 20 72 65 67 4e 75  OP_AddImm, regNu
5500: 6d 45 71 2c 20 31 29 3b 0a 20 20 20 20 20 20 20  mEq, 1);.       
5510: 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28 28 76 2c   VdbeComment((v,
5520: 20 22 69 6e 63 72 20 72 65 70 65 61 74 20 63 6f   "incr repeat co
5530: 75 6e 74 22 29 29 3b 0a 20 20 20 20 20 20 7d 0a  unt"));.      }.
5540: 23 65 6e 64 69 66 0a 20 20 20 20 7d 0a 20 20 20  #endif.    }.   
5550: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
5560: 70 32 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30  p2(v, OP_Goto, 0
5570: 2c 20 65 6e 64 4f 66 4c 6f 6f 70 29 3b 0a 20 20  , endOfLoop);.  
5580: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 43 6f    for(i=0; i<nCo
5590: 6c 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 73  l; i++){.      s
55a0: 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65  qlite3VdbeJumpHe
55b0: 72 65 28 76 2c 20 61 43 68 6e 67 41 64 64 72 5b  re(v, aChngAddr[
55c0: 69 5d 29 3b 20 20 2f 2a 20 53 65 74 20 6a 75 6d  i]);  /* Set jum
55d0: 70 20 64 65 73 74 20 66 6f 72 20 74 68 65 20 4f  p dest for the O
55e0: 50 5f 4e 65 20 2a 2f 0a 20 20 20 20 20 20 69 66  P_Ne */.      if
55f0: 28 20 69 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  ( i==0 ){.      
5600: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d    sqlite3VdbeJum
5610: 70 48 65 72 65 28 76 2c 20 61 64 64 72 49 66 4e  pHere(v, addrIfN
5620: 6f 74 29 3b 20 20 20 2f 2a 20 4a 75 6d 70 20 64  ot);   /* Jump d
5630: 65 73 74 20 66 6f 72 20 4f 50 5f 49 66 4e 6f 74  est for OP_IfNot
5640: 20 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c 49 54   */.#ifdef SQLIT
5650: 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 0a 20  E_ENABLE_STAT3. 
5660: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
5670: 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 46  beAddOp4(v, OP_F
5680: 75 6e 63 74 69 6f 6e 2c 20 31 2c 20 72 65 67 4e  unction, 1, regN
5690: 75 6d 45 71 2c 20 72 65 67 54 65 6d 70 32 2c 0a  umEq, regTemp2,.
56a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
56b0: 20 20 20 20 20 20 20 20 20 20 28 63 68 61 72 2a            (char*
56c0: 29 26 73 74 61 74 33 50 75 73 68 46 75 6e 63 64  )&stat3PushFuncd
56d0: 65 66 2c 20 50 34 5f 46 55 4e 43 44 45 46 29 3b  ef, P4_FUNCDEF);
56e0: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
56f0: 56 64 62 65 43 68 61 6e 67 65 50 35 28 76 2c 20  VdbeChangeP5(v, 
5700: 35 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  5);.        sqli
5710: 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c  te3VdbeAddOp3(v,
5720: 20 4f 50 5f 43 6f 6c 75 6d 6e 2c 20 69 49 64 78   OP_Column, iIdx
5730: 43 75 72 2c 20 70 49 64 78 2d 3e 6e 43 6f 6c 75  Cur, pIdx->nColu
5740: 6d 6e 2c 20 72 65 67 52 6f 77 69 64 29 3b 0a 20  mn, regRowid);. 
5750: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
5760: 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 41  beAddOp3(v, OP_A
5770: 64 64 2c 20 72 65 67 4e 75 6d 45 71 2c 20 72 65  dd, regNumEq, re
5780: 67 4e 75 6d 4c 74 2c 20 72 65 67 4e 75 6d 4c 74  gNumLt, regNumLt
5790: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
57a0: 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20  e3VdbeAddOp2(v, 
57b0: 4f 50 5f 41 64 64 49 6d 6d 2c 20 72 65 67 4e 75  OP_AddImm, regNu
57c0: 6d 44 4c 74 2c 20 31 29 3b 0a 20 20 20 20 20 20  mDLt, 1);.      
57d0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
57e0: 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65  Op2(v, OP_Intege
57f0: 72 2c 20 31 2c 20 72 65 67 4e 75 6d 45 71 29 3b  r, 1, regNumEq);
5800: 0a 23 65 6e 64 69 66 20 20 20 20 20 20 20 20 0a  .#endif        .
5810: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71        }.      sq
5820: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
5830: 76 2c 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 69 4d  v, OP_AddImm, iM
5840: 65 6d 2b 69 2b 31 2c 20 31 29 3b 0a 20 20 20 20  em+i+1, 1);.    
5850: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
5860: 4f 70 33 28 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e  Op3(v, OP_Column
5870: 2c 20 69 49 64 78 43 75 72 2c 20 69 2c 20 69 4d  , iIdxCur, i, iM
5880: 65 6d 2b 6e 43 6f 6c 2b 69 2b 31 29 3b 0a 20 20  em+nCol+i+1);.  
5890: 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 44    }.    sqlite3D
58a0: 62 46 72 65 65 28 64 62 2c 20 61 43 68 6e 67 41  bFree(db, aChngA
58b0: 64 64 72 29 3b 0a 0a 20 20 20 20 2f 2a 20 41 6c  ddr);..    /* Al
58c0: 77 61 79 73 20 6a 75 6d 70 20 68 65 72 65 20 61  ways jump here a
58d0: 66 74 65 72 20 75 70 64 61 74 69 6e 67 20 74 68  fter updating th
58e0: 65 20 69 4d 65 6d 2b 31 2e 2e 2e 69 4d 65 6d 2b  e iMem+1...iMem+
58f0: 31 2b 6e 43 6f 6c 20 63 6f 75 6e 74 65 72 73 20  1+nCol counters 
5900: 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  */.    sqlite3Vd
5910: 62 65 52 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76  beResolveLabel(v
5920: 2c 20 65 6e 64 4f 66 4c 6f 6f 70 29 3b 0a 0a 20  , endOfLoop);.. 
5930: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
5940: 64 4f 70 32 28 76 2c 20 4f 50 5f 4e 65 78 74 2c  dOp2(v, OP_Next,
5950: 20 69 49 64 78 43 75 72 2c 20 74 6f 70 4f 66 4c   iIdxCur, topOfL
5960: 6f 6f 70 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  oop);.    sqlite
5970: 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20 4f  3VdbeAddOp1(v, O
5980: 50 5f 43 6c 6f 73 65 2c 20 69 49 64 78 43 75 72  P_Close, iIdxCur
5990: 29 3b 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  );.#ifdef SQLITE
59a0: 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 0a 20 20  _ENABLE_STAT3.  
59b0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
59c0: 4f 70 34 28 76 2c 20 4f 50 5f 46 75 6e 63 74 69  Op4(v, OP_Functi
59d0: 6f 6e 2c 20 31 2c 20 72 65 67 4e 75 6d 45 71 2c  on, 1, regNumEq,
59e0: 20 72 65 67 54 65 6d 70 32 2c 0a 20 20 20 20 20   regTemp2,.     
59f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5a00: 20 28 63 68 61 72 2a 29 26 73 74 61 74 33 50 75   (char*)&stat3Pu
5a10: 73 68 46 75 6e 63 64 65 66 2c 20 50 34 5f 46 55  shFuncdef, P4_FU
5a20: 4e 43 44 45 46 29 3b 0a 20 20 20 20 73 71 6c 69  NCDEF);.    sqli
5a30: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 35 28  te3VdbeChangeP5(
5a40: 76 2c 20 35 29 3b 0a 20 20 20 20 73 71 6c 69 74  v, 5);.    sqlit
5a50: 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20  e3VdbeAddOp2(v, 
5a60: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 2d 31 2c 20  OP_Integer, -1, 
5a70: 72 65 67 4c 6f 6f 70 29 3b 0a 20 20 20 20 73 68  regLoop);.    sh
5a80: 6f 72 74 4a 75 6d 70 20 3d 20 0a 20 20 20 20 73  ortJump = .    s
5a90: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
5aa0: 28 76 2c 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 72  (v, OP_AddImm, r
5ab0: 65 67 4c 6f 6f 70 2c 20 31 29 3b 0a 20 20 20 20  egLoop, 1);.    
5ac0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
5ad0: 34 28 76 2c 20 4f 50 5f 46 75 6e 63 74 69 6f 6e  4(v, OP_Function
5ae0: 2c 20 31 2c 20 72 65 67 41 63 63 75 6d 2c 20 72  , 1, regAccum, r
5af0: 65 67 54 65 6d 70 31 2c 0a 20 20 20 20 20 20 20  egTemp1,.       
5b00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28                 (
5b10: 63 68 61 72 2a 29 26 73 74 61 74 33 47 65 74 46  char*)&stat3GetF
5b20: 75 6e 63 64 65 66 2c 20 50 34 5f 46 55 4e 43 44  uncdef, P4_FUNCD
5b30: 45 46 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  EF);.    sqlite3
5b40: 56 64 62 65 43 68 61 6e 67 65 50 35 28 76 2c 20  VdbeChangeP5(v, 
5b50: 32 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  2);.    sqlite3V
5b60: 64 62 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f  dbeAddOp1(v, OP_
5b70: 49 73 4e 75 6c 6c 2c 20 72 65 67 54 65 6d 70 31  IsNull, regTemp1
5b80: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
5b90: 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4e  beAddOp3(v, OP_N
5ba0: 6f 74 45 78 69 73 74 73 2c 20 69 54 61 62 43 75  otExists, iTabCu
5bb0: 72 2c 20 73 68 6f 72 74 4a 75 6d 70 2c 20 72 65  r, shortJump, re
5bc0: 67 54 65 6d 70 31 29 3b 0a 20 20 20 20 73 71 6c  gTemp1);.    sql
5bd0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76  ite3VdbeAddOp3(v
5be0: 2c 20 4f 50 5f 43 6f 6c 75 6d 6e 2c 20 69 54 61  , OP_Column, iTa
5bf0: 62 43 75 72 2c 20 70 49 64 78 2d 3e 61 69 43 6f  bCur, pIdx->aiCo
5c00: 6c 75 6d 6e 5b 30 5d 2c 20 72 65 67 53 61 6d 70  lumn[0], regSamp
5c10: 6c 65 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  le);.    sqlite3
5c20: 43 6f 6c 75 6d 6e 44 65 66 61 75 6c 74 28 76 2c  ColumnDefault(v,
5c30: 20 70 54 61 62 2c 20 70 49 64 78 2d 3e 61 69 43   pTab, pIdx->aiC
5c40: 6f 6c 75 6d 6e 5b 30 5d 2c 20 72 65 67 53 61 6d  olumn[0], regSam
5c50: 70 6c 65 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  ple);.    sqlite
5c60: 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f  3VdbeAddOp4(v, O
5c70: 50 5f 46 75 6e 63 74 69 6f 6e 2c 20 31 2c 20 72  P_Function, 1, r
5c80: 65 67 41 63 63 75 6d 2c 20 72 65 67 4e 75 6d 45  egAccum, regNumE
5c90: 71 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  q,.             
5ca0: 20 20 20 20 20 20 20 20 20 28 63 68 61 72 2a 29           (char*)
5cb0: 26 73 74 61 74 33 47 65 74 46 75 6e 63 64 65 66  &stat3GetFuncdef
5cc0: 2c 20 50 34 5f 46 55 4e 43 44 45 46 29 3b 0a 20  , P4_FUNCDEF);. 
5cd0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68     sqlite3VdbeCh
5ce0: 61 6e 67 65 50 35 28 76 2c 20 33 29 3b 0a 20 20  angeP5(v, 3);.  
5cf0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
5d00: 4f 70 34 28 76 2c 20 4f 50 5f 46 75 6e 63 74 69  Op4(v, OP_Functi
5d10: 6f 6e 2c 20 31 2c 20 72 65 67 41 63 63 75 6d 2c  on, 1, regAccum,
5d20: 20 72 65 67 4e 75 6d 4c 74 2c 0a 20 20 20 20 20   regNumLt,.     
5d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d40: 20 28 63 68 61 72 2a 29 26 73 74 61 74 33 47 65   (char*)&stat3Ge
5d50: 74 46 75 6e 63 64 65 66 2c 20 50 34 5f 46 55 4e  tFuncdef, P4_FUN
5d60: 43 44 45 46 29 3b 0a 20 20 20 20 73 71 6c 69 74  CDEF);.    sqlit
5d70: 65 33 56 64 62 65 43 68 61 6e 67 65 50 35 28 76  e3VdbeChangeP5(v
5d80: 2c 20 34 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  , 4);.    sqlite
5d90: 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f  3VdbeAddOp4(v, O
5da0: 50 5f 46 75 6e 63 74 69 6f 6e 2c 20 31 2c 20 72  P_Function, 1, r
5db0: 65 67 41 63 63 75 6d 2c 20 72 65 67 4e 75 6d 44  egAccum, regNumD
5dc0: 4c 74 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  Lt,.            
5dd0: 20 20 20 20 20 20 20 20 20 20 28 63 68 61 72 2a            (char*
5de0: 29 26 73 74 61 74 33 47 65 74 46 75 6e 63 64 65  )&stat3GetFuncde
5df0: 66 2c 20 50 34 5f 46 55 4e 43 44 45 46 29 3b 0a  f, P4_FUNCDEF);.
5e00: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43      sqlite3VdbeC
5e10: 68 61 6e 67 65 50 35 28 76 2c 20 35 29 3b 0a 20  hangeP5(v, 5);. 
5e20: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
5e30: 64 4f 70 34 28 76 2c 20 4f 50 5f 4d 61 6b 65 52  dOp4(v, OP_MakeR
5e40: 65 63 6f 72 64 2c 20 72 65 67 54 61 62 6e 61 6d  ecord, regTabnam
5e50: 65 2c 20 36 2c 20 72 65 67 52 65 63 2c 20 22 62  e, 6, regRec, "b
5e60: 62 62 62 62 62 22 2c 20 30 29 3b 0a 20 20 20 20  bbbbb", 0);.    
5e70: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
5e80: 32 28 76 2c 20 4f 50 5f 4e 65 77 52 6f 77 69 64  2(v, OP_NewRowid
5e90: 2c 20 69 53 74 61 74 43 75 72 2b 31 2c 20 72 65  , iStatCur+1, re
5ea0: 67 4e 65 77 52 6f 77 69 64 29 3b 0a 20 20 20 20  gNewRowid);.    
5eb0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
5ec0: 33 28 76 2c 20 4f 50 5f 49 6e 73 65 72 74 2c 20  3(v, OP_Insert, 
5ed0: 69 53 74 61 74 43 75 72 2b 31 2c 20 72 65 67 52  iStatCur+1, regR
5ee0: 65 63 2c 20 72 65 67 4e 65 77 52 6f 77 69 64 29  ec, regNewRowid)
5ef0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
5f00: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 47 6f  eAddOp2(v, OP_Go
5f10: 74 6f 2c 20 30 2c 20 73 68 6f 72 74 4a 75 6d 70  to, 0, shortJump
5f20: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
5f30: 62 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 73 68  beJumpHere(v, sh
5f40: 6f 72 74 4a 75 6d 70 2b 32 29 3b 0a 23 65 6e 64  ortJump+2);.#end
5f50: 69 66 20 20 20 20 20 20 20 20 0a 0a 20 20 20 20  if        ..    
5f60: 2f 2a 20 53 74 6f 72 65 20 74 68 65 20 72 65 73  /* Store the res
5f70: 75 6c 74 73 20 69 6e 20 73 71 6c 69 74 65 5f 73  ults in sqlite_s
5f80: 74 61 74 31 2e 0a 20 20 20 20 2a 2a 0a 20 20 20  tat1..    **.   
5f90: 20 2a 2a 20 54 68 65 20 72 65 73 75 6c 74 20 69   ** The result i
5fa0: 73 20 61 20 73 69 6e 67 6c 65 20 72 6f 77 20 6f  s a single row o
5fb0: 66 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74 61  f the sqlite_sta
5fc0: 74 31 20 74 61 62 6c 65 2e 20 20 54 68 65 20 66  t1 table.  The f
5fd0: 69 72 73 74 0a 20 20 20 20 2a 2a 20 74 77 6f 20  irst.    ** two 
5fe0: 63 6f 6c 75 6d 6e 73 20 61 72 65 20 74 68 65 20  columns are the 
5ff0: 6e 61 6d 65 73 20 6f 66 20 74 68 65 20 74 61 62  names of the tab
6000: 6c 65 20 61 6e 64 20 69 6e 64 65 78 2e 20 20 54  le and index.  T
6010: 68 65 20 74 68 69 72 64 20 63 6f 6c 75 6d 6e 0a  he third column.
6020: 20 20 20 20 2a 2a 20 69 73 20 61 20 73 74 72 69      ** is a stri
6030: 6e 67 20 63 6f 6d 70 6f 73 65 64 20 6f 66 20 61  ng composed of a
6040: 20 6c 69 73 74 20 6f 66 20 69 6e 74 65 67 65 72   list of integer
6050: 20 73 74 61 74 69 73 74 69 63 73 20 61 62 6f 75   statistics abou
6060: 74 20 74 68 65 0a 20 20 20 20 2a 2a 20 69 6e 64  t the.    ** ind
6070: 65 78 2e 20 20 54 68 65 20 66 69 72 73 74 20 69  ex.  The first i
6080: 6e 74 65 67 65 72 20 69 6e 20 74 68 65 20 6c 69  nteger in the li
6090: 73 74 20 69 73 20 74 68 65 20 74 6f 74 61 6c 20  st is the total 
60a0: 6e 75 6d 62 65 72 20 6f 66 20 65 6e 74 72 69 65  number of entrie
60b0: 73 0a 20 20 20 20 2a 2a 20 69 6e 20 74 68 65 20  s.    ** in the 
60c0: 69 6e 64 65 78 2e 20 20 54 68 65 72 65 20 69 73  index.  There is
60d0: 20 6f 6e 65 20 61 64 64 69 74 69 6f 6e 61 6c 20   one additional 
60e0: 69 6e 74 65 67 65 72 20 69 6e 20 74 68 65 20 6c  integer in the l
60f0: 69 73 74 20 66 6f 72 20 65 61 63 68 0a 20 20 20  ist for each.   
6100: 20 2a 2a 20 63 6f 6c 75 6d 6e 20 6f 66 20 74 68   ** column of th
6110: 65 20 74 61 62 6c 65 2e 20 20 54 68 69 73 20 61  e table.  This a
6120: 64 64 69 74 69 6f 6e 61 6c 20 69 6e 74 65 67 65  dditional intege
6130: 72 20 69 73 20 61 20 67 75 65 73 73 20 6f 66 20  r is a guess of 
6140: 68 6f 77 20 6d 61 6e 79 0a 20 20 20 20 2a 2a 20  how many.    ** 
6150: 72 6f 77 73 20 6f 66 20 74 68 65 20 74 61 62 6c  rows of the tabl
6160: 65 20 74 68 65 20 69 6e 64 65 78 20 77 69 6c 6c  e the index will
6170: 20 73 65 6c 65 63 74 2e 20 20 49 66 20 44 20 69   select.  If D i
6180: 73 20 74 68 65 20 63 6f 75 6e 74 20 6f 66 20 64  s the count of d
6190: 69 73 74 69 6e 63 74 0a 20 20 20 20 2a 2a 20 76  istinct.    ** v
61a0: 61 6c 75 65 73 20 61 6e 64 20 4b 20 69 73 20 74  alues and K is t
61b0: 68 65 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20  he total number 
61c0: 6f 66 20 72 6f 77 73 2c 20 74 68 65 6e 20 74 68  of rows, then th
61d0: 65 20 69 6e 74 65 67 65 72 20 69 73 20 63 6f 6d  e integer is com
61e0: 70 75 74 65 64 0a 20 20 20 20 2a 2a 20 61 73 3a  puted.    ** as:
61f0: 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 20  .    **.    **  
6200: 20 20 20 20 20 20 49 20 3d 20 28 4b 2b 44 2d 31        I = (K+D-1
6210: 29 2f 44 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a  )/D.    **.    *
6220: 2a 20 49 66 20 4b 3d 3d 30 20 74 68 65 6e 20 6e  * If K==0 then n
6230: 6f 20 65 6e 74 72 79 20 69 73 20 6d 61 64 65 20  o entry is made 
6240: 69 6e 74 6f 20 74 68 65 20 73 71 6c 69 74 65 5f  into the sqlite_
6250: 73 74 61 74 31 20 74 61 62 6c 65 2e 20 20 0a 20  stat1 table.  . 
6260: 20 20 20 2a 2a 20 49 66 20 4b 3e 30 20 74 68 65     ** If K>0 the
6270: 6e 20 69 74 20 69 73 20 61 6c 77 61 79 73 20 74  n it is always t
6280: 68 65 20 63 61 73 65 20 74 68 65 20 44 3e 30 20  he case the D>0 
6290: 73 6f 20 64 69 76 69 73 69 6f 6e 20 62 79 20 7a  so division by z
62a0: 65 72 6f 0a 20 20 20 20 2a 2a 20 69 73 20 6e 65  ero.    ** is ne
62b0: 76 65 72 20 70 6f 73 73 69 62 6c 65 2e 0a 20 20  ver possible..  
62c0: 20 20 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33    */.    sqlite3
62d0: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
62e0: 5f 53 43 6f 70 79 2c 20 69 4d 65 6d 2c 20 72 65  _SCopy, iMem, re
62f0: 67 53 74 61 74 31 29 3b 0a 20 20 20 20 69 66 28  gStat1);.    if(
6300: 20 6a 5a 65 72 6f 52 6f 77 73 3c 30 20 29 7b 0a   jZeroRows<0 ){.
6310: 20 20 20 20 20 20 6a 5a 65 72 6f 52 6f 77 73 20        jZeroRows 
6320: 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64  = sqlite3VdbeAdd
6330: 4f 70 31 28 76 2c 20 4f 50 5f 49 66 4e 6f 74 2c  Op1(v, OP_IfNot,
6340: 20 69 4d 65 6d 29 3b 0a 20 20 20 20 7d 0a 20 20   iMem);.    }.  
6350: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 43 6f    for(i=0; i<nCo
6360: 6c 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 73  l; i++){.      s
6370: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 34  qlite3VdbeAddOp4
6380: 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20  (v, OP_String8, 
6390: 30 2c 20 72 65 67 54 65 6d 70 2c 20 30 2c 20 22  0, regTemp, 0, "
63a0: 20 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71   ", 0);.      sq
63b0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33 28  lite3VdbeAddOp3(
63c0: 76 2c 20 4f 50 5f 43 6f 6e 63 61 74 2c 20 72 65  v, OP_Concat, re
63d0: 67 54 65 6d 70 2c 20 72 65 67 53 74 61 74 31 2c  gTemp, regStat1,
63e0: 20 72 65 67 53 74 61 74 31 29 3b 0a 20 20 20 20   regStat1);.    
63f0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
6400: 4f 70 33 28 76 2c 20 4f 50 5f 41 64 64 2c 20 69  Op3(v, OP_Add, i
6410: 4d 65 6d 2c 20 69 4d 65 6d 2b 69 2b 31 2c 20 72  Mem, iMem+i+1, r
6420: 65 67 54 65 6d 70 29 3b 0a 20 20 20 20 20 20 73  egTemp);.      s
6430: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
6440: 28 76 2c 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 72  (v, OP_AddImm, r
6450: 65 67 54 65 6d 70 2c 20 2d 31 29 3b 0a 20 20 20  egTemp, -1);.   
6460: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
6470: 64 4f 70 33 28 76 2c 20 4f 50 5f 44 69 76 69 64  dOp3(v, OP_Divid
6480: 65 2c 20 69 4d 65 6d 2b 69 2b 31 2c 20 72 65 67  e, iMem+i+1, reg
6490: 54 65 6d 70 2c 20 72 65 67 54 65 6d 70 29 3b 0a  Temp, regTemp);.
64a0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
64b0: 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f 54 6f  eAddOp1(v, OP_To
64c0: 49 6e 74 2c 20 72 65 67 54 65 6d 70 29 3b 0a 20  Int, regTemp);. 
64d0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
64e0: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 43 6f 6e  AddOp3(v, OP_Con
64f0: 63 61 74 2c 20 72 65 67 54 65 6d 70 2c 20 72 65  cat, regTemp, re
6500: 67 53 74 61 74 31 2c 20 72 65 67 53 74 61 74 31  gStat1, regStat1
6510: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c  );.    }.    sql
6520: 69 74 65 33 56 64 62 65 41 64 64 4f 70 34 28 76  ite3VdbeAddOp4(v
6530: 2c 20 4f 50 5f 4d 61 6b 65 52 65 63 6f 72 64 2c  , OP_MakeRecord,
6540: 20 72 65 67 54 61 62 6e 61 6d 65 2c 20 33 2c 20   regTabname, 3, 
6550: 72 65 67 52 65 63 2c 20 22 61 61 61 22 2c 20 30  regRec, "aaa", 0
6560: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
6570: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 4e  beAddOp2(v, OP_N
6580: 65 77 52 6f 77 69 64 2c 20 69 53 74 61 74 43 75  ewRowid, iStatCu
6590: 72 2c 20 72 65 67 4e 65 77 52 6f 77 69 64 29 3b  r, regNewRowid);
65a0: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
65b0: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 49 6e 73  AddOp3(v, OP_Ins
65c0: 65 72 74 2c 20 69 53 74 61 74 43 75 72 2c 20 72  ert, iStatCur, r
65d0: 65 67 52 65 63 2c 20 72 65 67 4e 65 77 52 6f 77  egRec, regNewRow
65e0: 69 64 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  id);.    sqlite3
65f0: 56 64 62 65 43 68 61 6e 67 65 50 35 28 76 2c 20  VdbeChangeP5(v, 
6600: 4f 50 46 4c 41 47 5f 41 50 50 45 4e 44 29 3b 0a  OPFLAG_APPEND);.
6610: 20 20 7d 0a 0a 20 20 2f 2a 20 49 66 20 74 68 65    }..  /* If the
6620: 20 74 61 62 6c 65 20 68 61 73 20 6e 6f 20 69 6e   table has no in
6630: 64 69 63 65 73 2c 20 63 72 65 61 74 65 20 61 20  dices, create a 
6640: 73 69 6e 67 6c 65 20 73 71 6c 69 74 65 5f 73 74  single sqlite_st
6650: 61 74 31 20 65 6e 74 72 79 0a 20 20 2a 2a 20 63  at1 entry.  ** c
6660: 6f 6e 74 61 69 6e 69 6e 67 20 4e 55 4c 4c 20 61  ontaining NULL a
6670: 73 20 74 68 65 20 69 6e 64 65 78 20 6e 61 6d 65  s the index name
6680: 20 61 6e 64 20 74 68 65 20 72 6f 77 20 63 6f 75   and the row cou
6690: 6e 74 20 61 73 20 74 68 65 20 63 6f 6e 74 65 6e  nt as the conten
66a0: 74 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 70 54  t..  */.  if( pT
66b0: 61 62 2d 3e 70 49 6e 64 65 78 3d 3d 30 20 29 7b  ab->pIndex==0 ){
66c0: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
66d0: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4f 70 65  AddOp3(v, OP_Ope
66e0: 6e 52 65 61 64 2c 20 69 49 64 78 43 75 72 2c 20  nRead, iIdxCur, 
66f0: 70 54 61 62 2d 3e 74 6e 75 6d 2c 20 69 44 62 29  pTab->tnum, iDb)
6700: 3b 0a 20 20 20 20 56 64 62 65 43 6f 6d 6d 65 6e  ;.    VdbeCommen
6710: 74 28 28 76 2c 20 22 25 73 22 2c 20 70 54 61 62  t((v, "%s", pTab
6720: 2d 3e 7a 4e 61 6d 65 29 29 3b 0a 20 20 20 20 73  ->zName));.    s
6730: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
6740: 28 76 2c 20 4f 50 5f 43 6f 75 6e 74 2c 20 69 49  (v, OP_Count, iI
6750: 64 78 43 75 72 2c 20 72 65 67 53 74 61 74 31 29  dxCur, regStat1)
6760: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
6770: 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f 43 6c  eAddOp1(v, OP_Cl
6780: 6f 73 65 2c 20 69 49 64 78 43 75 72 29 3b 0a 20  ose, iIdxCur);. 
6790: 20 20 20 6a 5a 65 72 6f 52 6f 77 73 20 3d 20 73     jZeroRows = s
67a0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 31  qlite3VdbeAddOp1
67b0: 28 76 2c 20 4f 50 5f 49 66 4e 6f 74 2c 20 72 65  (v, OP_IfNot, re
67c0: 67 53 74 61 74 31 29 3b 0a 20 20 7d 65 6c 73 65  gStat1);.  }else
67d0: 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  {.    sqlite3Vdb
67e0: 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 6a 5a 65  eJumpHere(v, jZe
67f0: 72 6f 52 6f 77 73 29 3b 0a 20 20 20 20 6a 5a 65  roRows);.    jZe
6800: 72 6f 52 6f 77 73 20 3d 20 73 71 6c 69 74 65 33  roRows = sqlite3
6810: 56 64 62 65 41 64 64 4f 70 30 28 76 2c 20 4f 50  VdbeAddOp0(v, OP
6820: 5f 47 6f 74 6f 29 3b 0a 20 20 7d 0a 20 20 73 71  _Goto);.  }.  sq
6830: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
6840: 76 2c 20 4f 50 5f 4e 75 6c 6c 2c 20 30 2c 20 72  v, OP_Null, 0, r
6850: 65 67 49 64 78 6e 61 6d 65 29 3b 0a 20 20 73 71  egIdxname);.  sq
6860: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 34 28  lite3VdbeAddOp4(
6870: 76 2c 20 4f 50 5f 4d 61 6b 65 52 65 63 6f 72 64  v, OP_MakeRecord
6880: 2c 20 72 65 67 54 61 62 6e 61 6d 65 2c 20 33 2c  , regTabname, 3,
6890: 20 72 65 67 52 65 63 2c 20 22 61 61 61 22 2c 20   regRec, "aaa", 
68a0: 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62  0);.  sqlite3Vdb
68b0: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 4e 65  eAddOp2(v, OP_Ne
68c0: 77 52 6f 77 69 64 2c 20 69 53 74 61 74 43 75 72  wRowid, iStatCur
68d0: 2c 20 72 65 67 4e 65 77 52 6f 77 69 64 29 3b 0a  , regNewRowid);.
68e0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
68f0: 4f 70 33 28 76 2c 20 4f 50 5f 49 6e 73 65 72 74  Op3(v, OP_Insert
6900: 2c 20 69 53 74 61 74 43 75 72 2c 20 72 65 67 52  , iStatCur, regR
6910: 65 63 2c 20 72 65 67 4e 65 77 52 6f 77 69 64 29  ec, regNewRowid)
6920: 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 43  ;.  sqlite3VdbeC
6930: 68 61 6e 67 65 50 35 28 76 2c 20 4f 50 46 4c 41  hangeP5(v, OPFLA
6940: 47 5f 41 50 50 45 4e 44 29 3b 0a 20 20 69 66 28  G_APPEND);.  if(
6950: 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 3c 72 65   pParse->nMem<re
6960: 67 52 65 63 20 29 20 70 50 61 72 73 65 2d 3e 6e  gRec ) pParse->n
6970: 4d 65 6d 20 3d 20 72 65 67 52 65 63 3b 0a 20 20  Mem = regRec;.  
6980: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
6990: 65 72 65 28 76 2c 20 6a 5a 65 72 6f 52 6f 77 73  ere(v, jZeroRows
69a0: 29 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e  );.}.../*.** Gen
69b0: 65 72 61 74 65 20 63 6f 64 65 20 74 68 61 74 20  erate code that 
69c0: 77 69 6c 6c 20 63 61 75 73 65 20 74 68 65 20 6d  will cause the m
69d0: 6f 73 74 20 72 65 63 65 6e 74 20 69 6e 64 65 78  ost recent index
69e0: 20 61 6e 61 6c 79 73 69 73 20 74 6f 0a 2a 2a 20   analysis to.** 
69f0: 62 65 20 6c 6f 61 64 65 64 20 69 6e 74 6f 20 69  be loaded into i
6a00: 6e 74 65 72 6e 61 6c 20 68 61 73 68 20 74 61 62  nternal hash tab
6a10: 6c 65 73 20 77 68 65 72 65 20 69 73 20 63 61 6e  les where is can
6a20: 20 62 65 20 75 73 65 64 2e 0a 2a 2f 0a 73 74 61   be used..*/.sta
6a30: 74 69 63 20 76 6f 69 64 20 6c 6f 61 64 41 6e 61  tic void loadAna
6a40: 6c 79 73 69 73 28 50 61 72 73 65 20 2a 70 50 61  lysis(Parse *pPa
6a50: 72 73 65 2c 20 69 6e 74 20 69 44 62 29 7b 0a 20  rse, int iDb){. 
6a60: 20 56 64 62 65 20 2a 76 20 3d 20 73 71 6c 69 74   Vdbe *v = sqlit
6a70: 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73 65  e3GetVdbe(pParse
6a80: 29 3b 0a 20 20 69 66 28 20 76 20 29 7b 0a 20 20  );.  if( v ){.  
6a90: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
6aa0: 4f 70 31 28 76 2c 20 4f 50 5f 4c 6f 61 64 41 6e  Op1(v, OP_LoadAn
6ab0: 61 6c 79 73 69 73 2c 20 69 44 62 29 3b 0a 20 20  alysis, iDb);.  
6ac0: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72  }.}../*.** Gener
6ad0: 61 74 65 20 63 6f 64 65 20 74 68 61 74 20 77 69  ate code that wi
6ae0: 6c 6c 20 64 6f 20 61 6e 20 61 6e 61 6c 79 73 69  ll do an analysi
6af0: 73 20 6f 66 20 61 6e 20 65 6e 74 69 72 65 20 64  s of an entire d
6b00: 61 74 61 62 61 73 65 0a 2a 2f 0a 73 74 61 74 69  atabase.*/.stati
6b10: 63 20 76 6f 69 64 20 61 6e 61 6c 79 7a 65 44 61  c void analyzeDa
6b20: 74 61 62 61 73 65 28 50 61 72 73 65 20 2a 70 50  tabase(Parse *pP
6b30: 61 72 73 65 2c 20 69 6e 74 20 69 44 62 29 7b 0a  arse, int iDb){.
6b40: 20 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20    sqlite3 *db = 
6b50: 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 53 63  pParse->db;.  Sc
6b60: 68 65 6d 61 20 2a 70 53 63 68 65 6d 61 20 3d 20  hema *pSchema = 
6b70: 64 62 2d 3e 61 44 62 5b 69 44 62 5d 2e 70 53 63  db->aDb[iDb].pSc
6b80: 68 65 6d 61 3b 20 20 20 20 2f 2a 20 53 63 68 65  hema;    /* Sche
6b90: 6d 61 20 6f 66 20 64 61 74 61 62 61 73 65 20 69  ma of database i
6ba0: 44 62 20 2a 2f 0a 20 20 48 61 73 68 45 6c 65 6d  Db */.  HashElem
6bb0: 20 2a 6b 3b 0a 20 20 69 6e 74 20 69 53 74 61 74   *k;.  int iStat
6bc0: 43 75 72 3b 0a 20 20 69 6e 74 20 69 4d 65 6d 3b  Cur;.  int iMem;
6bd0: 0a 0a 20 20 73 71 6c 69 74 65 33 42 65 67 69 6e  ..  sqlite3Begin
6be0: 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e 28 70  WriteOperation(p
6bf0: 50 61 72 73 65 2c 20 30 2c 20 69 44 62 29 3b 0a  Parse, 0, iDb);.
6c00: 20 20 69 53 74 61 74 43 75 72 20 3d 20 70 50 61    iStatCur = pPa
6c10: 72 73 65 2d 3e 6e 54 61 62 3b 0a 20 20 70 50 61  rse->nTab;.  pPa
6c20: 72 73 65 2d 3e 6e 54 61 62 20 2b 3d 20 33 3b 0a  rse->nTab += 3;.
6c30: 20 20 6f 70 65 6e 53 74 61 74 54 61 62 6c 65 28    openStatTable(
6c40: 70 50 61 72 73 65 2c 20 69 44 62 2c 20 69 53 74  pParse, iDb, iSt
6c50: 61 74 43 75 72 2c 20 30 2c 20 30 29 3b 0a 20 20  atCur, 0, 0);.  
6c60: 69 4d 65 6d 20 3d 20 70 50 61 72 73 65 2d 3e 6e  iMem = pParse->n
6c70: 4d 65 6d 2b 31 3b 0a 20 20 61 73 73 65 72 74 28  Mem+1;.  assert(
6c80: 20 73 71 6c 69 74 65 33 53 63 68 65 6d 61 4d 75   sqlite3SchemaMu
6c90: 74 65 78 48 65 6c 64 28 64 62 2c 20 69 44 62 2c  texHeld(db, iDb,
6ca0: 20 30 29 20 29 3b 0a 20 20 66 6f 72 28 6b 3d 73   0) );.  for(k=s
6cb0: 71 6c 69 74 65 48 61 73 68 46 69 72 73 74 28 26  qliteHashFirst(&
6cc0: 70 53 63 68 65 6d 61 2d 3e 74 62 6c 48 61 73 68  pSchema->tblHash
6cd0: 29 3b 20 6b 3b 20 6b 3d 73 71 6c 69 74 65 48 61  ); k; k=sqliteHa
6ce0: 73 68 4e 65 78 74 28 6b 29 29 7b 0a 20 20 20 20  shNext(k)){.    
6cf0: 54 61 62 6c 65 20 2a 70 54 61 62 20 3d 20 28 54  Table *pTab = (T
6d00: 61 62 6c 65 2a 29 73 71 6c 69 74 65 48 61 73 68  able*)sqliteHash
6d10: 44 61 74 61 28 6b 29 3b 0a 20 20 20 20 61 6e 61  Data(k);.    ana
6d20: 6c 79 7a 65 4f 6e 65 54 61 62 6c 65 28 70 50 61  lyzeOneTable(pPa
6d30: 72 73 65 2c 20 70 54 61 62 2c 20 30 2c 20 69 53  rse, pTab, 0, iS
6d40: 74 61 74 43 75 72 2c 20 69 4d 65 6d 29 3b 0a 20  tatCur, iMem);. 
6d50: 20 7d 0a 20 20 6c 6f 61 64 41 6e 61 6c 79 73 69   }.  loadAnalysi
6d60: 73 28 70 50 61 72 73 65 2c 20 69 44 62 29 3b 0a  s(pParse, iDb);.
6d70: 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74  }../*.** Generat
6d80: 65 20 63 6f 64 65 20 74 68 61 74 20 77 69 6c 6c  e code that will
6d90: 20 64 6f 20 61 6e 20 61 6e 61 6c 79 73 69 73 20   do an analysis 
6da0: 6f 66 20 61 20 73 69 6e 67 6c 65 20 74 61 62 6c  of a single tabl
6db0: 65 20 69 6e 0a 2a 2a 20 61 20 64 61 74 61 62 61  e in.** a databa
6dc0: 73 65 2e 20 20 49 66 20 70 4f 6e 6c 79 49 64 78  se.  If pOnlyIdx
6dd0: 20 69 73 20 6e 6f 74 20 4e 55 4c 4c 20 74 68 65   is not NULL the
6de0: 6e 20 69 74 20 69 73 20 61 20 73 69 6e 67 6c 65  n it is a single
6df0: 20 69 6e 64 65 78 0a 2a 2a 20 69 6e 20 70 54 61   index.** in pTa
6e00: 62 20 74 68 61 74 20 73 68 6f 75 6c 64 20 62 65  b that should be
6e10: 20 61 6e 61 6c 79 7a 65 64 2e 0a 2a 2f 0a 73 74   analyzed..*/.st
6e20: 61 74 69 63 20 76 6f 69 64 20 61 6e 61 6c 79 7a  atic void analyz
6e30: 65 54 61 62 6c 65 28 50 61 72 73 65 20 2a 70 50  eTable(Parse *pP
6e40: 61 72 73 65 2c 20 54 61 62 6c 65 20 2a 70 54 61  arse, Table *pTa
6e50: 62 2c 20 49 6e 64 65 78 20 2a 70 4f 6e 6c 79 49  b, Index *pOnlyI
6e60: 64 78 29 7b 0a 20 20 69 6e 74 20 69 44 62 3b 0a  dx){.  int iDb;.
6e70: 20 20 69 6e 74 20 69 53 74 61 74 43 75 72 3b 0a    int iStatCur;.
6e80: 0a 20 20 61 73 73 65 72 74 28 20 70 54 61 62 21  .  assert( pTab!
6e90: 3d 30 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20  =0 );.  assert( 
6ea0: 73 71 6c 69 74 65 33 42 74 72 65 65 48 6f 6c 64  sqlite3BtreeHold
6eb0: 73 41 6c 6c 4d 75 74 65 78 65 73 28 70 50 61 72  sAllMutexes(pPar
6ec0: 73 65 2d 3e 64 62 29 20 29 3b 0a 20 20 69 44 62  se->db) );.  iDb
6ed0: 20 3d 20 73 71 6c 69 74 65 33 53 63 68 65 6d 61   = sqlite3Schema
6ee0: 54 6f 49 6e 64 65 78 28 70 50 61 72 73 65 2d 3e  ToIndex(pParse->
6ef0: 64 62 2c 20 70 54 61 62 2d 3e 70 53 63 68 65 6d  db, pTab->pSchem
6f00: 61 29 3b 0a 20 20 73 71 6c 69 74 65 33 42 65 67  a);.  sqlite3Beg
6f10: 69 6e 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e  inWriteOperation
6f20: 28 70 50 61 72 73 65 2c 20 30 2c 20 69 44 62 29  (pParse, 0, iDb)
6f30: 3b 0a 20 20 69 53 74 61 74 43 75 72 20 3d 20 70  ;.  iStatCur = p
6f40: 50 61 72 73 65 2d 3e 6e 54 61 62 3b 0a 20 20 70  Parse->nTab;.  p
6f50: 50 61 72 73 65 2d 3e 6e 54 61 62 20 2b 3d 20 33  Parse->nTab += 3
6f60: 3b 0a 20 20 69 66 28 20 70 4f 6e 6c 79 49 64 78  ;.  if( pOnlyIdx
6f70: 20 29 7b 0a 20 20 20 20 6f 70 65 6e 53 74 61 74   ){.    openStat
6f80: 54 61 62 6c 65 28 70 50 61 72 73 65 2c 20 69 44  Table(pParse, iD
6f90: 62 2c 20 69 53 74 61 74 43 75 72 2c 20 70 4f 6e  b, iStatCur, pOn
6fa0: 6c 79 49 64 78 2d 3e 7a 4e 61 6d 65 2c 20 22 69  lyIdx->zName, "i
6fb0: 64 78 22 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20  dx");.  }else{. 
6fc0: 20 20 20 6f 70 65 6e 53 74 61 74 54 61 62 6c 65     openStatTable
6fd0: 28 70 50 61 72 73 65 2c 20 69 44 62 2c 20 69 53  (pParse, iDb, iS
6fe0: 74 61 74 43 75 72 2c 20 70 54 61 62 2d 3e 7a 4e  tatCur, pTab->zN
6ff0: 61 6d 65 2c 20 22 74 62 6c 22 29 3b 0a 20 20 7d  ame, "tbl");.  }
7000: 0a 20 20 61 6e 61 6c 79 7a 65 4f 6e 65 54 61 62  .  analyzeOneTab
7010: 6c 65 28 70 50 61 72 73 65 2c 20 70 54 61 62 2c  le(pParse, pTab,
7020: 20 70 4f 6e 6c 79 49 64 78 2c 20 69 53 74 61 74   pOnlyIdx, iStat
7030: 43 75 72 2c 20 70 50 61 72 73 65 2d 3e 6e 4d 65  Cur, pParse->nMe
7040: 6d 2b 31 29 3b 0a 20 20 6c 6f 61 64 41 6e 61 6c  m+1);.  loadAnal
7050: 79 73 69 73 28 70 50 61 72 73 65 2c 20 69 44 62  ysis(pParse, iDb
7060: 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65  );.}../*.** Gene
7070: 72 61 74 65 20 63 6f 64 65 20 66 6f 72 20 74 68  rate code for th
7080: 65 20 41 4e 41 4c 59 5a 45 20 63 6f 6d 6d 61 6e  e ANALYZE comman
7090: 64 2e 20 20 54 68 65 20 70 61 72 73 65 72 20 63  d.  The parser c
70a0: 61 6c 6c 73 20 74 68 69 73 20 72 6f 75 74 69 6e  alls this routin
70b0: 65 0a 2a 2a 20 77 68 65 6e 20 69 74 20 72 65 63  e.** when it rec
70c0: 6f 67 6e 69 7a 65 73 20 61 6e 20 41 4e 41 4c 59  ognizes an ANALY
70d0: 5a 45 20 63 6f 6d 6d 61 6e 64 2e 0a 2a 2a 0a 2a  ZE command..**.*
70e0: 2a 20 20 20 20 20 20 20 20 41 4e 41 4c 59 5a 45  *        ANALYZE
70f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7100: 20 20 20 20 20 20 20 20 20 20 20 20 2d 2d 20 31              -- 1
7110: 0a 2a 2a 20 20 20 20 20 20 20 20 41 4e 41 4c 59  .**        ANALY
7120: 5a 45 20 20 3c 64 61 74 61 62 61 73 65 3e 20 20  ZE  <database>  
7130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2d 2d                --
7140: 20 32 0a 2a 2a 20 20 20 20 20 20 20 20 41 4e 41   2.**        ANA
7150: 4c 59 5a 45 20 20 3f 3c 64 61 74 61 62 61 73 65  LYZE  ?<database
7160: 3e 2e 3f 3c 74 61 62 6c 65 6e 61 6d 65 3e 20 20  >.?<tablename>  
7170: 2d 2d 20 33 0a 2a 2a 0a 2a 2a 20 46 6f 72 6d 20  -- 3.**.** Form 
7180: 31 20 63 61 75 73 65 73 20 61 6c 6c 20 69 6e 64  1 causes all ind
7190: 69 63 65 73 20 69 6e 20 61 6c 6c 20 61 74 74 61  ices in all atta
71a0: 63 68 65 64 20 64 61 74 61 62 61 73 65 73 20 74  ched databases t
71b0: 6f 20 62 65 20 61 6e 61 6c 79 7a 65 64 2e 0a 2a  o be analyzed..*
71c0: 2a 20 46 6f 72 6d 20 32 20 61 6e 61 6c 79 7a 65  * Form 2 analyze
71d0: 73 20 61 6c 6c 20 69 6e 64 69 63 65 73 20 74 68  s all indices th
71e0: 65 20 73 69 6e 67 6c 65 20 64 61 74 61 62 61 73  e single databas
71f0: 65 20 6e 61 6d 65 64 2e 0a 2a 2a 20 46 6f 72 6d  e named..** Form
7200: 20 33 20 61 6e 61 6c 79 7a 65 73 20 61 6c 6c 20   3 analyzes all 
7210: 69 6e 64 69 63 65 73 20 61 73 73 6f 63 69 61 74  indices associat
7220: 65 64 20 77 69 74 68 20 74 68 65 20 6e 61 6d 65  ed with the name
7230: 64 20 74 61 62 6c 65 2e 0a 2a 2f 0a 76 6f 69 64  d table..*/.void
7240: 20 73 71 6c 69 74 65 33 41 6e 61 6c 79 7a 65 28   sqlite3Analyze(
7250: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 54  Parse *pParse, T
7260: 6f 6b 65 6e 20 2a 70 4e 61 6d 65 31 2c 20 54 6f  oken *pName1, To
7270: 6b 65 6e 20 2a 70 4e 61 6d 65 32 29 7b 0a 20 20  ken *pName2){.  
7280: 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70 50  sqlite3 *db = pP
7290: 61 72 73 65 2d 3e 64 62 3b 0a 20 20 69 6e 74 20  arse->db;.  int 
72a0: 69 44 62 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20  iDb;.  int i;.  
72b0: 63 68 61 72 20 2a 7a 2c 20 2a 7a 44 62 3b 0a 20  char *z, *zDb;. 
72c0: 20 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a 20 20   Table *pTab;.  
72d0: 49 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20 20 54  Index *pIdx;.  T
72e0: 6f 6b 65 6e 20 2a 70 54 61 62 6c 65 4e 61 6d 65  oken *pTableName
72f0: 3b 0a 0a 20 20 2f 2a 20 52 65 61 64 20 74 68 65  ;..  /* Read the
7300: 20 64 61 74 61 62 61 73 65 20 73 63 68 65 6d 61   database schema
7310: 2e 20 49 66 20 61 6e 20 65 72 72 6f 72 20 6f 63  . If an error oc
7320: 63 75 72 73 2c 20 6c 65 61 76 65 20 61 6e 20 65  curs, leave an e
7330: 72 72 6f 72 20 6d 65 73 73 61 67 65 0a 20 20 2a  rror message.  *
7340: 2a 20 61 6e 64 20 63 6f 64 65 20 69 6e 20 70 50  * and code in pP
7350: 61 72 73 65 20 61 6e 64 20 72 65 74 75 72 6e 20  arse and return 
7360: 4e 55 4c 4c 2e 20 2a 2f 0a 20 20 61 73 73 65 72  NULL. */.  asser
7370: 74 28 20 73 71 6c 69 74 65 33 42 74 72 65 65 48  t( sqlite3BtreeH
7380: 6f 6c 64 73 41 6c 6c 4d 75 74 65 78 65 73 28 70  oldsAllMutexes(p
7390: 50 61 72 73 65 2d 3e 64 62 29 20 29 3b 0a 20 20  Parse->db) );.  
73a0: 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 21 3d 73  if( SQLITE_OK!=s
73b0: 71 6c 69 74 65 33 52 65 61 64 53 63 68 65 6d 61  qlite3ReadSchema
73c0: 28 70 50 61 72 73 65 29 20 29 7b 0a 20 20 20 20  (pParse) ){.    
73d0: 72 65 74 75 72 6e 3b 0a 20 20 7d 0a 0a 20 20 61  return;.  }..  a
73e0: 73 73 65 72 74 28 20 70 4e 61 6d 65 32 21 3d 30  ssert( pName2!=0
73f0: 20 7c 7c 20 70 4e 61 6d 65 31 3d 3d 30 20 29 3b   || pName1==0 );
7400: 0a 20 20 69 66 28 20 70 4e 61 6d 65 31 3d 3d 30  .  if( pName1==0
7410: 20 29 7b 0a 20 20 20 20 2f 2a 20 46 6f 72 6d 20   ){.    /* Form 
7420: 31 3a 20 20 41 6e 61 6c 79 7a 65 20 65 76 65 72  1:  Analyze ever
7430: 79 74 68 69 6e 67 20 2a 2f 0a 20 20 20 20 66 6f  ything */.    fo
7440: 72 28 69 3d 30 3b 20 69 3c 64 62 2d 3e 6e 44 62  r(i=0; i<db->nDb
7450: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 69 66  ; i++){.      if
7460: 28 20 69 3d 3d 31 20 29 20 63 6f 6e 74 69 6e 75  ( i==1 ) continu
7470: 65 3b 20 20 2f 2a 20 44 6f 20 6e 6f 74 20 61 6e  e;  /* Do not an
7480: 61 6c 79 7a 65 20 74 68 65 20 54 45 4d 50 20 64  alyze the TEMP d
7490: 61 74 61 62 61 73 65 20 2a 2f 0a 20 20 20 20 20  atabase */.     
74a0: 20 61 6e 61 6c 79 7a 65 44 61 74 61 62 61 73 65   analyzeDatabase
74b0: 28 70 50 61 72 73 65 2c 20 69 29 3b 0a 20 20 20  (pParse, i);.   
74c0: 20 7d 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 70   }.  }else if( p
74d0: 4e 61 6d 65 32 2d 3e 6e 3d 3d 30 20 29 7b 0a 20  Name2->n==0 ){. 
74e0: 20 20 20 2f 2a 20 46 6f 72 6d 20 32 3a 20 20 41     /* Form 2:  A
74f0: 6e 61 6c 79 7a 65 20 74 68 65 20 64 61 74 61 62  nalyze the datab
7500: 61 73 65 20 6f 72 20 74 61 62 6c 65 20 6e 61 6d  ase or table nam
7510: 65 64 20 2a 2f 0a 20 20 20 20 69 44 62 20 3d 20  ed */.    iDb = 
7520: 73 71 6c 69 74 65 33 46 69 6e 64 44 62 28 64 62  sqlite3FindDb(db
7530: 2c 20 70 4e 61 6d 65 31 29 3b 0a 20 20 20 20 69  , pName1);.    i
7540: 66 28 20 69 44 62 3e 3d 30 20 29 7b 0a 20 20 20  f( iDb>=0 ){.   
7550: 20 20 20 61 6e 61 6c 79 7a 65 44 61 74 61 62 61     analyzeDataba
7560: 73 65 28 70 50 61 72 73 65 2c 20 69 44 62 29 3b  se(pParse, iDb);
7570: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
7580: 20 20 7a 20 3d 20 73 71 6c 69 74 65 33 4e 61 6d    z = sqlite3Nam
7590: 65 46 72 6f 6d 54 6f 6b 65 6e 28 64 62 2c 20 70  eFromToken(db, p
75a0: 4e 61 6d 65 31 29 3b 0a 20 20 20 20 20 20 69 66  Name1);.      if
75b0: 28 20 7a 20 29 7b 0a 20 20 20 20 20 20 20 20 69  ( z ){.        i
75c0: 66 28 20 28 70 49 64 78 20 3d 20 73 71 6c 69 74  f( (pIdx = sqlit
75d0: 65 33 46 69 6e 64 49 6e 64 65 78 28 64 62 2c 20  e3FindIndex(db, 
75e0: 7a 2c 20 30 29 29 21 3d 30 20 29 7b 0a 20 20 20  z, 0))!=0 ){.   
75f0: 20 20 20 20 20 20 20 61 6e 61 6c 79 7a 65 54 61         analyzeTa
7600: 62 6c 65 28 70 50 61 72 73 65 2c 20 70 49 64 78  ble(pParse, pIdx
7610: 2d 3e 70 54 61 62 6c 65 2c 20 70 49 64 78 29 3b  ->pTable, pIdx);
7620: 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 20 69  .        }else i
7630: 66 28 20 28 70 54 61 62 20 3d 20 73 71 6c 69 74  f( (pTab = sqlit
7640: 65 33 4c 6f 63 61 74 65 54 61 62 6c 65 28 70 50  e3LocateTable(pP
7650: 61 72 73 65 2c 20 30 2c 20 7a 2c 20 30 29 29 21  arse, 0, z, 0))!
7660: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
7670: 61 6e 61 6c 79 7a 65 54 61 62 6c 65 28 70 50 61  analyzeTable(pPa
7680: 72 73 65 2c 20 70 54 61 62 2c 20 30 29 3b 0a 20  rse, pTab, 0);. 
7690: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
76a0: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28 64   sqlite3DbFree(d
76b0: 62 2c 20 7a 29 3b 0a 20 20 20 20 20 20 7d 0a 20  b, z);.      }. 
76c0: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 7b 0a 20 20     }.  }else{.  
76d0: 20 20 2f 2a 20 46 6f 72 6d 20 33 3a 20 41 6e 61    /* Form 3: Ana
76e0: 6c 79 7a 65 20 74 68 65 20 66 75 6c 6c 79 20 71  lyze the fully q
76f0: 75 61 6c 69 66 69 65 64 20 74 61 62 6c 65 20 6e  ualified table n
7700: 61 6d 65 20 2a 2f 0a 20 20 20 20 69 44 62 20 3d  ame */.    iDb =
7710: 20 73 71 6c 69 74 65 33 54 77 6f 50 61 72 74 4e   sqlite3TwoPartN
7720: 61 6d 65 28 70 50 61 72 73 65 2c 20 70 4e 61 6d  ame(pParse, pNam
7730: 65 31 2c 20 70 4e 61 6d 65 32 2c 20 26 70 54 61  e1, pName2, &pTa
7740: 62 6c 65 4e 61 6d 65 29 3b 0a 20 20 20 20 69 66  bleName);.    if
7750: 28 20 69 44 62 3e 3d 30 20 29 7b 0a 20 20 20 20  ( iDb>=0 ){.    
7760: 20 20 7a 44 62 20 3d 20 64 62 2d 3e 61 44 62 5b    zDb = db->aDb[
7770: 69 44 62 5d 2e 7a 4e 61 6d 65 3b 0a 20 20 20 20  iDb].zName;.    
7780: 20 20 7a 20 3d 20 73 71 6c 69 74 65 33 4e 61 6d    z = sqlite3Nam
7790: 65 46 72 6f 6d 54 6f 6b 65 6e 28 64 62 2c 20 70  eFromToken(db, p
77a0: 54 61 62 6c 65 4e 61 6d 65 29 3b 0a 20 20 20 20  TableName);.    
77b0: 20 20 69 66 28 20 7a 20 29 7b 0a 20 20 20 20 20    if( z ){.     
77c0: 20 20 20 69 66 28 20 28 70 49 64 78 20 3d 20 73     if( (pIdx = s
77d0: 71 6c 69 74 65 33 46 69 6e 64 49 6e 64 65 78 28  qlite3FindIndex(
77e0: 64 62 2c 20 7a 2c 20 7a 44 62 29 29 21 3d 30 20  db, z, zDb))!=0 
77f0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 61 6e 61  ){.          ana
7800: 6c 79 7a 65 54 61 62 6c 65 28 70 50 61 72 73 65  lyzeTable(pParse
7810: 2c 20 70 49 64 78 2d 3e 70 54 61 62 6c 65 2c 20  , pIdx->pTable, 
7820: 70 49 64 78 29 3b 0a 20 20 20 20 20 20 20 20 7d  pIdx);.        }
7830: 65 6c 73 65 20 69 66 28 20 28 70 54 61 62 20 3d  else if( (pTab =
7840: 20 73 71 6c 69 74 65 33 4c 6f 63 61 74 65 54 61   sqlite3LocateTa
7850: 62 6c 65 28 70 50 61 72 73 65 2c 20 30 2c 20 7a  ble(pParse, 0, z
7860: 2c 20 7a 44 62 29 29 21 3d 30 20 29 7b 0a 20 20  , zDb))!=0 ){.  
7870: 20 20 20 20 20 20 20 20 61 6e 61 6c 79 7a 65 54          analyzeT
7880: 61 62 6c 65 28 70 50 61 72 73 65 2c 20 70 54 61  able(pParse, pTa
7890: 62 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 7d  b, 0);.        }
78a0: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
78b0: 44 62 46 72 65 65 28 64 62 2c 20 7a 29 3b 0a 20  DbFree(db, z);. 
78c0: 20 20 20 20 20 7d 0a 20 20 20 20 7d 20 20 20 0a       }.    }   .
78d0: 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55 73 65    }.}../*.** Use
78e0: 64 20 74 6f 20 70 61 73 73 20 69 6e 66 6f 72 6d  d to pass inform
78f0: 61 74 69 6f 6e 20 66 72 6f 6d 20 74 68 65 20 61  ation from the a
7900: 6e 61 6c 79 7a 65 72 20 72 65 61 64 65 72 20 74  nalyzer reader t
7910: 68 72 6f 75 67 68 20 74 6f 20 74 68 65 0a 2a 2a  hrough to the.**
7920: 20 63 61 6c 6c 62 61 63 6b 20 72 6f 75 74 69 6e   callback routin
7930: 65 2e 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74  e..*/.typedef st
7940: 72 75 63 74 20 61 6e 61 6c 79 73 69 73 49 6e 66  ruct analysisInf
7950: 6f 20 61 6e 61 6c 79 73 69 73 49 6e 66 6f 3b 0a  o analysisInfo;.
7960: 73 74 72 75 63 74 20 61 6e 61 6c 79 73 69 73 49  struct analysisI
7970: 6e 66 6f 20 7b 0a 20 20 73 71 6c 69 74 65 33 20  nfo {.  sqlite3 
7980: 2a 64 62 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61  *db;.  const cha
7990: 72 20 2a 7a 44 61 74 61 62 61 73 65 3b 0a 7d 3b  r *zDatabase;.};
79a0: 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 63 61 6c  ../*.** This cal
79b0: 6c 62 61 63 6b 20 69 73 20 69 6e 76 6f 6b 65 64  lback is invoked
79c0: 20 6f 6e 63 65 20 66 6f 72 20 65 61 63 68 20 69   once for each i
79d0: 6e 64 65 78 20 77 68 65 6e 20 72 65 61 64 69 6e  ndex when readin
79e0: 67 20 74 68 65 0a 2a 2a 20 73 71 6c 69 74 65 5f  g the.** sqlite_
79f0: 73 74 61 74 31 20 74 61 62 6c 65 2e 20 20 0a 2a  stat1 table.  .*
7a00: 2a 0a 2a 2a 20 20 20 20 20 61 72 67 76 5b 30 5d  *.**     argv[0]
7a10: 20 3d 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 74   = name of the t
7a20: 61 62 6c 65 0a 2a 2a 20 20 20 20 20 61 72 67 76  able.**     argv
7a30: 5b 31 5d 20 3d 20 6e 61 6d 65 20 6f 66 20 74 68  [1] = name of th
7a40: 65 20 69 6e 64 65 78 20 28 6d 69 67 68 74 20 62  e index (might b
7a50: 65 20 4e 55 4c 4c 29 0a 2a 2a 20 20 20 20 20 61  e NULL).**     a
7a60: 72 67 76 5b 32 5d 20 3d 20 72 65 73 75 6c 74 73  rgv[2] = results
7a70: 20 6f 66 20 61 6e 61 6c 79 73 69 73 20 2d 20 6f   of analysis - o
7a80: 6e 20 69 6e 74 65 67 65 72 20 66 6f 72 20 65 61  n integer for ea
7a90: 63 68 20 63 6f 6c 75 6d 6e 0a 2a 2a 0a 2a 2a 20  ch column.**.** 
7aa0: 45 6e 74 72 69 65 73 20 66 6f 72 20 77 68 69 63  Entries for whic
7ab0: 68 20 61 72 67 76 5b 31 5d 3d 3d 4e 55 4c 4c 20  h argv[1]==NULL 
7ac0: 73 69 6d 70 6c 79 20 72 65 63 6f 72 64 20 74 68  simply record th
7ad0: 65 20 6e 75 6d 62 65 72 20 6f 66 20 72 6f 77 73  e number of rows
7ae0: 20 69 6e 0a 2a 2a 20 74 68 65 20 74 61 62 6c 65   in.** the table
7af0: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
7b00: 61 6e 61 6c 79 73 69 73 4c 6f 61 64 65 72 28 76  analysisLoader(v
7b10: 6f 69 64 20 2a 70 44 61 74 61 2c 20 69 6e 74 20  oid *pData, int 
7b20: 61 72 67 63 2c 20 63 68 61 72 20 2a 2a 61 72 67  argc, char **arg
7b30: 76 2c 20 63 68 61 72 20 2a 2a 4e 6f 74 55 73 65  v, char **NotUse
7b40: 64 29 7b 0a 20 20 61 6e 61 6c 79 73 69 73 49 6e  d){.  analysisIn
7b50: 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 61 6e 61  fo *pInfo = (ana
7b60: 6c 79 73 69 73 49 6e 66 6f 2a 29 70 44 61 74 61  lysisInfo*)pData
7b70: 3b 0a 20 20 49 6e 64 65 78 20 2a 70 49 6e 64 65  ;.  Index *pInde
7b80: 78 3b 0a 20 20 54 61 62 6c 65 20 2a 70 54 61 62  x;.  Table *pTab
7b90: 6c 65 3b 0a 20 20 69 6e 74 20 69 2c 20 63 2c 20  le;.  int i, c, 
7ba0: 6e 3b 0a 20 20 74 52 6f 77 63 6e 74 20 76 3b 0a  n;.  tRowcnt v;.
7bb0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 3b    const char *z;
7bc0: 0a 0a 20 20 61 73 73 65 72 74 28 20 61 72 67 63  ..  assert( argc
7bd0: 3d 3d 33 20 29 3b 0a 20 20 55 4e 55 53 45 44 5f  ==3 );.  UNUSED_
7be0: 50 41 52 41 4d 45 54 45 52 32 28 4e 6f 74 55 73  PARAMETER2(NotUs
7bf0: 65 64 2c 20 61 72 67 63 29 3b 0a 0a 20 20 69 66  ed, argc);..  if
7c00: 28 20 61 72 67 76 3d 3d 30 20 7c 7c 20 61 72 67  ( argv==0 || arg
7c10: 76 5b 30 5d 3d 3d 30 20 7c 7c 20 61 72 67 76 5b  v[0]==0 || argv[
7c20: 32 5d 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74  2]==0 ){.    ret
7c30: 75 72 6e 20 30 3b 0a 20 20 7d 0a 20 20 70 54 61  urn 0;.  }.  pTa
7c40: 62 6c 65 20 3d 20 73 71 6c 69 74 65 33 46 69 6e  ble = sqlite3Fin
7c50: 64 54 61 62 6c 65 28 70 49 6e 66 6f 2d 3e 64 62  dTable(pInfo->db
7c60: 2c 20 61 72 67 76 5b 30 5d 2c 20 70 49 6e 66 6f  , argv[0], pInfo
7c70: 2d 3e 7a 44 61 74 61 62 61 73 65 29 3b 0a 20 20  ->zDatabase);.  
7c80: 69 66 28 20 70 54 61 62 6c 65 3d 3d 30 20 29 7b  if( pTable==0 ){
7c90: 0a 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20  .    return 0;. 
7ca0: 20 7d 0a 20 20 69 66 28 20 61 72 67 76 5b 31 5d   }.  if( argv[1]
7cb0: 20 29 7b 0a 20 20 20 20 70 49 6e 64 65 78 20 3d   ){.    pIndex =
7cc0: 20 73 71 6c 69 74 65 33 46 69 6e 64 49 6e 64 65   sqlite3FindInde
7cd0: 78 28 70 49 6e 66 6f 2d 3e 64 62 2c 20 61 72 67  x(pInfo->db, arg
7ce0: 76 5b 31 5d 2c 20 70 49 6e 66 6f 2d 3e 7a 44 61  v[1], pInfo->zDa
7cf0: 74 61 62 61 73 65 29 3b 0a 20 20 7d 65 6c 73 65  tabase);.  }else
7d00: 7b 0a 20 20 20 20 70 49 6e 64 65 78 20 3d 20 30  {.    pIndex = 0
7d10: 3b 0a 20 20 7d 0a 20 20 6e 20 3d 20 70 49 6e 64  ;.  }.  n = pInd
7d20: 65 78 20 3f 20 70 49 6e 64 65 78 2d 3e 6e 43 6f  ex ? pIndex->nCo
7d30: 6c 75 6d 6e 20 3a 20 30 3b 0a 20 20 7a 20 3d 20  lumn : 0;.  z = 
7d40: 61 72 67 76 5b 32 5d 3b 0a 20 20 66 6f 72 28 69  argv[2];.  for(i
7d50: 3d 30 3b 20 2a 7a 20 26 26 20 69 3c 3d 6e 3b 20  =0; *z && i<=n; 
7d60: 69 2b 2b 29 7b 0a 20 20 20 20 76 20 3d 20 30 3b  i++){.    v = 0;
7d70: 0a 20 20 20 20 77 68 69 6c 65 28 20 28 63 3d 7a  .    while( (c=z
7d80: 5b 30 5d 29 3e 3d 27 30 27 20 26 26 20 63 3c 3d  [0])>='0' && c<=
7d90: 27 39 27 20 29 7b 0a 20 20 20 20 20 20 76 20 3d  '9' ){.      v =
7da0: 20 76 2a 31 30 20 2b 20 63 20 2d 20 27 30 27 3b   v*10 + c - '0';
7db0: 0a 20 20 20 20 20 20 7a 2b 2b 3b 0a 20 20 20 20  .      z++;.    
7dc0: 7d 0a 20 20 20 20 69 66 28 20 69 3d 3d 30 20 29  }.    if( i==0 )
7dd0: 20 70 54 61 62 6c 65 2d 3e 6e 52 6f 77 45 73 74   pTable->nRowEst
7de0: 20 3d 20 76 3b 0a 20 20 20 20 69 66 28 20 70 49   = v;.    if( pI
7df0: 6e 64 65 78 3d 3d 30 20 29 20 62 72 65 61 6b 3b  ndex==0 ) break;
7e00: 0a 20 20 20 20 70 49 6e 64 65 78 2d 3e 61 69 52  .    pIndex->aiR
7e10: 6f 77 45 73 74 5b 69 5d 20 3d 20 76 3b 0a 20 20  owEst[i] = v;.  
7e20: 20 20 69 66 28 20 2a 7a 3d 3d 27 20 27 20 29 20    if( *z==' ' ) 
7e30: 7a 2b 2b 3b 0a 20 20 20 20 69 66 28 20 6d 65 6d  z++;.    if( mem
7e40: 63 6d 70 28 7a 2c 20 22 75 6e 6f 72 64 65 72 65  cmp(z, "unordere
7e50: 64 22 2c 20 31 30 29 3d 3d 30 20 29 7b 0a 20 20  d", 10)==0 ){.  
7e60: 20 20 20 20 70 49 6e 64 65 78 2d 3e 62 55 6e 6f      pIndex->bUno
7e70: 72 64 65 72 65 64 20 3d 20 31 3b 0a 20 20 20 20  rdered = 1;.    
7e80: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20    break;.    }. 
7e90: 20 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d   }.  return 0;.}
7ea0: 0a 0a 2f 2a 0a 2a 2a 20 49 66 20 74 68 65 20 49  ../*.** If the I
7eb0: 6e 64 65 78 2e 61 53 61 6d 70 6c 65 20 76 61 72  ndex.aSample var
7ec0: 69 61 62 6c 65 20 69 73 20 6e 6f 74 20 4e 55 4c  iable is not NUL
7ed0: 4c 2c 20 64 65 6c 65 74 65 20 74 68 65 20 61 53  L, delete the aS
7ee0: 61 6d 70 6c 65 5b 5d 20 61 72 72 61 79 0a 2a 2a  ample[] array.**
7ef0: 20 61 6e 64 20 69 74 73 20 63 6f 6e 74 65 6e 74   and its content
7f00: 73 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74  s..*/.void sqlit
7f10: 65 33 44 65 6c 65 74 65 49 6e 64 65 78 53 61 6d  e3DeleteIndexSam
7f20: 70 6c 65 73 28 73 71 6c 69 74 65 33 20 2a 64 62  ples(sqlite3 *db
7f30: 2c 20 49 6e 64 65 78 20 2a 70 49 64 78 29 7b 0a  , Index *pIdx){.
7f40: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e  #ifdef SQLITE_EN
7f50: 41 42 4c 45 5f 53 54 41 54 33 0a 20 20 69 66 28  ABLE_STAT3.  if(
7f60: 20 70 49 64 78 2d 3e 61 53 61 6d 70 6c 65 20 29   pIdx->aSample )
7f70: 7b 0a 20 20 20 20 69 6e 74 20 6a 3b 0a 20 20 20  {.    int j;.   
7f80: 20 66 6f 72 28 6a 3d 30 3b 20 6a 3c 70 49 64 78   for(j=0; j<pIdx
7f90: 2d 3e 6e 53 61 6d 70 6c 65 3b 20 6a 2b 2b 29 7b  ->nSample; j++){
7fa0: 0a 20 20 20 20 20 20 49 6e 64 65 78 53 61 6d 70  .      IndexSamp
7fb0: 6c 65 20 2a 70 20 3d 20 26 70 49 64 78 2d 3e 61  le *p = &pIdx->a
7fc0: 53 61 6d 70 6c 65 5b 6a 5d 3b 0a 20 20 20 20 20  Sample[j];.     
7fd0: 20 69 66 28 20 70 2d 3e 65 54 79 70 65 3d 3d 53   if( p->eType==S
7fe0: 51 4c 49 54 45 5f 54 45 58 54 20 7c 7c 20 70 2d  QLITE_TEXT || p-
7ff0: 3e 65 54 79 70 65 3d 3d 53 51 4c 49 54 45 5f 42  >eType==SQLITE_B
8000: 4c 4f 42 20 29 7b 0a 20 20 20 20 20 20 20 20 73  LOB ){.        s
8010: 71 6c 69 74 65 33 5f 66 72 65 65 28 70 2d 3e 75  qlite3_free(p->u
8020: 2e 7a 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  .z);.      }.   
8030: 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66   }.    sqlite3_f
8040: 72 65 65 28 70 49 64 78 2d 3e 61 53 61 6d 70 6c  ree(pIdx->aSampl
8050: 65 29 3b 0a 20 20 7d 0a 20 20 55 4e 55 53 45 44  e);.  }.  UNUSED
8060: 5f 50 41 52 41 4d 45 54 45 52 28 64 62 29 3b 0a  _PARAMETER(db);.
8070: 20 20 70 49 64 78 2d 3e 6e 53 61 6d 70 6c 65 20    pIdx->nSample 
8080: 3d 20 30 3b 0a 20 20 70 49 64 78 2d 3e 61 53 61  = 0;.  pIdx->aSa
8090: 6d 70 6c 65 20 3d 20 30 3b 0a 23 65 6c 73 65 0a  mple = 0;.#else.
80a0: 20 20 55 4e 55 53 45 44 5f 50 41 52 41 4d 45 54    UNUSED_PARAMET
80b0: 45 52 28 64 62 29 3b 0a 20 20 55 4e 55 53 45 44  ER(db);.  UNUSED
80c0: 5f 50 41 52 41 4d 45 54 45 52 28 70 49 64 78 29  _PARAMETER(pIdx)
80d0: 3b 0a 23 65 6e 64 69 66 0a 7d 0a 0a 23 69 66 64  ;.#endif.}..#ifd
80e0: 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45  ef SQLITE_ENABLE
80f0: 5f 53 54 41 54 33 0a 2f 2a 0a 2a 2a 20 4c 6f 61  _STAT3./*.** Loa
8100: 64 20 63 6f 6e 74 65 6e 74 20 66 72 6f 6d 20 74  d content from t
8110: 68 65 20 73 71 6c 69 74 65 5f 73 74 61 74 33 20  he sqlite_stat3 
8120: 74 61 62 6c 65 20 69 6e 74 6f 20 74 68 65 20 49  table into the I
8130: 6e 64 65 78 2e 61 53 61 6d 70 6c 65 5b 5d 0a 2a  ndex.aSample[].*
8140: 2a 20 61 72 72 61 79 73 20 6f 66 20 61 6c 6c 20  * arrays of all 
8150: 69 6e 64 69 63 65 73 2e 0a 2a 2f 0a 73 74 61 74  indices..*/.stat
8160: 69 63 20 69 6e 74 20 6c 6f 61 64 53 74 61 74 33  ic int loadStat3
8170: 28 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f  (sqlite3 *db, co
8180: 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 29 7b 0a  nst char *zDb){.
8190: 20 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20    int rc;       
81a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
81b0: 2f 2a 20 52 65 73 75 6c 74 20 63 6f 64 65 73 20  /* Result codes 
81c0: 66 72 6f 6d 20 73 75 62 72 6f 75 74 69 6e 65 73  from subroutines
81d0: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73 74   */.  sqlite3_st
81e0: 6d 74 20 2a 70 53 74 6d 74 20 3d 20 30 3b 20 20  mt *pStmt = 0;  
81f0: 20 20 20 20 2f 2a 20 41 6e 20 53 51 4c 20 73 74      /* An SQL st
8200: 61 74 65 6d 65 6e 74 20 62 65 69 6e 67 20 72 75  atement being ru
8210: 6e 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 53 71  n */.  char *zSq
8220: 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  l;              
8230: 20 20 20 20 20 2f 2a 20 54 65 78 74 20 6f 66 20       /* Text of 
8240: 74 68 65 20 53 51 4c 20 73 74 61 74 65 6d 65 6e  the SQL statemen
8250: 74 20 2a 2f 0a 20 20 49 6e 64 65 78 20 2a 70 50  t */.  Index *pP
8260: 72 65 76 49 64 78 20 3d 20 30 3b 20 20 20 20 20  revIdx = 0;     
8270: 20 20 20 20 20 2f 2a 20 50 72 65 76 69 6f 75 73       /* Previous
8280: 20 69 6e 64 65 78 20 69 6e 20 74 68 65 20 6c 6f   index in the lo
8290: 6f 70 20 2a 2f 0a 20 20 69 6e 74 20 69 64 78 20  op */.  int idx 
82a0: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
82b0: 20 20 20 20 20 20 2f 2a 20 73 6c 6f 74 20 69 6e        /* slot in
82c0: 20 70 49 64 78 2d 3e 61 53 61 6d 70 6c 65 5b 5d   pIdx->aSample[]
82d0: 20 66 6f 72 20 6e 65 78 74 20 73 61 6d 70 6c 65   for next sample
82e0: 20 2a 2f 0a 20 20 69 6e 74 20 65 54 79 70 65 3b   */.  int eType;
82f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8300: 20 20 20 20 2f 2a 20 44 61 74 61 74 79 70 65 20      /* Datatype 
8310: 6f 66 20 61 20 73 61 6d 70 6c 65 20 2a 2f 0a 20  of a sample */. 
8320: 20 49 6e 64 65 78 53 61 6d 70 6c 65 20 2a 70 53   IndexSample *pS
8330: 61 6d 70 6c 65 3b 20 20 20 20 20 20 20 20 20 2f  ample;         /
8340: 2a 20 41 20 73 6c 6f 74 20 69 6e 20 70 49 64 78  * A slot in pIdx
8350: 2d 3e 61 53 61 6d 70 6c 65 5b 5d 20 2a 2f 0a 0a  ->aSample[] */..
8360: 20 20 69 66 28 20 21 73 71 6c 69 74 65 33 46 69    if( !sqlite3Fi
8370: 6e 64 54 61 62 6c 65 28 64 62 2c 20 22 73 71 6c  ndTable(db, "sql
8380: 69 74 65 5f 73 74 61 74 33 22 2c 20 7a 44 62 29  ite_stat3", zDb)
8390: 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 53   ){.    return S
83a0: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 7d 0a 0a 20  QLITE_OK;.  }.. 
83b0: 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33 4d   zSql = sqlite3M
83c0: 50 72 69 6e 74 66 28 64 62 2c 20 0a 20 20 20 20  Printf(db, .    
83d0: 20 20 22 53 45 4c 45 43 54 20 69 64 78 2c 63 6f    "SELECT idx,co
83e0: 75 6e 74 28 2a 29 20 46 52 4f 4d 20 25 51 2e 73  unt(*) FROM %Q.s
83f0: 71 6c 69 74 65 5f 73 74 61 74 33 22 0a 20 20 20  qlite_stat3".   
8400: 20 20 20 22 20 47 52 4f 55 50 20 42 59 20 69 64     " GROUP BY id
8410: 78 22 2c 20 7a 44 62 29 3b 0a 20 20 69 66 28 20  x", zDb);.  if( 
8420: 21 7a 53 71 6c 20 29 7b 0a 20 20 20 20 72 65 74  !zSql ){.    ret
8430: 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d  urn SQLITE_NOMEM
8440: 3b 0a 20 20 7d 0a 20 20 72 63 20 3d 20 73 71 6c  ;.  }.  rc = sql
8450: 69 74 65 33 5f 70 72 65 70 61 72 65 28 64 62 2c  ite3_prepare(db,
8460: 20 7a 53 71 6c 2c 20 2d 31 2c 20 26 70 53 74 6d   zSql, -1, &pStm
8470: 74 2c 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33  t, 0);.  sqlite3
8480: 44 62 46 72 65 65 28 64 62 2c 20 7a 53 71 6c 29  DbFree(db, zSql)
8490: 3b 0a 20 20 69 66 28 20 72 63 20 29 20 72 65 74  ;.  if( rc ) ret
84a0: 75 72 6e 20 72 63 3b 0a 0a 20 20 77 68 69 6c 65  urn rc;..  while
84b0: 28 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70  ( sqlite3_step(p
84c0: 53 74 6d 74 29 3d 3d 53 51 4c 49 54 45 5f 52 4f  Stmt)==SQLITE_RO
84d0: 57 20 29 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a  W ){.    char *z
84e0: 49 6e 64 65 78 3b 20 20 20 2f 2a 20 49 6e 64 65  Index;   /* Inde
84f0: 78 20 6e 61 6d 65 20 2a 2f 0a 20 20 20 20 49 6e  x name */.    In
8500: 64 65 78 20 2a 70 49 64 78 3b 20 20 20 20 2f 2a  dex *pIdx;    /*
8510: 20 50 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20   Pointer to the 
8520: 69 6e 64 65 78 20 6f 62 6a 65 63 74 20 2a 2f 0a  index object */.
8530: 20 20 20 20 69 6e 74 20 6e 53 61 6d 70 6c 65 3b      int nSample;
8540: 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66      /* Number of
8550: 20 73 61 6d 70 6c 65 73 20 2a 2f 0a 0a 20 20 20   samples */..   
8560: 20 7a 49 6e 64 65 78 20 3d 20 28 63 68 61 72 20   zIndex = (char 
8570: 2a 29 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  *)sqlite3_column
8580: 5f 74 65 78 74 28 70 53 74 6d 74 2c 20 30 29 3b  _text(pStmt, 0);
8590: 0a 20 20 20 20 69 66 28 20 7a 49 6e 64 65 78 3d  .    if( zIndex=
85a0: 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20  =0 ) continue;. 
85b0: 20 20 20 6e 53 61 6d 70 6c 65 20 3d 20 73 71 6c     nSample = sql
85c0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28  ite3_column_int(
85d0: 70 53 74 6d 74 2c 20 31 29 3b 0a 20 20 20 20 69  pStmt, 1);.    i
85e0: 66 28 20 6e 53 61 6d 70 6c 65 3e 32 35 35 20 29  f( nSample>255 )
85f0: 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 70   continue;.    p
8600: 49 64 78 20 3d 20 73 71 6c 69 74 65 33 46 69 6e  Idx = sqlite3Fin
8610: 64 49 6e 64 65 78 28 64 62 2c 20 7a 49 6e 64 65  dIndex(db, zInde
8620: 78 2c 20 7a 44 62 29 3b 0a 20 20 20 20 69 66 28  x, zDb);.    if(
8630: 20 70 49 64 78 3d 3d 30 20 29 20 63 6f 6e 74 69   pIdx==0 ) conti
8640: 6e 75 65 3b 0a 20 20 20 20 61 73 73 65 72 74 28  nue;.    assert(
8650: 20 70 49 64 78 2d 3e 6e 53 61 6d 70 6c 65 3d 3d   pIdx->nSample==
8660: 30 20 29 3b 0a 20 20 20 20 70 49 64 78 2d 3e 6e  0 );.    pIdx->n
8670: 53 61 6d 70 6c 65 20 3d 20 28 75 38 29 6e 53 61  Sample = (u8)nSa
8680: 6d 70 6c 65 3b 0a 20 20 20 20 70 49 64 78 2d 3e  mple;.    pIdx->
8690: 61 53 61 6d 70 6c 65 20 3d 20 73 71 6c 69 74 65  aSample = sqlite
86a0: 33 4d 61 6c 6c 6f 63 5a 65 72 6f 28 20 6e 53 61  3MallocZero( nSa
86b0: 6d 70 6c 65 2a 73 69 7a 65 6f 66 28 49 6e 64 65  mple*sizeof(Inde
86c0: 78 53 61 6d 70 6c 65 29 20 29 3b 0a 20 20 20 20  xSample) );.    
86d0: 70 49 64 78 2d 3e 61 76 67 45 71 20 3d 20 70 49  pIdx->avgEq = pI
86e0: 64 78 2d 3e 61 69 52 6f 77 45 73 74 5b 31 5d 3b  dx->aiRowEst[1];
86f0: 0a 20 20 20 20 69 66 28 20 70 49 64 78 2d 3e 61  .    if( pIdx->a
8700: 53 61 6d 70 6c 65 3d 3d 30 20 29 7b 0a 20 20 20  Sample==0 ){.   
8710: 20 20 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69     db->mallocFai
8720: 6c 65 64 20 3d 20 31 3b 0a 20 20 20 20 20 20 73  led = 1;.      s
8730: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
8740: 70 53 74 6d 74 29 3b 0a 20 20 20 20 20 20 72 65  pStmt);.      re
8750: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45  turn SQLITE_NOME
8760: 4d 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 73  M;.    }.  }.  s
8770: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
8780: 70 53 74 6d 74 29 3b 0a 0a 20 20 7a 53 71 6c 20  pStmt);..  zSql 
8790: 3d 20 73 71 6c 69 74 65 33 4d 50 72 69 6e 74 66  = sqlite3MPrintf
87a0: 28 64 62 2c 20 0a 20 20 20 20 20 20 22 53 45 4c  (db, .      "SEL
87b0: 45 43 54 20 69 64 78 2c 6e 65 71 2c 6e 6c 74 2c  ECT idx,neq,nlt,
87c0: 6e 64 6c 74 2c 73 61 6d 70 6c 65 20 46 52 4f 4d  ndlt,sample FROM
87d0: 20 25 51 2e 73 71 6c 69 74 65 5f 73 74 61 74 33   %Q.sqlite_stat3
87e0: 22 2c 20 7a 44 62 29 3b 0a 20 20 69 66 28 20 21  ", zDb);.  if( !
87f0: 7a 53 71 6c 20 29 7b 0a 20 20 20 20 72 65 74 75  zSql ){.    retu
8800: 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b  rn SQLITE_NOMEM;
8810: 0a 20 20 7d 0a 20 20 72 63 20 3d 20 73 71 6c 69  .  }.  rc = sqli
8820: 74 65 33 5f 70 72 65 70 61 72 65 28 64 62 2c 20  te3_prepare(db, 
8830: 7a 53 71 6c 2c 20 2d 31 2c 20 26 70 53 74 6d 74  zSql, -1, &pStmt
8840: 2c 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 44  , 0);.  sqlite3D
8850: 62 46 72 65 65 28 64 62 2c 20 7a 53 71 6c 29 3b  bFree(db, zSql);
8860: 0a 20 20 69 66 28 20 72 63 20 29 20 72 65 74 75  .  if( rc ) retu
8870: 72 6e 20 72 63 3b 0a 0a 20 20 77 68 69 6c 65 28  rn rc;..  while(
8880: 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53   sqlite3_step(pS
8890: 74 6d 74 29 3d 3d 53 51 4c 49 54 45 5f 52 4f 57  tmt)==SQLITE_ROW
88a0: 20 29 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 49   ){.    char *zI
88b0: 6e 64 65 78 3b 20 20 20 2f 2a 20 49 6e 64 65 78  ndex;   /* Index
88c0: 20 6e 61 6d 65 20 2a 2f 0a 20 20 20 20 49 6e 64   name */.    Ind
88d0: 65 78 20 2a 70 49 64 78 3b 20 20 20 20 2f 2a 20  ex *pIdx;    /* 
88e0: 50 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 69  Pointer to the i
88f0: 6e 64 65 78 20 6f 62 6a 65 63 74 20 2a 2f 0a 20  ndex object */. 
8900: 20 20 20 69 6e 74 20 69 3b 20 20 20 20 20 20 20     int i;       
8910: 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74     /* Loop count
8920: 65 72 20 2a 2f 0a 20 20 20 20 74 52 6f 77 63 6e  er */.    tRowcn
8930: 74 20 73 75 6d 45 71 3b 20 20 2f 2a 20 53 75 6d  t sumEq;  /* Sum
8940: 20 6f 66 20 74 68 65 20 6e 45 71 20 76 61 6c 75   of the nEq valu
8950: 65 73 20 2a 2f 0a 0a 20 20 20 20 7a 49 6e 64 65  es */..    zInde
8960: 78 20 3d 20 28 63 68 61 72 20 2a 29 73 71 6c 69  x = (char *)sqli
8970: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28  te3_column_text(
8980: 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20 20 20 69  pStmt, 0);.    i
8990: 66 28 20 7a 49 6e 64 65 78 3d 3d 30 20 29 20 63  f( zIndex==0 ) c
89a0: 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 70 49 64  ontinue;.    pId
89b0: 78 20 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 49  x = sqlite3FindI
89c0: 6e 64 65 78 28 64 62 2c 20 7a 49 6e 64 65 78 2c  ndex(db, zIndex,
89d0: 20 7a 44 62 29 3b 0a 20 20 20 20 69 66 28 20 70   zDb);.    if( p
89e0: 49 64 78 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75  Idx==0 ) continu
89f0: 65 3b 0a 20 20 20 20 69 66 28 20 70 49 64 78 3d  e;.    if( pIdx=
8a00: 3d 70 50 72 65 76 49 64 78 20 29 7b 0a 20 20 20  =pPrevIdx ){.   
8a10: 20 20 20 69 64 78 2b 2b 3b 0a 20 20 20 20 7d 65     idx++;.    }e
8a20: 6c 73 65 7b 0a 20 20 20 20 20 20 70 50 72 65 76  lse{.      pPrev
8a30: 49 64 78 20 3d 20 70 49 64 78 3b 0a 20 20 20 20  Idx = pIdx;.    
8a40: 20 20 69 64 78 20 3d 20 30 3b 0a 20 20 20 20 7d    idx = 0;.    }
8a50: 0a 20 20 20 20 61 73 73 65 72 74 28 20 69 64 78  .    assert( idx
8a60: 3c 70 49 64 78 2d 3e 6e 53 61 6d 70 6c 65 20 29  <pIdx->nSample )
8a70: 3b 0a 20 20 20 20 70 53 61 6d 70 6c 65 20 3d 20  ;.    pSample = 
8a80: 26 70 49 64 78 2d 3e 61 53 61 6d 70 6c 65 5b 69  &pIdx->aSample[i
8a90: 64 78 5d 3b 0a 20 20 20 20 70 53 61 6d 70 6c 65  dx];.    pSample
8aa0: 2d 3e 6e 45 71 20 3d 20 28 74 52 6f 77 63 6e 74  ->nEq = (tRowcnt
8ab0: 29 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  )sqlite3_column_
8ac0: 69 6e 74 36 34 28 70 53 74 6d 74 2c 20 31 29 3b  int64(pStmt, 1);
8ad0: 0a 20 20 20 20 70 53 61 6d 70 6c 65 2d 3e 6e 4c  .    pSample->nL
8ae0: 74 20 3d 20 28 74 52 6f 77 63 6e 74 29 73 71 6c  t = (tRowcnt)sql
8af0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36  ite3_column_int6
8b00: 34 28 70 53 74 6d 74 2c 20 32 29 3b 0a 20 20 20  4(pStmt, 2);.   
8b10: 20 70 53 61 6d 70 6c 65 2d 3e 6e 44 4c 74 20 3d   pSample->nDLt =
8b20: 20 28 74 52 6f 77 63 6e 74 29 73 71 6c 69 74 65   (tRowcnt)sqlite
8b30: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 70  3_column_int64(p
8b40: 53 74 6d 74 2c 20 33 29 3b 0a 20 20 20 20 69 66  Stmt, 3);.    if
8b50: 28 20 69 64 78 3d 3d 70 49 64 78 2d 3e 6e 53 61  ( idx==pIdx->nSa
8b60: 6d 70 6c 65 2d 31 20 29 7b 0a 20 20 20 20 20 20  mple-1 ){.      
8b70: 69 66 28 20 70 53 61 6d 70 6c 65 2d 3e 6e 44 4c  if( pSample->nDL
8b80: 74 3e 30 20 29 7b 0a 20 20 20 20 20 20 20 20 66  t>0 ){.        f
8b90: 6f 72 28 69 3d 30 2c 20 73 75 6d 45 71 3d 30 3b  or(i=0, sumEq=0;
8ba0: 20 69 3c 3d 69 64 78 2d 31 3b 20 69 2b 2b 29 20   i<=idx-1; i++) 
8bb0: 73 75 6d 45 71 20 2b 3d 20 70 49 64 78 2d 3e 61  sumEq += pIdx->a
8bc0: 53 61 6d 70 6c 65 5b 69 5d 2e 6e 45 71 3b 0a 20  Sample[i].nEq;. 
8bd0: 20 20 20 20 20 20 20 70 49 64 78 2d 3e 61 76 67         pIdx->avg
8be0: 45 71 20 3d 20 28 70 53 61 6d 70 6c 65 2d 3e 6e  Eq = (pSample->n
8bf0: 4c 74 20 2d 20 73 75 6d 45 71 29 2f 70 53 61 6d  Lt - sumEq)/pSam
8c00: 70 6c 65 2d 3e 6e 44 4c 74 3b 0a 20 20 20 20 20  ple->nDLt;.     
8c10: 20 7d 0a 20 20 20 20 20 20 69 66 28 20 70 49 64   }.      if( pId
8c20: 78 2d 3e 61 76 67 45 71 3c 3d 30 20 29 20 70 49  x->avgEq<=0 ) pI
8c30: 64 78 2d 3e 61 76 67 45 71 20 3d 20 31 3b 0a 20  dx->avgEq = 1;. 
8c40: 20 20 20 7d 0a 20 20 20 20 65 54 79 70 65 20 3d     }.    eType =
8c50: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
8c60: 74 79 70 65 28 70 53 74 6d 74 2c 20 34 29 3b 0a  type(pStmt, 4);.
8c70: 20 20 20 20 70 53 61 6d 70 6c 65 2d 3e 65 54 79      pSample->eTy
8c80: 70 65 20 3d 20 28 75 38 29 65 54 79 70 65 3b 0a  pe = (u8)eType;.
8c90: 20 20 20 20 73 77 69 74 63 68 28 20 65 54 79 70      switch( eTyp
8ca0: 65 20 29 7b 0a 20 20 20 20 20 20 63 61 73 65 20  e ){.      case 
8cb0: 53 51 4c 49 54 45 5f 49 4e 54 45 47 45 52 3a 20  SQLITE_INTEGER: 
8cc0: 7b 0a 20 20 20 20 20 20 20 20 70 53 61 6d 70 6c  {.        pSampl
8cd0: 65 2d 3e 75 2e 69 20 3d 20 73 71 6c 69 74 65 33  e->u.i = sqlite3
8ce0: 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 70 53  _column_int64(pS
8cf0: 74 6d 74 2c 20 34 29 3b 0a 20 20 20 20 20 20 20  tmt, 4);.       
8d00: 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a   break;.      }.
8d10: 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 49 54        case SQLIT
8d20: 45 5f 46 4c 4f 41 54 3a 20 7b 0a 20 20 20 20 20  E_FLOAT: {.     
8d30: 20 20 20 70 53 61 6d 70 6c 65 2d 3e 75 2e 72 20     pSample->u.r 
8d40: 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  = sqlite3_column
8d50: 5f 64 6f 75 62 6c 65 28 70 53 74 6d 74 2c 20 34  _double(pStmt, 4
8d60: 29 3b 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b  );.        break
8d70: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
8d80: 63 61 73 65 20 53 51 4c 49 54 45 5f 4e 55 4c 4c  case SQLITE_NULL
8d90: 3a 20 7b 0a 20 20 20 20 20 20 20 20 62 72 65 61  : {.        brea
8da0: 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  k;.      }.     
8db0: 20 64 65 66 61 75 6c 74 3a 20 61 73 73 65 72 74   default: assert
8dc0: 28 20 65 54 79 70 65 3d 3d 53 51 4c 49 54 45 5f  ( eType==SQLITE_
8dd0: 54 45 58 54 20 7c 7c 20 65 54 79 70 65 3d 3d 53  TEXT || eType==S
8de0: 51 4c 49 54 45 5f 42 4c 4f 42 20 29 3b 20 7b 0a  QLITE_BLOB ); {.
8df0: 20 20 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68          const ch
8e00: 61 72 20 2a 7a 20 3d 20 28 63 6f 6e 73 74 20 63  ar *z = (const c
8e10: 68 61 72 20 2a 29 28 0a 20 20 20 20 20 20 20 20  har *)(.        
8e20: 20 20 20 20 20 20 28 65 54 79 70 65 3d 3d 53 51        (eType==SQ
8e30: 4c 49 54 45 5f 42 4c 4f 42 29 20 3f 0a 20 20 20  LITE_BLOB) ?.   
8e40: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
8e50: 65 33 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f 62 28 70  e3_column_blob(p
8e60: 53 74 6d 74 2c 20 34 29 3a 0a 20 20 20 20 20 20  Stmt, 4):.      
8e70: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
8e80: 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70 53 74 6d  column_text(pStm
8e90: 74 2c 20 34 29 0a 20 20 20 20 20 20 20 20 20 20  t, 4).          
8ea0: 20 29 3b 0a 20 20 20 20 20 20 20 20 69 6e 74 20   );.        int 
8eb0: 6e 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  n = sqlite3_colu
8ec0: 6d 6e 5f 62 79 74 65 73 28 70 53 74 6d 74 2c 20  mn_bytes(pStmt, 
8ed0: 34 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20  4);.        if( 
8ee0: 6e 3e 30 78 66 66 66 66 20 29 20 6e 20 3d 20 30  n>0xffff ) n = 0
8ef0: 78 66 66 66 66 3b 0a 20 20 20 20 20 20 20 20 70  xffff;.        p
8f00: 53 61 6d 70 6c 65 2d 3e 6e 42 79 74 65 20 3d 20  Sample->nByte = 
8f10: 28 75 31 36 29 6e 3b 0a 20 20 20 20 20 20 20 20  (u16)n;.        
8f20: 69 66 28 20 6e 20 3c 20 31 29 7b 0a 20 20 20 20  if( n < 1){.    
8f30: 20 20 20 20 20 20 70 53 61 6d 70 6c 65 2d 3e 75        pSample->u
8f40: 2e 7a 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  .z = 0;.        
8f50: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20  }else{.         
8f60: 20 70 53 61 6d 70 6c 65 2d 3e 75 2e 7a 20 3d 20   pSample->u.z = 
8f70: 73 71 6c 69 74 65 33 4d 61 6c 6c 6f 63 28 6e 29  sqlite3Malloc(n)
8f80: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  ;.          if( 
8f90: 70 53 61 6d 70 6c 65 2d 3e 75 2e 7a 3d 3d 30 20  pSample->u.z==0 
8fa0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 64  ){.            d
8fb0: 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20  b->mallocFailed 
8fc0: 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20 20  = 1;.           
8fd0: 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a   sqlite3_finaliz
8fe0: 65 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 20 20  e(pStmt);.      
8ff0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c        return SQL
9000: 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20  ITE_NOMEM;.     
9010: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
9020: 20 6d 65 6d 63 70 79 28 70 53 61 6d 70 6c 65 2d   memcpy(pSample-
9030: 3e 75 2e 7a 2c 20 7a 2c 20 6e 29 3b 0a 20 20 20  >u.z, z, n);.   
9040: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20       }.      }. 
9050: 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72     }.  }.  retur
9060: 6e 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69  n sqlite3_finali
9070: 7a 65 28 70 53 74 6d 74 29 3b 0a 7d 0a 23 65 6e  ze(pStmt);.}.#en
9080: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 45 4e  dif /* SQLITE_EN
9090: 41 42 4c 45 5f 53 54 41 54 33 20 2a 2f 0a 0a 2f  ABLE_STAT3 */../
90a0: 2a 0a 2a 2a 20 4c 6f 61 64 20 74 68 65 20 63 6f  *.** Load the co
90b0: 6e 74 65 6e 74 20 6f 66 20 74 68 65 20 73 71 6c  ntent of the sql
90c0: 69 74 65 5f 73 74 61 74 31 20 61 6e 64 20 73 71  ite_stat1 and sq
90d0: 6c 69 74 65 5f 73 74 61 74 33 20 74 61 62 6c 65  lite_stat3 table
90e0: 73 2e 20 54 68 65 0a 2a 2a 20 63 6f 6e 74 65 6e  s. The.** conten
90f0: 74 73 20 6f 66 20 73 71 6c 69 74 65 5f 73 74 61  ts of sqlite_sta
9100: 74 31 20 61 72 65 20 75 73 65 64 20 74 6f 20 70  t1 are used to p
9110: 6f 70 75 6c 61 74 65 20 74 68 65 20 49 6e 64 65  opulate the Inde
9120: 78 2e 61 69 52 6f 77 45 73 74 5b 5d 0a 2a 2a 20  x.aiRowEst[].** 
9130: 61 72 72 61 79 73 2e 20 54 68 65 20 63 6f 6e 74  arrays. The cont
9140: 65 6e 74 73 20 6f 66 20 73 71 6c 69 74 65 5f 73  ents of sqlite_s
9150: 74 61 74 33 20 61 72 65 20 75 73 65 64 20 74 6f  tat3 are used to
9160: 20 70 6f 70 75 6c 61 74 65 20 74 68 65 0a 2a 2a   populate the.**
9170: 20 49 6e 64 65 78 2e 61 53 61 6d 70 6c 65 5b 5d   Index.aSample[]
9180: 20 61 72 72 61 79 73 2e 0a 2a 2a 0a 2a 2a 20 49   arrays..**.** I
9190: 66 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74 61  f the sqlite_sta
91a0: 74 31 20 74 61 62 6c 65 20 69 73 20 6e 6f 74 20  t1 table is not 
91b0: 70 72 65 73 65 6e 74 20 69 6e 20 74 68 65 20 64  present in the d
91c0: 61 74 61 62 61 73 65 2c 20 53 51 4c 49 54 45 5f  atabase, SQLITE_
91d0: 45 52 52 4f 52 0a 2a 2a 20 69 73 20 72 65 74 75  ERROR.** is retu
91e0: 72 6e 65 64 2e 20 49 6e 20 74 68 69 73 20 63 61  rned. In this ca
91f0: 73 65 2c 20 65 76 65 6e 20 69 66 20 53 51 4c 49  se, even if SQLI
9200: 54 45 5f 45 4e 41 42 4c 45 5f 53 54 41 54 33 20  TE_ENABLE_STAT3 
9210: 77 61 73 20 64 65 66 69 6e 65 64 20 0a 2a 2a 20  was defined .** 
9220: 64 75 72 69 6e 67 20 63 6f 6d 70 69 6c 61 74 69  during compilati
9230: 6f 6e 20 61 6e 64 20 74 68 65 20 73 71 6c 69 74  on and the sqlit
9240: 65 5f 73 74 61 74 33 20 74 61 62 6c 65 20 69 73  e_stat3 table is
9250: 20 70 72 65 73 65 6e 74 2c 20 6e 6f 20 64 61 74   present, no dat
9260: 61 20 69 73 20 0a 2a 2a 20 72 65 61 64 20 66 72  a is .** read fr
9270: 6f 6d 20 69 74 2e 0a 2a 2a 0a 2a 2a 20 49 66 20  om it..**.** If 
9280: 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53 54  SQLITE_ENABLE_ST
9290: 41 54 33 20 77 61 73 20 64 65 66 69 6e 65 64 20  AT3 was defined 
92a0: 64 75 72 69 6e 67 20 63 6f 6d 70 69 6c 61 74 69  during compilati
92b0: 6f 6e 20 61 6e 64 20 74 68 65 20 0a 2a 2a 20 73  on and the .** s
92c0: 71 6c 69 74 65 5f 73 74 61 74 33 20 74 61 62 6c  qlite_stat3 tabl
92d0: 65 20 69 73 20 6e 6f 74 20 70 72 65 73 65 6e 74  e is not present
92e0: 20 69 6e 20 74 68 65 20 64 61 74 61 62 61 73 65   in the database
92f0: 2c 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 20 69  , SQLITE_ERROR i
9300: 73 0a 2a 2a 20 72 65 74 75 72 6e 65 64 2e 20 48  s.** returned. H
9310: 6f 77 65 76 65 72 2c 20 69 6e 20 74 68 69 73 20  owever, in this 
9320: 63 61 73 65 2c 20 64 61 74 61 20 69 73 20 72 65  case, data is re
9330: 61 64 20 66 72 6f 6d 20 74 68 65 20 73 71 6c 69  ad from the sqli
9340: 74 65 5f 73 74 61 74 31 0a 2a 2a 20 74 61 62 6c  te_stat1.** tabl
9350: 65 20 28 69 66 20 69 74 20 69 73 20 70 72 65 73  e (if it is pres
9360: 65 6e 74 29 20 62 65 66 6f 72 65 20 72 65 74 75  ent) before retu
9370: 72 6e 69 6e 67 2e 0a 2a 2a 0a 2a 2a 20 49 66 20  rning..**.** If 
9380: 61 6e 20 4f 4f 4d 20 65 72 72 6f 72 20 6f 63 63  an OOM error occ
9390: 75 72 73 2c 20 74 68 69 73 20 66 75 6e 63 74 69  urs, this functi
93a0: 6f 6e 20 61 6c 77 61 79 73 20 73 65 74 73 20 64  on always sets d
93b0: 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 2e  b->mallocFailed.
93c0: 0a 2a 2a 20 54 68 69 73 20 6d 65 61 6e 73 20 69  .** This means i
93d0: 66 20 74 68 65 20 63 61 6c 6c 65 72 20 64 6f 65  f the caller doe
93e0: 73 20 6e 6f 74 20 63 61 72 65 20 61 62 6f 75 74  s not care about
93f0: 20 6f 74 68 65 72 20 65 72 72 6f 72 73 2c 20 74   other errors, t
9400: 68 65 20 72 65 74 75 72 6e 0a 2a 2a 20 63 6f 64  he return.** cod
9410: 65 20 6d 61 79 20 62 65 20 69 67 6e 6f 72 65 64  e may be ignored
9420: 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33  ..*/.int sqlite3
9430: 41 6e 61 6c 79 73 69 73 4c 6f 61 64 28 73 71 6c  AnalysisLoad(sql
9440: 69 74 65 33 20 2a 64 62 2c 20 69 6e 74 20 69 44  ite3 *db, int iD
9450: 62 29 7b 0a 20 20 61 6e 61 6c 79 73 69 73 49 6e  b){.  analysisIn
9460: 66 6f 20 73 49 6e 66 6f 3b 0a 20 20 48 61 73 68  fo sInfo;.  Hash
9470: 45 6c 65 6d 20 2a 69 3b 0a 20 20 63 68 61 72 20  Elem *i;.  char 
9480: 2a 7a 53 71 6c 3b 0a 20 20 69 6e 74 20 72 63 3b  *zSql;.  int rc;
9490: 0a 0a 20 20 61 73 73 65 72 74 28 20 69 44 62 3e  ..  assert( iDb>
94a0: 3d 30 20 26 26 20 69 44 62 3c 64 62 2d 3e 6e 44  =0 && iDb<db->nD
94b0: 62 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 64  b );.  assert( d
94c0: 62 2d 3e 61 44 62 5b 69 44 62 5d 2e 70 42 74 21  b->aDb[iDb].pBt!
94d0: 3d 30 20 29 3b 0a 0a 20 20 2f 2a 20 43 6c 65 61  =0 );..  /* Clea
94e0: 72 20 61 6e 79 20 70 72 69 6f 72 20 73 74 61 74  r any prior stat
94f0: 69 73 74 69 63 73 20 2a 2f 0a 20 20 61 73 73 65  istics */.  asse
9500: 72 74 28 20 73 71 6c 69 74 65 33 53 63 68 65 6d  rt( sqlite3Schem
9510: 61 4d 75 74 65 78 48 65 6c 64 28 64 62 2c 20 69  aMutexHeld(db, i
9520: 44 62 2c 20 30 29 20 29 3b 0a 20 20 66 6f 72 28  Db, 0) );.  for(
9530: 69 3d 73 71 6c 69 74 65 48 61 73 68 46 69 72 73  i=sqliteHashFirs
9540: 74 28 26 64 62 2d 3e 61 44 62 5b 69 44 62 5d 2e  t(&db->aDb[iDb].
9550: 70 53 63 68 65 6d 61 2d 3e 69 64 78 48 61 73 68  pSchema->idxHash
9560: 29 3b 69 3b 69 3d 73 71 6c 69 74 65 48 61 73 68  );i;i=sqliteHash
9570: 4e 65 78 74 28 69 29 29 7b 0a 20 20 20 20 49 6e  Next(i)){.    In
9580: 64 65 78 20 2a 70 49 64 78 20 3d 20 73 71 6c 69  dex *pIdx = sqli
9590: 74 65 48 61 73 68 44 61 74 61 28 69 29 3b 0a 20  teHashData(i);. 
95a0: 20 20 20 73 71 6c 69 74 65 33 44 65 66 61 75 6c     sqlite3Defaul
95b0: 74 52 6f 77 45 73 74 28 70 49 64 78 29 3b 0a 23  tRowEst(pIdx);.#
95c0: 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41  ifdef SQLITE_ENA
95d0: 42 4c 45 5f 53 54 41 54 33 0a 20 20 20 20 73 71  BLE_STAT3.    sq
95e0: 6c 69 74 65 33 44 65 6c 65 74 65 49 6e 64 65 78  lite3DeleteIndex
95f0: 53 61 6d 70 6c 65 73 28 64 62 2c 20 70 49 64 78  Samples(db, pIdx
9600: 29 3b 0a 20 20 20 20 70 49 64 78 2d 3e 61 53 61  );.    pIdx->aSa
9610: 6d 70 6c 65 20 3d 20 30 3b 0a 23 65 6e 64 69 66  mple = 0;.#endif
9620: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 43 68 65 63 6b  .  }..  /* Check
9630: 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20 74 68   to make sure th
9640: 65 20 73 71 6c 69 74 65 5f 73 74 61 74 31 20 74  e sqlite_stat1 t
9650: 61 62 6c 65 20 65 78 69 73 74 73 20 2a 2f 0a 20  able exists */. 
9660: 20 73 49 6e 66 6f 2e 64 62 20 3d 20 64 62 3b 0a   sInfo.db = db;.
9670: 20 20 73 49 6e 66 6f 2e 7a 44 61 74 61 62 61 73    sInfo.zDatabas
9680: 65 20 3d 20 64 62 2d 3e 61 44 62 5b 69 44 62 5d  e = db->aDb[iDb]
9690: 2e 7a 4e 61 6d 65 3b 0a 20 20 69 66 28 20 73 71  .zName;.  if( sq
96a0: 6c 69 74 65 33 46 69 6e 64 54 61 62 6c 65 28 64  lite3FindTable(d
96b0: 62 2c 20 22 73 71 6c 69 74 65 5f 73 74 61 74 31  b, "sqlite_stat1
96c0: 22 2c 20 73 49 6e 66 6f 2e 7a 44 61 74 61 62 61  ", sInfo.zDataba
96d0: 73 65 29 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65  se)==0 ){.    re
96e0: 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f  turn SQLITE_ERRO
96f0: 52 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 4c 6f 61  R;.  }..  /* Loa
9700: 64 20 6e 65 77 20 73 74 61 74 69 73 74 69 63 73  d new statistics
9710: 20 6f 75 74 20 6f 66 20 74 68 65 20 73 71 6c 69   out of the sqli
9720: 74 65 5f 73 74 61 74 31 20 74 61 62 6c 65 20 2a  te_stat1 table *
9730: 2f 0a 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74  /.  zSql = sqlit
9740: 65 33 4d 50 72 69 6e 74 66 28 64 62 2c 20 0a 20  e3MPrintf(db, . 
9750: 20 20 20 20 20 22 53 45 4c 45 43 54 20 74 62 6c       "SELECT tbl
9760: 2c 69 64 78 2c 73 74 61 74 20 46 52 4f 4d 20 25  ,idx,stat FROM %
9770: 51 2e 73 71 6c 69 74 65 5f 73 74 61 74 31 22 2c  Q.sqlite_stat1",
9780: 20 73 49 6e 66 6f 2e 7a 44 61 74 61 62 61 73 65   sInfo.zDatabase
9790: 29 3b 0a 20 20 69 66 28 20 7a 53 71 6c 3d 3d 30  );.  if( zSql==0
97a0: 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 53 51 4c   ){.    rc = SQL
97b0: 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 7d 65 6c  ITE_NOMEM;.  }el
97c0: 73 65 7b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c  se{.    rc = sql
97d0: 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 7a 53  ite3_exec(db, zS
97e0: 71 6c 2c 20 61 6e 61 6c 79 73 69 73 4c 6f 61 64  ql, analysisLoad
97f0: 65 72 2c 20 26 73 49 6e 66 6f 2c 20 30 29 3b 0a  er, &sInfo, 0);.
9800: 20 20 20 20 73 71 6c 69 74 65 33 44 62 46 72 65      sqlite3DbFre
9810: 65 28 64 62 2c 20 7a 53 71 6c 29 3b 0a 20 20 7d  e(db, zSql);.  }
9820: 0a 0a 0a 20 20 2f 2a 20 4c 6f 61 64 20 74 68 65  ...  /* Load the
9830: 20 73 74 61 74 69 73 74 69 63 73 20 66 72 6f 6d   statistics from
9840: 20 74 68 65 20 73 71 6c 69 74 65 5f 73 74 61 74   the sqlite_stat
9850: 33 20 74 61 62 6c 65 2e 20 2a 2f 0a 23 69 66 64  3 table. */.#ifd
9860: 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45  ef SQLITE_ENABLE
9870: 5f 53 54 41 54 33 0a 20 20 69 66 28 20 72 63 3d  _STAT3.  if( rc=
9880: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20  =SQLITE_OK ){.  
9890: 20 20 72 63 20 3d 20 6c 6f 61 64 53 74 61 74 33    rc = loadStat3
98a0: 28 64 62 2c 20 73 49 6e 66 6f 2e 7a 44 61 74 61  (db, sInfo.zData
98b0: 62 61 73 65 29 3b 0a 20 20 7d 0a 23 65 6e 64 69  base);.  }.#endi
98c0: 66 0a 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c  f..  if( rc==SQL
98d0: 49 54 45 5f 4e 4f 4d 45 4d 20 29 7b 0a 20 20 20  ITE_NOMEM ){.   
98e0: 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65   db->mallocFaile
98f0: 64 20 3d 20 31 3b 0a 20 20 7d 0a 20 20 72 65 74  d = 1;.  }.  ret
9900: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 0a 23 65 6e 64  urn rc;.}...#end
9910: 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49  if /* SQLITE_OMI
9920: 54 5f 41 4e 41 4c 59 5a 45 20 2a 2f 0a           T_ANALYZE */.