/ Hex Artifact Content
Login

Artifact 504a3161886d2938cbd163054ad620b8356df758:


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 2a 0a 2a 2a 20 40 28 23 29 20 24  ss..**.** @(#) $
01c0: 49 64 3a 20 73 71 6c 69 74 65 4c 69 6d 69 74 2e  Id: sqliteLimit.
01d0: 68 2c 76 20 31 2e 31 30 20 32 30 30 39 2f 30 31  h,v 1.10 2009/01
01e0: 2f 31 30 20 31 36 3a 31 35 3a 30 39 20 64 61 6e  /10 16:15:09 dan
01f0: 69 65 6c 6b 31 39 37 37 20 45 78 70 20 24 0a 2a  ielk1977 Exp $.*
0200: 2f 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61 78  /../*.** The max
0210: 69 6d 75 6d 20 6c 65 6e 67 74 68 20 6f 66 20 61  imum length of a
0220: 20 54 45 58 54 20 6f 72 20 42 4c 4f 42 20 69 6e   TEXT or BLOB in
0230: 20 62 79 74 65 73 2e 20 20 20 54 68 69 73 20 61   bytes.   This a
0240: 6c 73 6f 0a 2a 2a 20 6c 69 6d 69 74 73 20 74 68  lso.** limits th
0250: 65 20 73 69 7a 65 20 6f 66 20 61 20 72 6f 77 20  e size of a row 
0260: 69 6e 20 61 20 74 61 62 6c 65 20 6f 72 20 69 6e  in a table or in
0270: 64 65 78 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 68  dex..**.** The h
0280: 61 72 64 20 6c 69 6d 69 74 20 69 73 20 74 68 65  ard limit is the
0290: 20 61 62 69 6c 69 74 79 20 6f 66 20 61 20 33 32   ability of a 32
02a0: 2d 62 69 74 20 73 69 67 6e 65 64 20 69 6e 74 65  -bit signed inte
02b0: 67 65 72 0a 2a 2a 20 74 6f 20 63 6f 75 6e 74 20  ger.** to count 
02c0: 74 68 65 20 73 69 7a 65 3a 20 32 5e 33 31 2d 31  the size: 2^31-1
02d0: 20 6f 72 20 32 31 34 37 34 38 33 36 34 37 2e 0a   or 2147483647..
02e0: 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  */.#ifndef SQLIT
02f0: 45 5f 4d 41 58 5f 4c 45 4e 47 54 48 0a 23 20 64  E_MAX_LENGTH.# d
0300: 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58  efine SQLITE_MAX
0310: 5f 4c 45 4e 47 54 48 20 31 30 30 30 30 30 30 30  _LENGTH 10000000
0320: 30 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a  00.#endif../*.**
0330: 20 54 68 69 73 20 69 73 20 74 68 65 20 6d 61 78   This is the max
0340: 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 0a 2a  imum number of.*
0350: 2a 0a 2a 2a 20 20 20 20 2a 20 43 6f 6c 75 6d 6e  *.**    * Column
0360: 73 20 69 6e 20 61 20 74 61 62 6c 65 0a 2a 2a 20  s in a table.** 
0370: 20 20 20 2a 20 43 6f 6c 75 6d 6e 73 20 69 6e 20     * Columns in 
0380: 61 6e 20 69 6e 64 65 78 0a 2a 2a 20 20 20 20 2a  an index.**    *
0390: 20 43 6f 6c 75 6d 6e 73 20 69 6e 20 61 20 76 69   Columns in a vi
03a0: 65 77 0a 2a 2a 20 20 20 20 2a 20 54 65 72 6d 73  ew.**    * Terms
03b0: 20 69 6e 20 74 68 65 20 53 45 54 20 63 6c 61 75   in the SET clau
03c0: 73 65 20 6f 66 20 61 6e 20 55 50 44 41 54 45 20  se of an UPDATE 
03d0: 73 74 61 74 65 6d 65 6e 74 0a 2a 2a 20 20 20 20  statement.**    
03e0: 2a 20 54 65 72 6d 73 20 69 6e 20 74 68 65 20 72  * Terms in the r
03f0: 65 73 75 6c 74 20 73 65 74 20 6f 66 20 61 20 53  esult set of a S
0400: 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 0a  ELECT statement.
0410: 2a 2a 20 20 20 20 2a 20 54 65 72 6d 73 20 69 6e  **    * Terms in
0420: 20 74 68 65 20 47 52 4f 55 50 20 42 59 20 6f 72   the GROUP BY or
0430: 20 4f 52 44 45 52 20 42 59 20 63 6c 61 75 73 65   ORDER BY clause
0440: 73 20 6f 66 20 61 20 53 45 4c 45 43 54 20 73 74  s of a SELECT st
0450: 61 74 65 6d 65 6e 74 2e 0a 2a 2a 20 20 20 20 2a  atement..**    *
0460: 20 54 65 72 6d 73 20 69 6e 20 74 68 65 20 56 41   Terms in the VA
0470: 4c 55 45 53 20 63 6c 61 75 73 65 20 6f 66 20 61  LUES clause of a
0480: 6e 20 49 4e 53 45 52 54 20 73 74 61 74 65 6d 65  n INSERT stateme
0490: 6e 74 0a 2a 2a 0a 2a 2a 20 54 68 65 20 68 61 72  nt.**.** The har
04a0: 64 20 75 70 70 65 72 20 6c 69 6d 69 74 20 68 65  d upper limit he
04b0: 72 65 20 69 73 20 33 32 36 37 36 2e 20 20 4d 6f  re is 32676.  Mo
04c0: 73 74 20 64 61 74 61 62 61 73 65 20 70 65 6f 70  st database peop
04d0: 6c 65 20 77 69 6c 6c 0a 2a 2a 20 74 65 6c 6c 20  le will.** tell 
04e0: 79 6f 75 20 74 68 61 74 20 69 6e 20 61 20 77 65  you that in a we
04f0: 6c 6c 2d 6e 6f 72 6d 61 6c 69 7a 65 64 20 64 61  ll-normalized da
0500: 74 61 62 61 73 65 2c 20 79 6f 75 20 75 73 75 61  tabase, you usua
0510: 6c 6c 79 20 73 68 6f 75 6c 64 0a 2a 2a 20 6e 6f  lly should.** no
0520: 74 20 68 61 76 65 20 6d 6f 72 65 20 74 68 61 6e  t have more than
0530: 20 61 20 64 6f 7a 65 6e 20 6f 72 20 73 6f 20 63   a dozen or so c
0540: 6f 6c 75 6d 6e 73 20 69 6e 20 61 6e 79 20 74 61  olumns in any ta
0550: 62 6c 65 2e 20 20 41 6e 64 20 69 66 0a 2a 2a 20  ble.  And if.** 
0560: 74 68 61 74 20 69 73 20 74 68 65 20 63 61 73 65  that is the case
0570: 2c 20 74 68 65 72 65 20 69 73 20 6e 6f 20 70 6f  , there is no po
0580: 69 6e 74 20 69 6e 20 68 61 76 69 6e 67 20 6d 6f  int in having mo
0590: 72 65 20 74 68 61 6e 20 61 20 66 65 77 0a 2a 2a  re than a few.**
05a0: 20 64 6f 7a 65 6e 20 76 61 6c 75 65 73 20 69 6e   dozen values in
05b0: 20 61 6e 79 20 6f 66 20 74 68 65 20 6f 74 68 65   any of the othe
05c0: 72 20 73 69 74 75 61 74 69 6f 6e 73 20 64 65 73  r situations des
05d0: 63 72 69 62 65 64 20 61 62 6f 76 65 2e 0a 2a 2f  cribed above..*/
05e0: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
05f0: 4d 41 58 5f 43 4f 4c 55 4d 4e 0a 23 20 64 65 66  MAX_COLUMN.# def
0600: 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 43  ine SQLITE_MAX_C
0610: 4f 4c 55 4d 4e 20 32 30 30 30 0a 23 65 6e 64 69  OLUMN 2000.#endi
0620: 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61 78  f../*.** The max
0630: 69 6d 75 6d 20 6c 65 6e 67 74 68 20 6f 66 20 61  imum length of a
0640: 20 73 69 6e 67 6c 65 20 53 51 4c 20 73 74 61 74   single SQL stat
0650: 65 6d 65 6e 74 20 69 6e 20 62 79 74 65 73 2e 0a  ement in bytes..
0660: 2a 2a 0a 2a 2a 20 49 74 20 75 73 65 64 20 74 6f  **.** It used to
0670: 20 62 65 20 74 68 65 20 63 61 73 65 20 74 68 61   be the case tha
0680: 74 20 73 65 74 74 69 6e 67 20 74 68 69 73 20 76  t setting this v
0690: 61 6c 75 65 20 74 6f 20 7a 65 72 6f 20 77 6f 75  alue to zero wou
06a0: 6c 64 0a 2a 2a 20 74 75 72 6e 20 74 68 65 20 6c  ld.** turn the l
06b0: 69 6d 69 74 20 6f 66 66 2e 20 20 54 68 61 74 20  imit off.  That 
06c0: 69 73 20 6e 6f 20 6c 6f 6e 67 65 72 20 74 72 75  is no longer tru
06d0: 65 2e 20 20 49 74 20 69 73 20 6e 6f 74 20 70 6f  e.  It is not po
06e0: 73 73 69 62 6c 65 0a 2a 2a 20 74 6f 20 74 75 72  ssible.** to tur
06f0: 6e 20 74 68 69 73 20 6c 69 6d 69 74 20 6f 66 66  n this limit off
0700: 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c  ..*/.#ifndef SQL
0710: 49 54 45 5f 4d 41 58 5f 53 51 4c 5f 4c 45 4e 47  ITE_MAX_SQL_LENG
0720: 54 48 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49  TH.# define SQLI
0730: 54 45 5f 4d 41 58 5f 53 51 4c 5f 4c 45 4e 47 54  TE_MAX_SQL_LENGT
0740: 48 20 31 30 30 30 30 30 30 30 30 30 0a 23 65 6e  H 1000000000.#en
0750: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d  dif../*.** The m
0760: 61 78 69 6d 75 6d 20 64 65 70 74 68 20 6f 66 20  aximum depth of 
0770: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 74 72  an expression tr
0780: 65 65 2e 20 54 68 69 73 20 69 73 20 6c 69 6d 69  ee. This is limi
0790: 74 65 64 20 74 6f 20 0a 2a 2a 20 73 6f 6d 65 20  ted to .** some 
07a0: 65 78 74 65 6e 74 20 62 79 20 53 51 4c 49 54 45  extent by SQLITE
07b0: 5f 4d 41 58 5f 53 51 4c 5f 4c 45 4e 47 54 48 2e  _MAX_SQL_LENGTH.
07c0: 20 42 75 74 20 73 6f 6d 65 74 69 6d 65 20 79 6f   But sometime yo
07d0: 75 20 6d 69 67 68 74 20 0a 2a 2a 20 77 61 6e 74  u might .** want
07e0: 20 74 6f 20 70 6c 61 63 65 20 6d 6f 72 65 20 73   to place more s
07f0: 65 76 65 72 65 20 6c 69 6d 69 74 73 20 6f 6e 20  evere limits on 
0800: 74 68 65 20 63 6f 6d 70 6c 65 78 69 74 79 20 6f  the complexity o
0810: 66 20 61 6e 20 0a 2a 2a 20 65 78 70 72 65 73 73  f an .** express
0820: 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20 41 20 76 61 6c  ion..**.** A val
0830: 75 65 20 6f 66 20 30 20 75 73 65 64 20 74 6f 20  ue of 0 used to 
0840: 6d 65 61 6e 20 74 68 61 74 20 74 68 65 20 6c 69  mean that the li
0850: 6d 69 74 20 77 61 73 20 6e 6f 74 20 65 6e 66 6f  mit was not enfo
0860: 72 63 65 64 2e 0a 2a 2a 20 42 75 74 20 74 68 61  rced..** But tha
0870: 74 20 69 73 20 6e 6f 20 6c 6f 6e 67 65 72 20 74  t is no longer t
0880: 72 75 65 2e 20 20 54 68 65 20 6c 69 6d 69 74 20  rue.  The limit 
0890: 69 73 20 6e 6f 77 20 73 74 72 69 63 74 6c 79 20  is now strictly 
08a0: 65 6e 66 6f 72 63 65 64 0a 2a 2a 20 61 74 20 61  enforced.** at a
08b0: 6c 6c 20 74 69 6d 65 73 2e 0a 2a 2f 0a 23 69 66  ll times..*/.#if
08c0: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f  ndef SQLITE_MAX_
08d0: 45 58 50 52 5f 44 45 50 54 48 0a 23 20 64 65 66  EXPR_DEPTH.# def
08e0: 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 45  ine SQLITE_MAX_E
08f0: 58 50 52 5f 44 45 50 54 48 20 31 30 30 30 0a 23  XPR_DEPTH 1000.#
0900: 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65  endif../*.** The
0910: 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20   maximum number 
0920: 6f 66 20 74 65 72 6d 73 20 69 6e 20 61 20 63 6f  of terms in a co
0930: 6d 70 6f 75 6e 64 20 53 45 4c 45 43 54 20 73 74  mpound SELECT st
0940: 61 74 65 6d 65 6e 74 2e 0a 2a 2a 20 54 68 65 20  atement..** The 
0950: 63 6f 64 65 20 67 65 6e 65 72 61 74 6f 72 20 66  code generator f
0960: 6f 72 20 63 6f 6d 70 6f 75 6e 64 20 53 45 4c 45  or compound SELE
0970: 43 54 20 73 74 61 74 65 6d 65 6e 74 73 20 64 6f  CT statements do
0980: 65 73 20 6f 6e 65 0a 2a 2a 20 6c 65 76 65 6c 20  es one.** level 
0990: 6f 66 20 72 65 63 75 72 73 69 6f 6e 20 66 6f 72  of recursion for
09a0: 20 65 61 63 68 20 74 65 72 6d 2e 20 20 41 20 73   each term.  A s
09b0: 74 61 63 6b 20 6f 76 65 72 66 6c 6f 77 20 63 61  tack overflow ca
09c0: 6e 20 72 65 73 75 6c 74 0a 2a 2a 20 69 66 20 74  n result.** if t
09d0: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 74 65 72  he number of ter
09e0: 6d 73 20 69 73 20 74 6f 6f 20 6c 61 72 67 65 2e  ms is too large.
09f0: 20 20 49 6e 20 70 72 61 63 74 69 63 65 2c 20 6d    In practice, m
0a00: 6f 73 74 20 53 51 4c 0a 2a 2a 20 6e 65 76 65 72  ost SQL.** never
0a10: 20 68 61 73 20 6d 6f 72 65 20 74 68 61 6e 20 33   has more than 3
0a20: 20 6f 72 20 34 20 74 65 72 6d 73 2e 20 20 55 73   or 4 terms.  Us
0a30: 65 20 61 20 76 61 6c 75 65 20 6f 66 20 30 20 74  e a value of 0 t
0a40: 6f 20 64 69 73 61 62 6c 65 0a 2a 2a 20 61 6e 79  o disable.** any
0a50: 20 6c 69 6d 69 74 20 6f 6e 20 74 68 65 20 6e 75   limit on the nu
0a60: 6d 62 65 72 20 6f 66 20 74 65 72 6d 73 20 69 6e  mber of terms in
0a70: 20 61 20 63 6f 6d 70 6f 75 6e 74 20 53 45 4c 45   a compount SELE
0a80: 43 54 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53  CT..*/.#ifndef S
0a90: 51 4c 49 54 45 5f 4d 41 58 5f 43 4f 4d 50 4f 55  QLITE_MAX_COMPOU
0aa0: 4e 44 5f 53 45 4c 45 43 54 0a 23 20 64 65 66 69  ND_SELECT.# defi
0ab0: 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 43 4f  ne SQLITE_MAX_CO
0ac0: 4d 50 4f 55 4e 44 5f 53 45 4c 45 43 54 20 35 30  MPOUND_SELECT 50
0ad0: 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20  0.#endif../*.** 
0ae0: 54 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  The maximum numb
0af0: 65 72 20 6f 66 20 6f 70 63 6f 64 65 73 20 69 6e  er of opcodes in
0b00: 20 61 20 56 44 42 45 20 70 72 6f 67 72 61 6d 2e   a VDBE program.
0b10: 0a 2a 2a 20 4e 6f 74 20 63 75 72 72 65 6e 74 6c  .** Not currentl
0b20: 79 20 65 6e 66 6f 72 63 65 64 2e 0a 2a 2f 0a 23  y enforced..*/.#
0b30: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 41  ifndef SQLITE_MA
0b40: 58 5f 56 44 42 45 5f 4f 50 0a 23 20 64 65 66 69  X_VDBE_OP.# defi
0b50: 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 56 44  ne SQLITE_MAX_VD
0b60: 42 45 5f 4f 50 20 32 35 30 30 30 0a 23 65 6e 64  BE_OP 25000.#end
0b70: 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61  if../*.** The ma
0b80: 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20  ximum number of 
0b90: 61 72 67 75 6d 65 6e 74 73 20 74 6f 20 61 6e 20  arguments to an 
0ba0: 53 51 4c 20 66 75 6e 63 74 69 6f 6e 2e 0a 2a 2f  SQL function..*/
0bb0: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
0bc0: 4d 41 58 5f 46 55 4e 43 54 49 4f 4e 5f 41 52 47  MAX_FUNCTION_ARG
0bd0: 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45  .# define SQLITE
0be0: 5f 4d 41 58 5f 46 55 4e 43 54 49 4f 4e 5f 41 52  _MAX_FUNCTION_AR
0bf0: 47 20 31 32 37 0a 23 65 6e 64 69 66 0a 0a 2f 2a  G 127.#endif../*
0c00: 0a 2a 2a 20 54 68 65 20 6d 61 78 69 6d 75 6d 20  .** The maximum 
0c10: 6e 75 6d 62 65 72 20 6f 66 20 69 6e 2d 6d 65 6d  number of in-mem
0c20: 6f 72 79 20 70 61 67 65 73 20 74 6f 20 75 73 65  ory pages to use
0c30: 20 66 6f 72 20 74 68 65 20 6d 61 69 6e 20 64 61   for the main da
0c40: 74 61 62 61 73 65 0a 2a 2a 20 74 61 62 6c 65 20  tabase.** table 
0c50: 61 6e 64 20 66 6f 72 20 74 65 6d 70 6f 72 61 72  and for temporar
0c60: 79 20 74 61 62 6c 65 73 2e 20 20 54 68 65 20 53  y tables.  The S
0c70: 51 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f 43 41  QLITE_DEFAULT_CA
0c80: 43 48 45 5f 53 49 5a 45 0a 2a 2f 0a 23 69 66 6e  CHE_SIZE.*/.#ifn
0c90: 64 65 66 20 53 51 4c 49 54 45 5f 44 45 46 41 55  def SQLITE_DEFAU
0ca0: 4c 54 5f 43 41 43 48 45 5f 53 49 5a 45 0a 23 20  LT_CACHE_SIZE.# 
0cb0: 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 44 45  define SQLITE_DE
0cc0: 46 41 55 4c 54 5f 43 41 43 48 45 5f 53 49 5a 45  FAULT_CACHE_SIZE
0cd0: 20 20 32 30 30 30 0a 23 65 6e 64 69 66 0a 23 69    2000.#endif.#i
0ce0: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 44 45 46  fndef SQLITE_DEF
0cf0: 41 55 4c 54 5f 54 45 4d 50 5f 43 41 43 48 45 5f  AULT_TEMP_CACHE_
0d00: 53 49 5a 45 0a 23 20 64 65 66 69 6e 65 20 53 51  SIZE.# define SQ
0d10: 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f 54 45 4d  LITE_DEFAULT_TEM
0d20: 50 5f 43 41 43 48 45 5f 53 49 5a 45 20 20 35 30  P_CACHE_SIZE  50
0d30: 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20  0.#endif../*.** 
0d40: 54 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  The maximum numb
0d50: 65 72 20 6f 66 20 61 74 74 61 63 68 65 64 20 64  er of attached d
0d60: 61 74 61 62 61 73 65 73 2e 20 20 54 68 69 73 20  atabases.  This 
0d70: 6d 75 73 74 20 62 65 20 62 65 74 77 65 65 6e 20  must be between 
0d80: 30 0a 2a 2a 20 61 6e 64 20 33 30 2e 20 20 54 68  0.** and 30.  Th
0d90: 65 20 75 70 70 65 72 20 62 6f 75 6e 64 20 6f 6e  e upper bound on
0da0: 20 33 30 20 69 73 20 62 65 63 61 75 73 65 20 61   30 is because a
0db0: 20 33 32 2d 62 69 74 20 69 6e 74 65 67 65 72 20   32-bit integer 
0dc0: 62 69 74 6d 61 70 0a 2a 2a 20 69 73 20 75 73 65  bitmap.** is use
0dd0: 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20 74 6f 20  d internally to 
0de0: 74 72 61 63 6b 20 61 74 74 61 63 68 65 64 20 64  track attached d
0df0: 61 74 61 62 61 73 65 73 2e 0a 2a 2f 0a 23 69 66  atabases..*/.#if
0e00: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f  ndef SQLITE_MAX_
0e10: 41 54 54 41 43 48 45 44 0a 23 20 64 65 66 69 6e  ATTACHED.# defin
0e20: 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 41 54 54  e SQLITE_MAX_ATT
0e30: 41 43 48 45 44 20 31 30 0a 23 65 6e 64 69 66 0a  ACHED 10.#endif.
0e40: 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61 78 69  ../*.** The maxi
0e50: 6d 75 6d 20 76 61 6c 75 65 20 6f 66 20 61 20 3f  mum value of a ?
0e60: 6e 6e 6e 20 77 69 6c 64 63 61 72 64 20 74 68 61  nnn wildcard tha
0e70: 74 20 74 68 65 20 70 61 72 73 65 72 20 77 69 6c  t the parser wil
0e80: 6c 20 61 63 63 65 70 74 2e 0a 2a 2f 0a 23 69 66  l accept..*/.#if
0e90: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f  ndef SQLITE_MAX_
0ea0: 56 41 52 49 41 42 4c 45 5f 4e 55 4d 42 45 52 0a  VARIABLE_NUMBER.
0eb0: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
0ec0: 4d 41 58 5f 56 41 52 49 41 42 4c 45 5f 4e 55 4d  MAX_VARIABLE_NUM
0ed0: 42 45 52 20 39 39 39 0a 23 65 6e 64 69 66 0a 0a  BER 999.#endif..
0ee0: 2f 2a 20 4d 61 78 69 6d 75 6d 20 70 61 67 65 20  /* Maximum page 
0ef0: 73 69 7a 65 2e 20 20 54 68 65 20 75 70 70 65 72  size.  The upper
0f00: 20 62 6f 75 6e 64 20 6f 6e 20 74 68 69 73 20 76   bound on this v
0f10: 61 6c 75 65 20 69 73 20 33 32 37 36 38 2e 20 20  alue is 32768.  
0f20: 54 68 69 73 20 61 20 6c 69 6d 69 74 0a 2a 2a 20  This a limit.** 
0f30: 69 6d 70 6f 73 65 64 20 62 79 20 74 68 65 20 6e  imposed by the n
0f40: 65 63 65 73 73 69 74 79 20 6f 66 20 73 74 6f 72  ecessity of stor
0f50: 69 6e 67 20 74 68 65 20 76 61 6c 75 65 20 69 6e  ing the value in
0f60: 20 61 20 32 2d 62 79 74 65 20 75 6e 73 69 67 6e   a 2-byte unsign
0f70: 65 64 20 69 6e 74 65 67 65 72 0a 2a 2a 20 61 6e  ed integer.** an
0f80: 64 20 74 68 65 20 66 61 63 74 20 74 68 61 74 20  d the fact that 
0f90: 74 68 65 20 70 61 67 65 20 73 69 7a 65 20 6d 75  the page size mu
0fa0: 73 74 20 62 65 20 61 20 70 6f 77 65 72 20 6f 66  st be a power of
0fb0: 20 32 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 69   2..**.** If thi
0fc0: 73 20 6c 69 6d 69 74 20 69 73 20 63 68 61 6e 67  s limit is chang
0fd0: 65 64 2c 20 74 68 65 6e 20 74 68 65 20 63 6f 6d  ed, then the com
0fe0: 70 69 6c 65 64 20 6c 69 62 72 61 72 79 20 69 73  piled library is
0ff0: 20 74 65 63 68 6e 69 63 61 6c 6c 79 0a 2a 2a 20   technically.** 
1000: 69 6e 63 6f 6d 70 61 74 69 62 6c 65 20 77 69 74  incompatible wit
1010: 68 20 61 6e 20 53 51 4c 69 74 65 20 6c 69 62 72  h an SQLite libr
1020: 61 72 79 20 63 6f 6d 70 69 6c 65 64 20 77 69 74  ary compiled wit
1030: 68 20 61 20 64 69 66 66 65 72 65 6e 74 20 6c 69  h a different li
1040: 6d 69 74 2e 20 49 66 0a 2a 2a 20 61 20 70 72 6f  mit. If.** a pro
1050: 63 65 73 73 20 6f 70 65 72 61 74 69 6e 67 20 6f  cess operating o
1060: 6e 20 61 20 64 61 74 61 62 61 73 65 20 77 69 74  n a database wit
1070: 68 20 61 20 70 61 67 65 2d 73 69 7a 65 20 6f 66  h a page-size of
1080: 20 36 35 35 33 36 20 62 79 74 65 73 20 0a 2a 2a   65536 bytes .**
1090: 20 63 72 61 73 68 65 73 2c 20 74 68 65 6e 20 61   crashes, then a
10a0: 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 20 53 51  n instance of SQ
10b0: 4c 69 74 65 20 63 6f 6d 70 69 6c 65 64 20 77 69  Lite compiled wi
10c0: 74 68 20 74 68 65 20 64 65 66 61 75 6c 74 20 70  th the default p
10d0: 61 67 65 2d 73 69 7a 65 20 0a 2a 2a 20 6c 69 6d  age-size .** lim
10e0: 69 74 20 77 69 6c 6c 20 6e 6f 74 20 62 65 20 61  it will not be a
10f0: 62 6c 65 20 74 6f 20 72 6f 6c 6c 62 61 63 6b 20  ble to rollback 
1100: 74 68 65 20 61 62 6f 72 74 65 64 20 74 72 61 6e  the aborted tran
1110: 73 61 63 74 69 6f 6e 2e 20 54 68 69 73 20 63 6f  saction. This co
1120: 75 6c 64 0a 2a 2a 20 6c 65 61 64 20 74 6f 20 64  uld.** lead to d
1130: 61 74 61 62 61 73 65 20 63 6f 72 72 75 70 74 69  atabase corrupti
1140: 6f 6e 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53  on..*/.#ifndef S
1150: 51 4c 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53  QLITE_MAX_PAGE_S
1160: 49 5a 45 0a 23 20 64 65 66 69 6e 65 20 53 51 4c  IZE.# define SQL
1170: 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49 5a  ITE_MAX_PAGE_SIZ
1180: 45 20 33 32 37 36 38 0a 23 65 6e 64 69 66 0a 0a  E 32768.#endif..
1190: 0a 2f 2a 0a 2a 2a 20 54 68 65 20 64 65 66 61 75  ./*.** The defau
11a0: 6c 74 20 73 69 7a 65 20 6f 66 20 61 20 64 61 74  lt size of a dat
11b0: 61 62 61 73 65 20 70 61 67 65 2e 0a 2a 2f 0a 23  abase page..*/.#
11c0: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 44 45  ifndef SQLITE_DE
11d0: 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45 0a  FAULT_PAGE_SIZE.
11e0: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
11f0: 44 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a  DEFAULT_PAGE_SIZ
1200: 45 20 31 30 32 34 0a 23 65 6e 64 69 66 0a 23 69  E 1024.#endif.#i
1210: 66 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c 54  f SQLITE_DEFAULT
1220: 5f 50 41 47 45 5f 53 49 5a 45 3e 53 51 4c 49 54  _PAGE_SIZE>SQLIT
1230: 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49 5a 45 0a  E_MAX_PAGE_SIZE.
1240: 23 20 75 6e 64 65 66 20 53 51 4c 49 54 45 5f 44  # undef SQLITE_D
1250: 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45  EFAULT_PAGE_SIZE
1260: 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45  .# define SQLITE
1270: 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49  _DEFAULT_PAGE_SI
1280: 5a 45 20 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41  ZE SQLITE_MAX_PA
1290: 47 45 5f 53 49 5a 45 0a 23 65 6e 64 69 66 0a 0a  GE_SIZE.#endif..
12a0: 2f 2a 0a 2a 2a 20 4f 72 64 69 6e 61 72 69 6c 79  /*.** Ordinarily
12b0: 2c 20 69 66 20 6e 6f 20 76 61 6c 75 65 20 69 73  , if no value is
12c0: 20 65 78 70 6c 69 63 69 74 6c 79 20 70 72 6f 76   explicitly prov
12d0: 69 64 65 64 2c 20 53 51 4c 69 74 65 20 63 72 65  ided, SQLite cre
12e0: 61 74 65 73 20 64 61 74 61 62 61 73 65 73 0a 2a  ates databases.*
12f0: 2a 20 77 69 74 68 20 70 61 67 65 20 73 69 7a 65  * with page size
1300: 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f   SQLITE_DEFAULT_
1310: 50 41 47 45 5f 53 49 5a 45 2e 20 48 6f 77 65 76  PAGE_SIZE. Howev
1320: 65 72 2c 20 62 61 73 65 64 20 6f 6e 20 63 65 72  er, based on cer
1330: 74 61 69 6e 0a 2a 2a 20 64 65 76 69 63 65 20 63  tain.** device c
1340: 68 61 72 61 63 74 65 72 69 73 74 69 63 73 20 28  haracteristics (
1350: 73 65 63 74 6f 72 2d 73 69 7a 65 20 61 6e 64 20  sector-size and 
1360: 61 74 6f 6d 69 63 20 77 72 69 74 65 28 29 20 73  atomic write() s
1370: 75 70 70 6f 72 74 29 2c 0a 2a 2a 20 53 51 4c 69  upport),.** SQLi
1380: 74 65 20 6d 61 79 20 63 68 6f 6f 73 65 20 61 20  te may choose a 
1390: 6c 61 72 67 65 72 20 76 61 6c 75 65 2e 20 54 68  larger value. Th
13a0: 69 73 20 63 6f 6e 73 74 61 6e 74 20 69 73 20 74  is constant is t
13b0: 68 65 20 6d 61 78 69 6d 75 6d 20 76 61 6c 75 65  he maximum value
13c0: 0a 2a 2a 20 53 51 4c 69 74 65 20 77 69 6c 6c 20  .** SQLite will 
13d0: 63 68 6f 6f 73 65 20 6f 6e 20 69 74 73 20 6f 77  choose on its ow
13e0: 6e 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  n..*/.#ifndef SQ
13f0: 4c 49 54 45 5f 4d 41 58 5f 44 45 46 41 55 4c 54  LITE_MAX_DEFAULT
1400: 5f 50 41 47 45 5f 53 49 5a 45 0a 23 20 64 65 66  _PAGE_SIZE.# def
1410: 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 44  ine SQLITE_MAX_D
1420: 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45  EFAULT_PAGE_SIZE
1430: 20 38 31 39 32 0a 23 65 6e 64 69 66 0a 23 69 66   8192.#endif.#if
1440: 20 53 51 4c 49 54 45 5f 4d 41 58 5f 44 45 46 41   SQLITE_MAX_DEFA
1450: 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45 3e 53 51  ULT_PAGE_SIZE>SQ
1460: 4c 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49  LITE_MAX_PAGE_SI
1470: 5a 45 0a 23 20 75 6e 64 65 66 20 53 51 4c 49 54  ZE.# undef SQLIT
1480: 45 5f 4d 41 58 5f 44 45 46 41 55 4c 54 5f 50 41  E_MAX_DEFAULT_PA
1490: 47 45 5f 53 49 5a 45 0a 23 20 64 65 66 69 6e 65  GE_SIZE.# define
14a0: 20 53 51 4c 49 54 45 5f 4d 41 58 5f 44 45 46 41   SQLITE_MAX_DEFA
14b0: 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45 20 53 51  ULT_PAGE_SIZE SQ
14c0: 4c 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f 53 49  LITE_MAX_PAGE_SI
14d0: 5a 45 0a 23 65 6e 64 69 66 0a 0a 0a 2f 2a 0a 2a  ZE.#endif.../*.*
14e0: 2a 20 4d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72  * Maximum number
14f0: 20 6f 66 20 70 61 67 65 73 20 69 6e 20 6f 6e 65   of pages in one
1500: 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e 0a   database file..
1510: 2a 2a 0a 2a 2a 20 54 68 69 73 20 69 73 20 72 65  **.** This is re
1520: 61 6c 6c 79 20 6a 75 73 74 20 74 68 65 20 64 65  ally just the de
1530: 66 61 75 6c 74 20 76 61 6c 75 65 20 66 6f 72 20  fault value for 
1540: 74 68 65 20 6d 61 78 5f 70 61 67 65 5f 63 6f 75  the max_page_cou
1550: 6e 74 20 70 72 61 67 6d 61 2e 0a 2a 2a 20 54 68  nt pragma..** Th
1560: 69 73 20 76 61 6c 75 65 20 63 61 6e 20 62 65 20  is value can be 
1570: 6c 6f 77 65 72 65 64 20 28 6f 72 20 72 61 69 73  lowered (or rais
1580: 65 64 29 20 61 74 20 72 75 6e 2d 74 69 6d 65 20  ed) at run-time 
1590: 75 73 69 6e 67 20 74 68 61 74 20 74 68 65 0a 2a  using that the.*
15a0: 2a 20 6d 61 78 5f 70 61 67 65 5f 63 6f 75 6e 74  * max_page_count
15b0: 20 6d 61 63 72 6f 2e 0a 2a 2f 0a 23 69 66 6e 64   macro..*/.#ifnd
15c0: 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41  ef SQLITE_MAX_PA
15d0: 47 45 5f 43 4f 55 4e 54 0a 23 20 64 65 66 69 6e  GE_COUNT.# defin
15e0: 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41 47  e SQLITE_MAX_PAG
15f0: 45 5f 43 4f 55 4e 54 20 31 30 37 33 37 34 31 38  E_COUNT 10737418
1600: 32 33 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a  23.#endif../*.**
1610: 20 4d 61 78 69 6d 75 6d 20 6c 65 6e 67 74 68 20   Maximum length 
1620: 28 69 6e 20 62 79 74 65 73 29 20 6f 66 20 74 68  (in bytes) of th
1630: 65 20 70 61 74 74 65 72 6e 20 69 6e 20 61 20 4c  e pattern in a L
1640: 49 4b 45 20 6f 72 20 47 4c 4f 42 0a 2a 2a 20 6f  IKE or GLOB.** o
1650: 70 65 72 61 74 6f 72 2e 0a 2a 2f 0a 23 69 66 6e  perator..*/.#ifn
1660: 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 4c  def SQLITE_MAX_L
1670: 49 4b 45 5f 50 41 54 54 45 52 4e 5f 4c 45 4e 47  IKE_PATTERN_LENG
1680: 54 48 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49  TH.# define SQLI
1690: 54 45 5f 4d 41 58 5f 4c 49 4b 45 5f 50 41 54 54  TE_MAX_LIKE_PATT
16a0: 45 52 4e 5f 4c 45 4e 47 54 48 20 35 30 30 30 30  ERN_LENGTH 50000
16b0: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 4d  .#endif../*.** M
16c0: 61 78 69 6d 75 6d 20 64 65 70 74 68 20 6f 66 20  aximum depth of 
16d0: 72 65 63 75 72 73 69 6f 6e 20 66 6f 72 20 74 72  recursion for tr
16e0: 69 67 67 65 72 73 2e 0a 2a 2f 0a 23 69 66 6e 64  iggers..*/.#ifnd
16f0: 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 54 52  ef SQLITE_MAX_TR
1700: 49 47 47 45 52 5f 44 45 50 54 48 0a 23 69 66 20  IGGER_DEPTH.#if 
1710: 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 53  defined(SQLITE_S
1720: 4d 41 4c 4c 5f 53 54 41 43 4b 29 0a 23 20 64 65  MALL_STACK).# de
1730: 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f  fine SQLITE_MAX_
1740: 54 52 49 47 47 45 52 5f 44 45 50 54 48 20 31 30  TRIGGER_DEPTH 10
1750: 0a 23 65 6c 73 65 0a 23 20 64 65 66 69 6e 65 20  .#else.# define 
1760: 53 51 4c 49 54 45 5f 4d 41 58 5f 54 52 49 47 47  SQLITE_MAX_TRIGG
1770: 45 52 5f 44 45 50 54 48 20 31 30 30 30 0a 23 65  ER_DEPTH 1000.#e
1780: 6e 64 69 66 0a 23 65 6e 64 69 66 0a              ndif.#endif.