System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact a17dcd3fb775d63b64a43a55c54cb282f9726f44:


0000: 2f 2a 0a 2a 2a 20 32 30 30 37 20 4d 61 79 20 37  /*.** 2007 May 7
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
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 0a  ***************.
0170: 2a 2a 20 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65  ** .** This file
0180: 20 64 65 66 69 6e 65 73 20 76 61 72 69 6f 75 73   defines various
0190: 20 6c 69 6d 69 74 73 20 6f 66 20 77 68 61 74 20   limits of what 
01a0: 53 51 4c 69 74 65 20 63 61 6e 20 70 72 6f 63 65  SQLite can proce
01b0: 73 73 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 54 68  ss..*/../*.** Th
01c0: 65 20 6d 61 78 69 6d 75 6d 20 6c 65 6e 67 74 68  e maximum length
01d0: 20 6f 66 20 61 20 54 45 58 54 20 6f 72 20 42 4c   of a TEXT or BL
01e0: 4f 42 20 69 6e 20 62 79 74 65 73 2e 20 20 20 54  OB in bytes.   T
01f0: 68 69 73 20 61 6c 73 6f 0a 2a 2a 20 6c 69 6d 69  his also.** limi
0200: 74 73 20 74 68 65 20 73 69 7a 65 20 6f 66 20 61  ts the size of a
0210: 20 72 6f 77 20 69 6e 20 61 20 74 61 62 6c 65 20   row in a table 
0220: 6f 72 20 69 6e 64 65 78 2e 0a 2a 2a 0a 2a 2a 20  or index..**.** 
0230: 54 68 65 20 68 61 72 64 20 6c 69 6d 69 74 20 69  The hard limit i
0240: 73 20 74 68 65 20 61 62 69 6c 69 74 79 20 6f 66  s the ability of
0250: 20 61 20 33 32 2d 62 69 74 20 73 69 67 6e 65 64   a 32-bit signed
0260: 20 69 6e 74 65 67 65 72 0a 2a 2a 20 74 6f 20 63   integer.** to c
0270: 6f 75 6e 74 20 74 68 65 20 73 69 7a 65 3a 20 32  ount the size: 2
0280: 5e 33 31 2d 31 20 6f 72 20 32 31 34 37 34 38 33  ^31-1 or 2147483
0290: 36 34 37 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20  647..*/.#ifndef 
02a0: 53 51 4c 49 54 45 5f 4d 41 58 5f 4c 45 4e 47 54  SQLITE_MAX_LENGT
02b0: 48 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54  H.# define SQLIT
02c0: 45 5f 4d 41 58 5f 4c 45 4e 47 54 48 20 31 30 30  E_MAX_LENGTH 100
02d0: 30 30 30 30 30 30 30 0a 23 65 6e 64 69 66 0a 0a  0000000.#endif..
02e0: 2f 2a 0a 2a 2a 20 54 68 69 73 20 69 73 20 74 68  /*.** This is th
02f0: 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72  e maximum number
0300: 20 6f 66 0a 2a 2a 0a 2a 2a 20 20 20 20 2a 20 43   of.**.**    * C
0310: 6f 6c 75 6d 6e 73 20 69 6e 20 61 20 74 61 62 6c  olumns in a tabl
0320: 65 0a 2a 2a 20 20 20 20 2a 20 43 6f 6c 75 6d 6e  e.**    * Column
0330: 73 20 69 6e 20 61 6e 20 69 6e 64 65 78 0a 2a 2a  s in an index.**
0340: 20 20 20 20 2a 20 43 6f 6c 75 6d 6e 73 20 69 6e      * Columns in
0350: 20 61 20 76 69 65 77 0a 2a 2a 20 20 20 20 2a 20   a view.**    * 
0360: 54 65 72 6d 73 20 69 6e 20 74 68 65 20 53 45 54  Terms in the SET
0370: 20 63 6c 61 75 73 65 20 6f 66 20 61 6e 20 55 50   clause of an UP
0380: 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 0a 2a  DATE statement.*
0390: 2a 20 20 20 20 2a 20 54 65 72 6d 73 20 69 6e 20  *    * Terms in 
03a0: 74 68 65 20 72 65 73 75 6c 74 20 73 65 74 20 6f  the result set o
03b0: 66 20 61 20 53 45 4c 45 43 54 20 73 74 61 74 65  f a SELECT state
03c0: 6d 65 6e 74 0a 2a 2a 20 20 20 20 2a 20 54 65 72  ment.**    * Ter
03d0: 6d 73 20 69 6e 20 74 68 65 20 47 52 4f 55 50 20  ms in the GROUP 
03e0: 42 59 20 6f 72 20 4f 52 44 45 52 20 42 59 20 63  BY or ORDER BY c
03f0: 6c 61 75 73 65 73 20 6f 66 20 61 20 53 45 4c 45  lauses of a SELE
0400: 43 54 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2a  CT statement..**
0410: 20 20 20 20 2a 20 54 65 72 6d 73 20 69 6e 20 74      * Terms in t
0420: 68 65 20 56 41 4c 55 45 53 20 63 6c 61 75 73 65  he VALUES clause
0430: 20 6f 66 20 61 6e 20 49 4e 53 45 52 54 20 73 74   of an INSERT st
0440: 61 74 65 6d 65 6e 74 0a 2a 2a 0a 2a 2a 20 54 68  atement.**.** Th
0450: 65 20 68 61 72 64 20 75 70 70 65 72 20 6c 69 6d  e hard upper lim
0460: 69 74 20 68 65 72 65 20 69 73 20 33 32 36 37 36  it here is 32676
0470: 2e 20 20 4d 6f 73 74 20 64 61 74 61 62 61 73 65  .  Most database
0480: 20 70 65 6f 70 6c 65 20 77 69 6c 6c 0a 2a 2a 20   people will.** 
0490: 74 65 6c 6c 20 79 6f 75 20 74 68 61 74 20 69 6e  tell you that in
04a0: 20 61 20 77 65 6c 6c 2d 6e 6f 72 6d 61 6c 69 7a   a well-normaliz
04b0: 65 64 20 64 61 74 61 62 61 73 65 2c 20 79 6f 75  ed database, you
04c0: 20 75 73 75 61 6c 6c 79 20 73 68 6f 75 6c 64 0a   usually should.
04d0: 2a 2a 20 6e 6f 74 20 68 61 76 65 20 6d 6f 72 65  ** not have more
04e0: 20 74 68 61 6e 20 61 20 64 6f 7a 65 6e 20 6f 72   than a dozen or
04f0: 20 73 6f 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 61   so columns in a
0500: 6e 79 20 74 61 62 6c 65 2e 20 20 41 6e 64 20 69  ny table.  And i
0510: 66 0a 2a 2a 20 74 68 61 74 20 69 73 20 74 68 65  f.** that is the
0520: 20 63 61 73 65 2c 20 74 68 65 72 65 20 69 73 20   case, there is 
0530: 6e 6f 20 70 6f 69 6e 74 20 69 6e 20 68 61 76 69  no point in havi
0540: 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 61 20 66  ng more than a f
0550: 65 77 0a 2a 2a 20 64 6f 7a 65 6e 20 76 61 6c 75  ew.** dozen valu
0560: 65 73 20 69 6e 20 61 6e 79 20 6f 66 20 74 68 65  es in any of the
0570: 20 6f 74 68 65 72 20 73 69 74 75 61 74 69 6f 6e   other situation
0580: 73 20 64 65 73 63 72 69 62 65 64 20 61 62 6f 76  s described abov
0590: 65 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  e..*/.#ifndef SQ
05a0: 4c 49 54 45 5f 4d 41 58 5f 43 4f 4c 55 4d 4e 0a  LITE_MAX_COLUMN.
05b0: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
05c0: 4d 41 58 5f 43 4f 4c 55 4d 4e 20 32 30 30 30 0a  MAX_COLUMN 2000.
05d0: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68  #endif../*.** Th
05e0: 65 20 6d 61 78 69 6d 75 6d 20 6c 65 6e 67 74 68  e maximum length
05f0: 20 6f 66 20 61 20 73 69 6e 67 6c 65 20 53 51 4c   of a single SQL
0600: 20 73 74 61 74 65 6d 65 6e 74 20 69 6e 20 62 79   statement in by
0610: 74 65 73 2e 0a 2a 2a 0a 2a 2a 20 49 74 20 75 73  tes..**.** It us
0620: 65 64 20 74 6f 20 62 65 20 74 68 65 20 63 61 73  ed to be the cas
0630: 65 20 74 68 61 74 20 73 65 74 74 69 6e 67 20 74  e that setting t
0640: 68 69 73 20 76 61 6c 75 65 20 74 6f 20 7a 65 72  his value to zer
0650: 6f 20 77 6f 75 6c 64 0a 2a 2a 20 74 75 72 6e 20  o would.** turn 
0660: 74 68 65 20 6c 69 6d 69 74 20 6f 66 66 2e 20 20  the limit off.  
0670: 54 68 61 74 20 69 73 20 6e 6f 20 6c 6f 6e 67 65  That is no longe
0680: 72 20 74 72 75 65 2e 20 20 49 74 20 69 73 20 6e  r true.  It is n
0690: 6f 74 20 70 6f 73 73 69 62 6c 65 0a 2a 2a 20 74  ot possible.** t
06a0: 6f 20 74 75 72 6e 20 74 68 69 73 20 6c 69 6d 69  o turn this limi
06b0: 74 20 6f 66 66 2e 0a 2a 2f 0a 23 69 66 6e 64 65  t off..*/.#ifnde
06c0: 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 53 51 4c  f SQLITE_MAX_SQL
06d0: 5f 4c 45 4e 47 54 48 0a 23 20 64 65 66 69 6e 65  _LENGTH.# define
06e0: 20 53 51 4c 49 54 45 5f 4d 41 58 5f 53 51 4c 5f   SQLITE_MAX_SQL_
06f0: 4c 45 4e 47 54 48 20 31 30 30 30 30 30 30 30 30  LENGTH 100000000
0700: 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20  0.#endif../*.** 
0710: 54 68 65 20 6d 61 78 69 6d 75 6d 20 64 65 70 74  The maximum dept
0720: 68 20 6f 66 20 61 6e 20 65 78 70 72 65 73 73 69  h of an expressi
0730: 6f 6e 20 74 72 65 65 2e 20 54 68 69 73 20 69 73  on tree. This is
0740: 20 6c 69 6d 69 74 65 64 20 74 6f 20 0a 2a 2a 20   limited to .** 
0750: 73 6f 6d 65 20 65 78 74 65 6e 74 20 62 79 20 53  some extent by S
0760: 51 4c 49 54 45 5f 4d 41 58 5f 53 51 4c 5f 4c 45  QLITE_MAX_SQL_LE
0770: 4e 47 54 48 2e 20 42 75 74 20 73 6f 6d 65 74 69  NGTH. But someti
0780: 6d 65 20 79 6f 75 20 6d 69 67 68 74 20 0a 2a 2a  me you might .**
0790: 20 77 61 6e 74 20 74 6f 20 70 6c 61 63 65 20 6d   want to place m
07a0: 6f 72 65 20 73 65 76 65 72 65 20 6c 69 6d 69 74  ore severe limit
07b0: 73 20 6f 6e 20 74 68 65 20 63 6f 6d 70 6c 65 78  s on the complex
07c0: 69 74 79 20 6f 66 20 61 6e 20 0a 2a 2a 20 65 78  ity of an .** ex
07d0: 70 72 65 73 73 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20  pression..**.** 
07e0: 41 20 76 61 6c 75 65 20 6f 66 20 30 20 75 73 65  A value of 0 use
07f0: 64 20 74 6f 20 6d 65 61 6e 20 74 68 61 74 20 74  d to mean that t
0800: 68 65 20 6c 69 6d 69 74 20 77 61 73 20 6e 6f 74  he limit was not
0810: 20 65 6e 66 6f 72 63 65 64 2e 0a 2a 2a 20 42 75   enforced..** Bu
0820: 74 20 74 68 61 74 20 69 73 20 6e 6f 20 6c 6f 6e  t that is no lon
0830: 67 65 72 20 74 72 75 65 2e 20 20 54 68 65 20 6c  ger true.  The l
0840: 69 6d 69 74 20 69 73 20 6e 6f 77 20 73 74 72 69  imit is now stri
0850: 63 74 6c 79 20 65 6e 66 6f 72 63 65 64 0a 2a 2a  ctly enforced.**
0860: 20 61 74 20 61 6c 6c 20 74 69 6d 65 73 2e 0a 2a   at all times..*
0870: 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  /.#ifndef SQLITE
0880: 5f 4d 41 58 5f 45 58 50 52 5f 44 45 50 54 48 0a  _MAX_EXPR_DEPTH.
0890: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
08a0: 4d 41 58 5f 45 58 50 52 5f 44 45 50 54 48 20 31  MAX_EXPR_DEPTH 1
08b0: 30 30 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a  000.#endif../*.*
08c0: 2a 20 54 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75  * The maximum nu
08d0: 6d 62 65 72 20 6f 66 20 74 65 72 6d 73 20 69 6e  mber of terms in
08e0: 20 61 20 63 6f 6d 70 6f 75 6e 64 20 53 45 4c 45   a compound SELE
08f0: 43 54 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2a  CT statement..**
0900: 20 54 68 65 20 63 6f 64 65 20 67 65 6e 65 72 61   The code genera
0910: 74 6f 72 20 66 6f 72 20 63 6f 6d 70 6f 75 6e 64  tor for compound
0920: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
0930: 74 73 20 64 6f 65 73 20 6f 6e 65 0a 2a 2a 20 6c  ts does one.** l
0940: 65 76 65 6c 20 6f 66 20 72 65 63 75 72 73 69 6f  evel of recursio
0950: 6e 20 66 6f 72 20 65 61 63 68 20 74 65 72 6d 2e  n for each term.
0960: 20 20 41 20 73 74 61 63 6b 20 6f 76 65 72 66 6c    A stack overfl
0970: 6f 77 20 63 61 6e 20 72 65 73 75 6c 74 0a 2a 2a  ow can result.**
0980: 20 69 66 20 74 68 65 20 6e 75 6d 62 65 72 20 6f   if the number o
0990: 66 20 74 65 72 6d 73 20 69 73 20 74 6f 6f 20 6c  f terms is too l
09a0: 61 72 67 65 2e 20 20 49 6e 20 70 72 61 63 74 69  arge.  In practi
09b0: 63 65 2c 20 6d 6f 73 74 20 53 51 4c 0a 2a 2a 20  ce, most SQL.** 
09c0: 6e 65 76 65 72 20 68 61 73 20 6d 6f 72 65 20 74  never has more t
09d0: 68 61 6e 20 33 20 6f 72 20 34 20 74 65 72 6d 73  han 3 or 4 terms
09e0: 2e 20 20 55 73 65 20 61 20 76 61 6c 75 65 20 6f  .  Use a value o
09f0: 66 20 30 20 74 6f 20 64 69 73 61 62 6c 65 0a 2a  f 0 to disable.*
0a00: 2a 20 61 6e 79 20 6c 69 6d 69 74 20 6f 6e 20 74  * any limit on t
0a10: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 74 65 72  he number of ter
0a20: 6d 73 20 69 6e 20 61 20 63 6f 6d 70 6f 75 6e 74  ms in a compount
0a30: 20 53 45 4c 45 43 54 2e 0a 2a 2f 0a 23 69 66 6e   SELECT..*/.#ifn
0a40: 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 43  def SQLITE_MAX_C
0a50: 4f 4d 50 4f 55 4e 44 5f 53 45 4c 45 43 54 0a 23  OMPOUND_SELECT.#
0a60: 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d   define SQLITE_M
0a70: 41 58 5f 43 4f 4d 50 4f 55 4e 44 5f 53 45 4c 45  AX_COMPOUND_SELE
0a80: 43 54 20 35 30 30 0a 23 65 6e 64 69 66 0a 0a 2f  CT 500.#endif../
0a90: 2a 0a 2a 2a 20 54 68 65 20 6d 61 78 69 6d 75 6d  *.** The maximum
0aa0: 20 6e 75 6d 62 65 72 20 6f 66 20 6f 70 63 6f 64   number of opcod
0ab0: 65 73 20 69 6e 20 61 20 56 44 42 45 20 70 72 6f  es in a VDBE pro
0ac0: 67 72 61 6d 2e 0a 2a 2a 20 4e 6f 74 20 63 75 72  gram..** Not cur
0ad0: 72 65 6e 74 6c 79 20 65 6e 66 6f 72 63 65 64 2e  rently enforced.
0ae0: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  .*/.#ifndef SQLI
0af0: 54 45 5f 4d 41 58 5f 56 44 42 45 5f 4f 50 0a 23  TE_MAX_VDBE_OP.#
0b00: 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d   define SQLITE_M
0b10: 41 58 5f 56 44 42 45 5f 4f 50 20 32 35 30 30 30  AX_VDBE_OP 25000
0b20: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54  .#endif../*.** T
0b30: 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65  he maximum numbe
0b40: 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73 20 74  r of arguments t
0b50: 6f 20 61 6e 20 53 51 4c 20 66 75 6e 63 74 69 6f  o an SQL functio
0b60: 6e 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  n..*/.#ifndef SQ
0b70: 4c 49 54 45 5f 4d 41 58 5f 46 55 4e 43 54 49 4f  LITE_MAX_FUNCTIO
0b80: 4e 5f 41 52 47 0a 23 20 64 65 66 69 6e 65 20 53  N_ARG.# define S
0b90: 51 4c 49 54 45 5f 4d 41 58 5f 46 55 4e 43 54 49  QLITE_MAX_FUNCTI
0ba0: 4f 4e 5f 41 52 47 20 31 32 37 0a 23 65 6e 64 69  ON_ARG 127.#endi
0bb0: 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61 78  f../*.** The max
0bc0: 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20 69  imum number of i
0bd0: 6e 2d 6d 65 6d 6f 72 79 20 70 61 67 65 73 20 74  n-memory pages t
0be0: 6f 20 75 73 65 20 66 6f 72 20 74 68 65 20 6d 61  o use for the ma
0bf0: 69 6e 20 64 61 74 61 62 61 73 65 0a 2a 2a 20 74  in database.** t
0c00: 61 62 6c 65 20 61 6e 64 20 66 6f 72 20 74 65 6d  able and for tem
0c10: 70 6f 72 61 72 79 20 74 61 62 6c 65 73 2e 20 20  porary tables.  
0c20: 54 68 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55  The SQLITE_DEFAU
0c30: 4c 54 5f 43 41 43 48 45 5f 53 49 5a 45 0a 2a 2f  LT_CACHE_SIZE.*/
0c40: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
0c50: 44 45 46 41 55 4c 54 5f 43 41 43 48 45 5f 53 49  DEFAULT_CACHE_SI
0c60: 5a 45 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49  ZE.# define SQLI
0c70: 54 45 5f 44 45 46 41 55 4c 54 5f 43 41 43 48 45  TE_DEFAULT_CACHE
0c80: 5f 53 49 5a 45 20 20 32 30 30 30 0a 23 65 6e 64  _SIZE  2000.#end
0c90: 69 66 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  if.#ifndef SQLIT
0ca0: 45 5f 44 45 46 41 55 4c 54 5f 54 45 4d 50 5f 43  E_DEFAULT_TEMP_C
0cb0: 41 43 48 45 5f 53 49 5a 45 0a 23 20 64 65 66 69  ACHE_SIZE.# defi
0cc0: 6e 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c  ne SQLITE_DEFAUL
0cd0: 54 5f 54 45 4d 50 5f 43 41 43 48 45 5f 53 49 5a  T_TEMP_CACHE_SIZ
0ce0: 45 20 20 35 30 30 0a 23 65 6e 64 69 66 0a 0a 2f  E  500.#endif../
0cf0: 2a 0a 2a 2a 20 54 68 65 20 64 65 66 61 75 6c 74  *.** The default
0d00: 20 6e 75 6d 62 65 72 20 6f 66 20 66 72 61 6d 65   number of frame
0d10: 73 20 74 6f 20 61 63 63 75 6d 75 6c 61 74 65 20  s to accumulate 
0d20: 69 6e 20 74 68 65 20 6c 6f 67 20 66 69 6c 65 20  in the log file 
0d30: 62 65 66 6f 72 65 0a 2a 2a 20 63 68 65 63 6b 70  before.** checkp
0d40: 6f 69 6e 74 69 6e 67 20 74 68 65 20 64 61 74 61  ointing the data
0d50: 62 61 73 65 20 69 6e 20 57 41 4c 20 6d 6f 64 65  base in WAL mode
0d60: 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c  ..*/.#ifndef SQL
0d70: 49 54 45 5f 44 45 46 41 55 4c 54 5f 57 41 4c 5f  ITE_DEFAULT_WAL_
0d80: 41 55 54 4f 43 48 45 43 4b 50 4f 49 4e 54 0a 23  AUTOCHECKPOINT.#
0d90: 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 44   define SQLITE_D
0da0: 45 46 41 55 4c 54 5f 57 41 4c 5f 41 55 54 4f 43  EFAULT_WAL_AUTOC
0db0: 48 45 43 4b 50 4f 49 4e 54 20 20 31 30 30 30 0a  HECKPOINT  1000.
0dc0: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68  #endif../*.** Th
0dd0: 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72  e maximum number
0de0: 20 6f 66 20 61 74 74 61 63 68 65 64 20 64 61 74   of attached dat
0df0: 61 62 61 73 65 73 2e 20 20 54 68 69 73 20 6d 75  abases.  This mu
0e00: 73 74 20 62 65 20 62 65 74 77 65 65 6e 20 30 0a  st be between 0.
0e10: 2a 2a 20 61 6e 64 20 33 30 2e 20 20 54 68 65 20  ** and 30.  The 
0e20: 75 70 70 65 72 20 62 6f 75 6e 64 20 6f 6e 20 33  upper bound on 3
0e30: 30 20 69 73 20 62 65 63 61 75 73 65 20 61 20 33  0 is because a 3
0e40: 32 2d 62 69 74 20 69 6e 74 65 67 65 72 20 62 69  2-bit integer bi
0e50: 74 6d 61 70 0a 2a 2a 20 69 73 20 75 73 65 64 20  tmap.** is used 
0e60: 69 6e 74 65 72 6e 61 6c 6c 79 20 74 6f 20 74 72  internally to tr
0e70: 61 63 6b 20 61 74 74 61 63 68 65 64 20 64 61 74  ack attached dat
0e80: 61 62 61 73 65 73 2e 0a 2a 2f 0a 23 69 66 6e 64  abases..*/.#ifnd
0e90: 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 41 54  ef SQLITE_MAX_AT
0ea0: 54 41 43 48 45 44 0a 23 20 64 65 66 69 6e 65 20  TACHED.# define 
0eb0: 53 51 4c 49 54 45 5f 4d 41 58 5f 41 54 54 41 43  SQLITE_MAX_ATTAC
0ec0: 48 45 44 20 31 30 0a 23 65 6e 64 69 66 0a 0a 0a  HED 10.#endif...
0ed0: 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61 78 69 6d 75  /*.** The maximu
0ee0: 6d 20 76 61 6c 75 65 20 6f 66 20 61 20 3f 6e 6e  m value of a ?nn
0ef0: 6e 20 77 69 6c 64 63 61 72 64 20 74 68 61 74 20  n wildcard that 
0f00: 74 68 65 20 70 61 72 73 65 72 20 77 69 6c 6c 20  the parser will 
0f10: 61 63 63 65 70 74 2e 0a 2a 2f 0a 23 69 66 6e 64  accept..*/.#ifnd
0f20: 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 56 41  ef SQLITE_MAX_VA
0f30: 52 49 41 42 4c 45 5f 4e 55 4d 42 45 52 0a 23 20  RIABLE_NUMBER.# 
0f40: 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41  define SQLITE_MA
0f50: 58 5f 56 41 52 49 41 42 4c 45 5f 4e 55 4d 42 45  X_VARIABLE_NUMBE
0f60: 52 20 39 39 39 0a 23 65 6e 64 69 66 0a 0a 2f 2a  R 999.#endif../*
0f70: 20 4d 61 78 69 6d 75 6d 20 70 61 67 65 20 73 69   Maximum page si
0f80: 7a 65 2e 20 20 54 68 65 20 75 70 70 65 72 20 62  ze.  The upper b
0f90: 6f 75 6e 64 20 6f 6e 20 74 68 69 73 20 76 61 6c  ound on this val
0fa0: 75 65 20 69 73 20 36 35 35 33 36 2e 20 20 54 68  ue is 65536.  Th
0fb0: 69 73 20 61 20 6c 69 6d 69 74 0a 2a 2a 20 69 6d  is a limit.** im
0fc0: 70 6f 73 65 64 20 62 79 20 74 68 65 20 75 73 65  posed by the use
0fd0: 20 6f 66 20 31 36 2d 62 69 74 20 6f 66 66 73 65   of 16-bit offse
0fe0: 74 73 20 77 69 74 68 69 6e 20 65 61 63 68 20 70  ts within each p
0ff0: 61 67 65 2e 0a 2a 2a 0a 2a 2a 20 45 61 72 6c 69  age..**.** Earli
1000: 65 72 20 76 65 72 73 69 6f 6e 73 20 6f 66 20 53  er versions of S
1010: 51 4c 69 74 65 20 61 6c 6c 6f 77 65 64 20 74 68  QLite allowed th
1020: 65 20 75 73 65 72 20 74 6f 20 63 68 61 6e 67 65  e user to change
1030: 20 74 68 69 73 20 76 61 6c 75 65 20 61 74 0a 2a   this value at.*
1040: 2a 20 63 6f 6d 70 69 6c 65 20 74 69 6d 65 2e 20  * compile time. 
1050: 54 68 69 73 20 69 73 20 6e 6f 20 6c 6f 6e 67 65  This is no longe
1060: 72 20 70 65 72 6d 69 74 74 65 64 2c 20 6f 6e 20  r permitted, on 
1070: 74 68 65 20 67 72 6f 75 6e 64 73 20 74 68 61 74  the grounds that
1080: 20 69 74 20 63 72 65 61 74 65 73 0a 2a 2a 20 61   it creates.** a
1090: 20 6c 69 62 72 61 72 79 20 74 68 61 74 20 69 73   library that is
10a0: 20 74 65 63 68 6e 69 63 61 6c 6c 79 20 69 6e 63   technically inc
10b0: 6f 6d 70 61 74 69 62 6c 65 20 77 69 74 68 20 61  ompatible with a
10c0: 6e 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79  n SQLite library
10d0: 20 0a 2a 2a 20 63 6f 6d 70 69 6c 65 64 20 77 69   .** compiled wi
10e0: 74 68 20 61 20 64 69 66 66 65 72 65 6e 74 20 6c  th a different l
10f0: 69 6d 69 74 2e 20 49 66 20 61 20 70 72 6f 63 65  imit. If a proce
1100: 73 73 20 6f 70 65 72 61 74 69 6e 67 20 6f 6e 20  ss operating on 
1110: 61 20 64 61 74 61 62 61 73 65 20 0a 2a 2a 20 77  a database .** w
1120: 69 74 68 20 61 20 70 61 67 65 2d 73 69 7a 65 20  ith a page-size 
1130: 6f 66 20 36 35 35 33 36 20 62 79 74 65 73 20 63  of 65536 bytes c
1140: 72 61 73 68 65 73 2c 20 74 68 65 6e 20 61 6e 20  rashes, then an 
1150: 69 6e 73 74 61 6e 63 65 20 6f 66 20 53 51 4c 69  instance of SQLi
1160: 74 65 20 0a 2a 2a 20 63 6f 6d 70 69 6c 65 64 20  te .** compiled 
1170: 77 69 74 68 20 74 68 65 20 64 65 66 61 75 6c 74  with the default
1180: 20 70 61 67 65 2d 73 69 7a 65 20 6c 69 6d 69 74   page-size limit
1190: 20 77 69 6c 6c 20 6e 6f 74 20 62 65 20 61 62 6c   will not be abl
11a0: 65 20 74 6f 20 72 6f 6c 6c 62 61 63 6b 20 0a 2a  e to rollback .*
11b0: 2a 20 74 68 65 20 61 62 6f 72 74 65 64 20 74 72  * the aborted tr
11c0: 61 6e 73 61 63 74 69 6f 6e 2e 20 54 68 69 73 20  ansaction. This 
11d0: 63 6f 75 6c 64 20 6c 65 61 64 20 74 6f 20 64 61  could lead to da
11e0: 74 61 62 61 73 65 20 63 6f 72 72 75 70 74 69 6f  tabase corruptio
11f0: 6e 2e 0a 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c  n..*/.#ifdef SQL
1200: 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49 5a  ITE_MAX_PAGE_SIZ
1210: 45 0a 23 20 75 6e 64 65 66 20 53 51 4c 49 54 45  E.# undef SQLITE
1220: 5f 4d 41 58 5f 50 41 47 45 5f 53 49 5a 45 0a 23  _MAX_PAGE_SIZE.#
1230: 65 6e 64 69 66 0a 23 64 65 66 69 6e 65 20 53 51  endif.#define SQ
1240: 4c 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49  LITE_MAX_PAGE_SI
1250: 5a 45 20 36 35 35 33 36 0a 0a 0a 2f 2a 0a 2a 2a  ZE 65536.../*.**
1260: 20 54 68 65 20 64 65 66 61 75 6c 74 20 73 69 7a   The default siz
1270: 65 20 6f 66 20 61 20 64 61 74 61 62 61 73 65 20  e of a database 
1280: 70 61 67 65 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66  page..*/.#ifndef
1290: 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f   SQLITE_DEFAULT_
12a0: 50 41 47 45 5f 53 49 5a 45 0a 23 20 64 65 66 69  PAGE_SIZE.# defi
12b0: 6e 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c  ne SQLITE_DEFAUL
12c0: 54 5f 50 41 47 45 5f 53 49 5a 45 20 31 30 32 34  T_PAGE_SIZE 1024
12d0: 0a 23 65 6e 64 69 66 0a 23 69 66 20 53 51 4c 49  .#endif.#if SQLI
12e0: 54 45 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f  TE_DEFAULT_PAGE_
12f0: 53 49 5a 45 3e 53 51 4c 49 54 45 5f 4d 41 58 5f  SIZE>SQLITE_MAX_
1300: 50 41 47 45 5f 53 49 5a 45 0a 23 20 75 6e 64 65  PAGE_SIZE.# unde
1310: 66 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c 54  f SQLITE_DEFAULT
1320: 5f 50 41 47 45 5f 53 49 5a 45 0a 23 20 64 65 66  _PAGE_SIZE.# def
1330: 69 6e 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55  ine SQLITE_DEFAU
1340: 4c 54 5f 50 41 47 45 5f 53 49 5a 45 20 53 51 4c  LT_PAGE_SIZE SQL
1350: 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49 5a  ITE_MAX_PAGE_SIZ
1360: 45 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20  E.#endif../*.** 
1370: 4f 72 64 69 6e 61 72 69 6c 79 2c 20 69 66 20 6e  Ordinarily, if n
1380: 6f 20 76 61 6c 75 65 20 69 73 20 65 78 70 6c 69  o value is expli
1390: 63 69 74 6c 79 20 70 72 6f 76 69 64 65 64 2c 20  citly provided, 
13a0: 53 51 4c 69 74 65 20 63 72 65 61 74 65 73 20 64  SQLite creates d
13b0: 61 74 61 62 61 73 65 73 0a 2a 2a 20 77 69 74 68  atabases.** with
13c0: 20 70 61 67 65 20 73 69 7a 65 20 53 51 4c 49 54   page size SQLIT
13d0: 45 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f 53  E_DEFAULT_PAGE_S
13e0: 49 5a 45 2e 20 48 6f 77 65 76 65 72 2c 20 62 61  IZE. However, ba
13f0: 73 65 64 20 6f 6e 20 63 65 72 74 61 69 6e 0a 2a  sed on certain.*
1400: 2a 20 64 65 76 69 63 65 20 63 68 61 72 61 63 74  * device charact
1410: 65 72 69 73 74 69 63 73 20 28 73 65 63 74 6f 72  eristics (sector
1420: 2d 73 69 7a 65 20 61 6e 64 20 61 74 6f 6d 69 63  -size and atomic
1430: 20 77 72 69 74 65 28 29 20 73 75 70 70 6f 72 74   write() support
1440: 29 2c 0a 2a 2a 20 53 51 4c 69 74 65 20 6d 61 79  ),.** SQLite may
1450: 20 63 68 6f 6f 73 65 20 61 20 6c 61 72 67 65 72   choose a larger
1460: 20 76 61 6c 75 65 2e 20 54 68 69 73 20 63 6f 6e   value. This con
1470: 73 74 61 6e 74 20 69 73 20 74 68 65 20 6d 61 78  stant is the max
1480: 69 6d 75 6d 20 76 61 6c 75 65 0a 2a 2a 20 53 51  imum value.** SQ
1490: 4c 69 74 65 20 77 69 6c 6c 20 63 68 6f 6f 73 65  Lite will choose
14a0: 20 6f 6e 20 69 74 73 20 6f 77 6e 2e 0a 2a 2f 0a   on its own..*/.
14b0: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d  #ifndef SQLITE_M
14c0: 41 58 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f  AX_DEFAULT_PAGE_
14d0: 53 49 5a 45 0a 23 20 64 65 66 69 6e 65 20 53 51  SIZE.# define SQ
14e0: 4c 49 54 45 5f 4d 41 58 5f 44 45 46 41 55 4c 54  LITE_MAX_DEFAULT
14f0: 5f 50 41 47 45 5f 53 49 5a 45 20 38 31 39 32 0a  _PAGE_SIZE 8192.
1500: 23 65 6e 64 69 66 0a 23 69 66 20 53 51 4c 49 54  #endif.#if SQLIT
1510: 45 5f 4d 41 58 5f 44 45 46 41 55 4c 54 5f 50 41  E_MAX_DEFAULT_PA
1520: 47 45 5f 53 49 5a 45 3e 53 51 4c 49 54 45 5f 4d  GE_SIZE>SQLITE_M
1530: 41 58 5f 50 41 47 45 5f 53 49 5a 45 0a 23 20 75  AX_PAGE_SIZE.# u
1540: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f  ndef SQLITE_MAX_
1550: 44 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a  DEFAULT_PAGE_SIZ
1560: 45 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54  E.# define SQLIT
1570: 45 5f 4d 41 58 5f 44 45 46 41 55 4c 54 5f 50 41  E_MAX_DEFAULT_PA
1580: 47 45 5f 53 49 5a 45 20 53 51 4c 49 54 45 5f 4d  GE_SIZE SQLITE_M
1590: 41 58 5f 50 41 47 45 5f 53 49 5a 45 0a 23 65 6e  AX_PAGE_SIZE.#en
15a0: 64 69 66 0a 0a 0a 2f 2a 0a 2a 2a 20 4d 61 78 69  dif.../*.** Maxi
15b0: 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20 70 61  mum number of pa
15c0: 67 65 73 20 69 6e 20 6f 6e 65 20 64 61 74 61 62  ges in one datab
15d0: 61 73 65 20 66 69 6c 65 2e 0a 2a 2a 0a 2a 2a 20  ase file..**.** 
15e0: 54 68 69 73 20 69 73 20 72 65 61 6c 6c 79 20 6a  This is really j
15f0: 75 73 74 20 74 68 65 20 64 65 66 61 75 6c 74 20  ust the default 
1600: 76 61 6c 75 65 20 66 6f 72 20 74 68 65 20 6d 61  value for the ma
1610: 78 5f 70 61 67 65 5f 63 6f 75 6e 74 20 70 72 61  x_page_count pra
1620: 67 6d 61 2e 0a 2a 2a 20 54 68 69 73 20 76 61 6c  gma..** This val
1630: 75 65 20 63 61 6e 20 62 65 20 6c 6f 77 65 72 65  ue can be lowere
1640: 64 20 28 6f 72 20 72 61 69 73 65 64 29 20 61 74  d (or raised) at
1650: 20 72 75 6e 2d 74 69 6d 65 20 75 73 69 6e 67 20   run-time using 
1660: 74 68 61 74 20 74 68 65 0a 2a 2a 20 6d 61 78 5f  that the.** max_
1670: 70 61 67 65 5f 63 6f 75 6e 74 20 6d 61 63 72 6f  page_count macro
1680: 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c  ..*/.#ifndef SQL
1690: 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 43 4f 55  ITE_MAX_PAGE_COU
16a0: 4e 54 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49  NT.# define SQLI
16b0: 54 45 5f 4d 41 58 5f 50 41 47 45 5f 43 4f 55 4e  TE_MAX_PAGE_COUN
16c0: 54 20 31 30 37 33 37 34 31 38 32 33 0a 23 65 6e  T 1073741823.#en
16d0: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 4d 61 78 69 6d  dif../*.** Maxim
16e0: 75 6d 20 6c 65 6e 67 74 68 20 28 69 6e 20 62 79  um length (in by
16f0: 74 65 73 29 20 6f 66 20 74 68 65 20 70 61 74 74  tes) of the patt
1700: 65 72 6e 20 69 6e 20 61 20 4c 49 4b 45 20 6f 72  ern in a LIKE or
1710: 20 47 4c 4f 42 0a 2a 2a 20 6f 70 65 72 61 74 6f   GLOB.** operato
1720: 72 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  r..*/.#ifndef SQ
1730: 4c 49 54 45 5f 4d 41 58 5f 4c 49 4b 45 5f 50 41  LITE_MAX_LIKE_PA
1740: 54 54 45 52 4e 5f 4c 45 4e 47 54 48 0a 23 20 64  TTERN_LENGTH.# d
1750: 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58  efine SQLITE_MAX
1760: 5f 4c 49 4b 45 5f 50 41 54 54 45 52 4e 5f 4c 45  _LIKE_PATTERN_LE
1770: 4e 47 54 48 20 35 30 30 30 30 0a 23 65 6e 64 69  NGTH 50000.#endi
1780: 66 0a 0a 2f 2a 0a 2a 2a 20 4d 61 78 69 6d 75 6d  f../*.** Maximum
1790: 20 64 65 70 74 68 20 6f 66 20 72 65 63 75 72 73   depth of recurs
17a0: 69 6f 6e 20 66 6f 72 20 74 72 69 67 67 65 72 73  ion for triggers
17b0: 2e 0a 2a 2a 0a 2a 2a 20 41 20 76 61 6c 75 65 20  ..**.** A value 
17c0: 6f 66 20 31 20 6d 65 61 6e 73 20 74 68 61 74 20  of 1 means that 
17d0: 61 20 74 72 69 67 67 65 72 20 70 72 6f 67 72 61  a trigger progra
17e0: 6d 20 77 69 6c 6c 20 6e 6f 74 20 62 65 20 61 62  m will not be ab
17f0: 6c 65 20 74 6f 20 69 74 73 65 6c 66 0a 2a 2a 20  le to itself.** 
1800: 66 69 72 65 20 61 6e 79 20 74 72 69 67 67 65 72  fire any trigger
1810: 73 2e 20 41 20 76 61 6c 75 65 20 6f 66 20 30 20  s. A value of 0 
1820: 6d 65 61 6e 73 20 74 68 61 74 20 6e 6f 20 74 72  means that no tr
1830: 69 67 67 65 72 20 70 72 6f 67 72 61 6d 73 20 61  igger programs a
1840: 74 20 61 6c 6c 20 0a 2a 2a 20 6d 61 79 20 62 65  t all .** may be
1850: 20 65 78 65 63 75 74 65 64 2e 0a 2a 2f 0a 23 69   executed..*/.#i
1860: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58  fndef SQLITE_MAX
1870: 5f 54 52 49 47 47 45 52 5f 44 45 50 54 48 0a 23  _TRIGGER_DEPTH.#
1880: 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d   define SQLITE_M
1890: 41 58 5f 54 52 49 47 47 45 52 5f 44 45 50 54 48  AX_TRIGGER_DEPTH
18a0: 20 31 30 30 30 0a 23 65 6e 64 69 66 0a            1000.#endif.