Documentation Source Text

Hex Artifact Content
Login

Artifact 21c6c0dd3b573d0f676a201e8bbd8b43c76853faf9c50822d3f6c4ce90fb7f6b:


0000: 3c 74 69 74 6c 65 3e 41 6e 20 49 6e 74 72 6f 64  <title>An Introd
0010: 75 63 74 69 6f 6e 20 54 6f 20 54 68 65 20 53 51  uction To The SQ
0020: 4c 69 74 65 20 43 2f 43 2b 2b 20 49 6e 74 65 72  Lite C/C++ Inter
0030: 66 61 63 65 3c 2f 74 69 74 6c 65 3e 0a 3c 74 61  face</title>.<ta
0040: 62 6c 65 5f 6f 66 5f 63 6f 6e 74 65 6e 74 73 3e  ble_of_contents>
0050: 0a 3c 74 63 6c 3e 0a 68 64 5f 6b 65 79 77 6f 72  .<tcl>.hd_keywor
0060: 64 73 20 7b 2a 63 69 6e 74 72 6f 7d 0a 3c 2f 74  ds {*cintro}.</t
0070: 63 6c 3e 0a 0a 3c 74 61 62 6c 65 5f 6f 66 5f 63  cl>..<table_of_c
0080: 6f 6e 74 65 6e 74 73 3e 0a 0a 3c 68 31 3e 53 75  ontents>..<h1>Su
0090: 6d 6d 61 72 79 3c 2f 68 31 3e 0a 0a 3c 70 3e 54  mmary</h1>..<p>T
00a0: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 77 6f  he following two
00b0: 20 6f 62 6a 65 63 74 73 20 61 6e 64 20 65 69 67   objects and eig
00c0: 68 74 20 6d 65 74 68 6f 64 73 20 63 6f 6d 70 72  ht methods compr
00d0: 69 73 65 20 74 68 65 20 65 73 73 65 6e 74 69 61  ise the essentia
00e0: 6c 0a 65 6c 65 6d 65 6e 74 73 20 6f 66 20 74 68  l.elements of th
00f0: 65 20 53 51 4c 69 74 65 20 69 6e 74 65 72 66 61  e SQLite interfa
0100: 63 65 3a 0a 0a 3c 75 6c 3e 0a 3c 6c 69 3e 3c 70  ce:..<ul>.<li><p
0110: 3e 3c 62 3e 5b 73 71 6c 69 74 65 33 5d 3c 2f 62  ><b>[sqlite3]</b
0120: 3e 20 26 72 61 72 72 3b 0a 54 68 65 20 64 61 74  > &rarr;.The dat
0130: 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  abase connection
0140: 20 6f 62 6a 65 63 74 2e 20 20 43 72 65 61 74 65   object.  Create
0150: 64 20 62 79 0a 5b 73 71 6c 69 74 65 33 5f 6f 70  d by.[sqlite3_op
0160: 65 6e 28 29 5d 20 61 6e 64 20 64 65 73 74 72 6f  en()] and destro
0170: 79 65 64 20 62 79 20 5b 73 71 6c 69 74 65 33 5f  yed by [sqlite3_
0180: 63 6c 6f 73 65 28 29 5d 2e 0a 0a 3c 6c 69 3e 3c  close()]...<li><
0190: 70 3e 3c 62 3e 5b 73 71 6c 69 74 65 33 5f 73 74  p><b>[sqlite3_st
01a0: 6d 74 5d 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 54  mt]</b> &rarr;.T
01b0: 68 65 20 70 72 65 70 61 72 65 64 20 73 74 61 74  he prepared stat
01c0: 65 6d 65 6e 74 20 6f 62 6a 65 63 74 2e 20 20 43  ement object.  C
01d0: 72 65 61 74 65 64 20 62 79 0a 5b 73 71 6c 69 74  reated by.[sqlit
01e0: 65 33 5f 70 72 65 70 61 72 65 28 29 5d 20 61 6e  e3_prepare()] an
01f0: 64 20 64 65 73 74 72 6f 79 65 64 20 62 79 20 5b  d destroyed by [
0200: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
0210: 28 29 5d 2e 0a 0a 0a 3c 6c 69 3e 3c 70 3e 3c 62  ()]....<li><p><b
0220: 3e 5b 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28 29  >[sqlite3_open()
0230: 5d 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 4f 70 65  ]</b> &rarr;.Ope
0240: 6e 20 61 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 74  n a connection t
0250: 6f 20 61 20 6e 65 77 20 6f 72 20 65 78 69 73 74  o a new or exist
0260: 69 6e 67 20 53 51 4c 69 74 65 20 64 61 74 61 62  ing SQLite datab
0270: 61 73 65 2e 0a 54 68 65 20 63 6f 6e 73 74 72 75  ase..The constru
0280: 63 74 6f 72 20 66 6f 72 20 5b 73 71 6c 69 74 65  ctor for [sqlite
0290: 33 5d 2e 0a 0a 3c 6c 69 3e 3c 70 3e 3c 62 3e 5b  3]...<li><p><b>[
02a0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 28  sqlite3_prepare(
02b0: 29 5d 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 43 6f  )]</b> &rarr;.Co
02c0: 6d 70 69 6c 65 20 53 51 4c 20 74 65 78 74 20 69  mpile SQL text i
02d0: 6e 74 6f 0a 62 79 74 65 2d 63 6f 64 65 20 74 68  nto.byte-code th
02e0: 61 74 20 77 69 6c 6c 20 64 6f 20 74 68 65 20 77  at will do the w
02f0: 6f 72 6b 20 6f 66 20 71 75 65 72 79 69 6e 67 20  ork of querying 
0300: 6f 72 20 75 70 64 61 74 69 6e 67 20 74 68 65 20  or updating the 
0310: 64 61 74 61 62 61 73 65 2e 20 0a 54 68 65 20 63  database. .The c
0320: 6f 6e 73 74 72 75 63 74 6f 72 20 66 6f 72 20 5b  onstructor for [
0330: 73 71 6c 69 74 65 33 5f 73 74 6d 74 5d 2e 0a 0a  sqlite3_stmt]...
0340: 3c 6c 69 3e 3c 70 3e 3c 62 3e 5b 73 71 6c 69 74  <li><p><b>[sqlit
0350: 65 33 5f 62 69 6e 64 5f 69 6e 74 7c 73 71 6c 69  e3_bind_int|sqli
0360: 74 65 33 5f 62 69 6e 64 28 29 5d 3c 2f 62 3e 20  te3_bind()]</b> 
0370: 26 72 61 72 72 3b 0a 53 74 6f 72 65 20 61 70 70  &rarr;.Store app
0380: 6c 69 63 61 74 69 6f 6e 20 64 61 74 61 20 69 6e  lication data in
0390: 74 6f 0a 5b 70 61 72 61 6d 65 74 65 72 73 5d 20  to.[parameters] 
03a0: 6f 66 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20  of the original 
03b0: 53 51 4c 2e 0a 0a 0a 3c 6c 69 3e 3c 70 3e 3c 62  SQL....<li><p><b
03c0: 3e 5b 73 71 6c 69 74 65 33 5f 73 74 65 70 28 29  >[sqlite3_step()
03d0: 5d 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 41 64 76  ]</b> &rarr;.Adv
03e0: 61 6e 63 65 20 61 6e 20 5b 73 71 6c 69 74 65 33  ance an [sqlite3
03f0: 5f 73 74 6d 74 5d 20 74 6f 20 74 68 65 20 6e 65  _stmt] to the ne
0400: 78 74 20 72 65 73 75 6c 74 20 72 6f 77 20 6f 72  xt result row or
0410: 20 74 6f 20 63 6f 6d 70 6c 65 74 69 6f 6e 2e 0a   to completion..
0420: 0a 3c 6c 69 3e 3c 70 3e 3c 62 3e 5b 73 71 6c 69  .<li><p><b>[sqli
0430: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 7c 73  te3_column_int|s
0440: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 28 29 5d  qlite3_column()]
0450: 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 43 6f 6c 75  </b> &rarr;.Colu
0460: 6d 6e 20 76 61 6c 75 65 73 20 69 6e 20 74 68 65  mn values in the
0470: 20 63 75 72 72 65 6e 74 20 72 65 73 75 6c 74 20   current result 
0480: 72 6f 77 20 66 6f 72 20 61 6e 20 5b 73 71 6c 69  row for an [sqli
0490: 74 65 33 5f 73 74 6d 74 5d 2e 0a 0a 3c 6c 69 3e  te3_stmt]...<li>
04a0: 3c 70 3e 3c 62 3e 5b 73 71 6c 69 74 65 33 5f 66  <p><b>[sqlite3_f
04b0: 69 6e 61 6c 69 7a 65 28 29 5d 3c 2f 62 3e 20 26  inalize()]</b> &
04c0: 72 61 72 72 3b 0a 44 65 73 74 72 75 63 74 6f 72  rarr;.Destructor
04d0: 20 66 6f 72 20 5b 73 71 6c 69 74 65 33 5f 73 74   for [sqlite3_st
04e0: 6d 74 5d 2e 0a 0a 3c 6c 69 3e 3c 70 3e 3c 62 3e  mt]...<li><p><b>
04f0: 5b 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28 29  [sqlite3_close()
0500: 5d 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 44 65 73  ]</b> &rarr;.Des
0510: 74 72 75 63 74 6f 72 20 66 6f 72 20 5b 73 71 6c  tructor for [sql
0520: 69 74 65 33 5d 2e 0a 0a 3c 6c 69 3e 3c 70 3e 3c  ite3]...<li><p><
0530: 62 3e 5b 73 71 6c 69 74 65 33 5f 65 78 65 63 28  b>[sqlite3_exec(
0540: 29 5d 3c 2f 62 3e 20 26 72 61 72 72 3b 0a 41 20  )]</b> &rarr;.A 
0550: 77 72 61 70 70 65 72 20 66 75 6e 63 74 69 6f 6e  wrapper function
0560: 20 74 68 61 74 20 64 6f 65 73 20 5b 73 71 6c 69   that does [sqli
0570: 74 65 33 5f 70 72 65 70 61 72 65 28 29 5d 2c 20  te3_prepare()], 
0580: 5b 73 71 6c 69 74 65 33 5f 73 74 65 70 28 29 5d  [sqlite3_step()]
0590: 2c 0a 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ,.[sqlite3_colum
05a0: 6e 5f 69 6e 74 7c 73 71 6c 69 74 65 33 5f 63 6f  n_int|sqlite3_co
05b0: 6c 75 6d 6e 28 29 5d 2c 20 61 6e 64 20 5b 73 71  lumn()], and [sq
05c0: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 29  lite3_finalize()
05d0: 5d 20 66 6f 72 0a 61 20 73 74 72 69 6e 67 20 6f  ] for.a string o
05e0: 66 20 6f 6e 65 20 6f 72 20 6d 6f 72 65 20 53 51  f one or more SQ
05f0: 4c 20 73 74 61 74 65 6d 65 6e 74 73 2e 0a 3c 2f  L statements..</
0600: 75 6c 3e 0a 0a 3c 68 31 3e 49 6e 74 72 6f 64 75  ul>..<h1>Introdu
0610: 63 74 69 6f 6e 3c 2f 68 31 3e 0a 0a 3c 70 3e 0a  ction</h1>..<p>.
0620: 20 20 53 51 4c 69 74 65 20 68 61 73 20 6d 6f 72    SQLite has mor
0630: 65 20 74 68 61 6e 20 32 32 35 20 41 50 49 73 2e  e than 225 APIs.
0640: 0a 20 20 48 6f 77 65 76 65 72 2c 20 6d 6f 73 74  .  However, most
0650: 20 6f 66 20 74 68 65 20 41 50 49 73 20 61 72 65   of the APIs are
0660: 20 6f 70 74 69 6f 6e 61 6c 20 61 6e 64 20 76 65   optional and ve
0670: 72 79 20 73 70 65 63 69 61 6c 69 7a 65 64 0a 20  ry specialized. 
0680: 20 61 6e 64 20 63 61 6e 20 62 65 20 69 67 6e 6f   and can be igno
0690: 72 65 64 20 62 79 20 62 65 67 69 6e 6e 65 72 73  red by beginners
06a0: 2e 0a 20 20 54 68 65 20 63 6f 72 65 20 41 50 49  ..  The core API
06b0: 20 69 73 20 73 6d 61 6c 6c 2c 20 73 69 6d 70 6c   is small, simpl
06c0: 65 2c 20 61 6e 64 20 65 61 73 79 20 74 6f 20 6c  e, and easy to l
06d0: 65 61 72 6e 2e 0a 20 20 54 68 69 73 20 61 72 74  earn..  This art
06e0: 69 63 6c 65 20 73 75 6d 6d 61 72 69 7a 65 73 20  icle summarizes 
06f0: 74 68 65 20 63 6f 72 65 20 41 50 49 2e 0a 3c 2f  the core API..</
0700: 70 3e 0a 0a 3c 70 3e 0a 20 20 41 20 73 65 70 61  p>..<p>.  A sepa
0710: 72 61 74 65 20 64 6f 63 75 6d 65 6e 74 2c 20 5b  rate document, [
0720: 63 61 70 69 33 72 65 66 20 7c 20 54 68 65 20 53  capi3ref | The S
0730: 51 4c 69 74 65 20 43 2f 43 2b 2b 20 49 6e 74 65  QLite C/C++ Inte
0740: 72 66 61 63 65 5d 2c 0a 20 20 70 72 6f 76 69 64  rface],.  provid
0750: 65 73 20 64 65 74 61 69 6c 65 64 0a 20 20 73 70  es detailed.  sp
0760: 65 63 69 66 69 63 61 74 69 6f 6e 73 20 66 6f 72  ecifications for
0770: 20 61 6c 6c 20 43 2f 43 2b 2b 20 41 50 49 73 20   all C/C++ APIs 
0780: 66 6f 72 20 53 51 4c 69 74 65 2e 20 20 4f 6e 63  for SQLite.  Onc
0790: 65 0a 20 20 74 68 65 20 72 65 61 64 65 72 0a 20  e.  the reader. 
07a0: 20 75 6e 64 65 72 73 74 61 6e 64 73 20 74 68 65   understands the
07b0: 20 62 61 73 69 63 20 70 72 69 6e 63 69 70 6c 65   basic principle
07c0: 73 20 6f 66 20 6f 70 65 72 61 74 69 6f 6e 20 66  s of operation f
07d0: 6f 72 20 53 51 4c 69 74 65 2c 20 0a 20 20 5b 63  or SQLite, .  [c
07e0: 61 70 69 33 72 65 66 20 7c 20 74 68 61 74 20 64  api3ref | that d
07f0: 6f 63 75 6d 65 6e 74 5d 20 73 68 6f 75 6c 64 20  ocument] should 
0800: 62 65 20 75 73 65 64 20 61 73 20 61 20 72 65 66  be used as a ref
0810: 65 72 65 6e 63 65 0a 20 20 67 75 69 64 65 2e 20  erence.  guide. 
0820: 20 54 68 69 73 20 61 72 74 69 63 6c 65 20 69 73   This article is
0830: 20 69 6e 74 65 6e 64 65 64 20 61 73 20 69 6e 74   intended as int
0840: 72 6f 64 75 63 74 69 6f 6e 20 6f 6e 6c 79 20 61  roduction only a
0850: 6e 64 20 69 73 20 6e 65 69 74 68 65 72 20 61 0a  nd is neither a.
0860: 20 20 63 6f 6d 70 6c 65 74 65 20 6e 6f 72 20 61    complete nor a
0870: 75 74 68 6f 72 69 74 61 74 69 76 65 20 72 65 66  uthoritative ref
0880: 65 72 65 6e 63 65 20 66 6f 72 20 74 68 65 20 53  erence for the S
0890: 51 4c 69 74 65 20 41 50 49 2e 0a 3c 2f 70 3e 0a  QLite API..</p>.
08a0: 0a 3c 68 31 3e 43 6f 72 65 20 4f 62 6a 65 63 74  .<h1>Core Object
08b0: 73 20 41 6e 64 20 49 6e 74 65 72 66 61 63 65 73  s And Interfaces
08c0: 3c 2f 68 31 3e 0a 0a 3c 70 3e 0a 20 20 54 68 65  </h1>..<p>.  The
08d0: 20 70 72 69 6e 63 69 70 61 6c 20 74 61 73 6b 20   principal task 
08e0: 6f 66 20 61 6e 20 53 51 4c 20 64 61 74 61 62 61  of an SQL databa
08f0: 73 65 20 65 6e 67 69 6e 65 20 69 73 20 74 6f 20  se engine is to 
0900: 65 76 61 6c 75 61 74 65 20 53 51 4c 20 73 74 61  evaluate SQL sta
0910: 74 65 6d 65 6e 74 73 0a 20 20 6f 66 20 53 51 4c  tements.  of SQL
0920: 2e 20 20 54 6f 20 61 63 63 6f 6d 70 6c 69 73 68  .  To accomplish
0930: 20 74 68 69 73 2c 20 74 68 65 20 64 65 76 65 6c   this, the devel
0940: 6f 70 65 72 20 6e 65 65 64 73 20 74 77 6f 20 6f  oper needs two o
0950: 62 6a 65 63 74 73 3a 0a 3c 2f 70 3e 0a 0a 3c 70  bjects:.</p>..<p
0960: 3e 3c 75 6c 3e 0a 20 20 3c 6c 69 3e 20 54 68 65  ><ul>.  <li> The
0970: 20 5b 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65   [database conne
0980: 63 74 69 6f 6e 5d 20 6f 62 6a 65 63 74 3a 20 73  ction] object: s
0990: 71 6c 69 74 65 33 20 3c 2f 6c 69 3e 0a 20 20 3c  qlite3 </li>.  <
09a0: 6c 69 3e 20 54 68 65 20 5b 70 72 65 70 61 72 65  li> The [prepare
09b0: 64 20 73 74 61 74 65 6d 65 6e 74 5d 20 6f 62 6a  d statement] obj
09c0: 65 63 74 3a 20 73 71 6c 69 74 65 33 5f 73 74 6d  ect: sqlite3_stm
09d0: 74 20 3c 2f 6c 69 3e 0a 3c 2f 75 6c 3e 3c 2f 70  t </li>.</ul></p
09e0: 3e 0a 0a 3c 70 3e 0a 20 20 53 74 72 69 63 74 6c  >..<p>.  Strictl
09f0: 79 20 73 70 65 61 6b 69 6e 67 2c 20 74 68 65 20  y speaking, the 
0a00: 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d  [prepared statem
0a10: 65 6e 74 5d 20 6f 62 6a 65 63 74 20 69 73 20 6e  ent] object is n
0a20: 6f 74 20 72 65 71 75 69 72 65 64 20 73 69 6e 63  ot required sinc
0a30: 65 0a 20 20 74 68 65 20 63 6f 6e 76 65 6e 69 65  e.  the convenie
0a40: 6e 63 65 20 77 72 61 70 70 65 72 20 69 6e 74 65  nce wrapper inte
0a50: 72 66 61 63 65 73 2c 20 5b 73 71 6c 69 74 65 33  rfaces, [sqlite3
0a60: 5f 65 78 65 63 5d 20 6f 72 0a 20 20 5b 73 71 6c  _exec] or.  [sql
0a70: 69 74 65 33 5f 67 65 74 5f 74 61 62 6c 65 5d 2c  ite3_get_table],
0a80: 20 63 61 6e 20 62 65 20 75 73 65 64 20 61 6e 64   can be used and
0a90: 20 74 68 65 73 65 20 63 6f 6e 76 65 6e 69 65 6e   these convenien
0aa0: 63 65 20 77 72 61 70 70 65 72 73 0a 20 20 65 6e  ce wrappers.  en
0ab0: 63 61 70 73 75 6c 61 74 65 20 61 6e 64 20 68 69  capsulate and hi
0ac0: 64 65 20 74 68 65 20 5b 70 72 65 70 61 72 65 64  de the [prepared
0ad0: 20 73 74 61 74 65 6d 65 6e 74 5d 20 6f 62 6a 65   statement] obje
0ae0: 63 74 2e 0a 20 20 4e 65 76 65 72 74 68 65 6c 65  ct..  Neverthele
0af0: 73 73 2c 20 61 6e 20 75 6e 64 65 72 73 74 61 6e  ss, an understan
0b00: 64 69 6e 67 20 6f 66 0a 20 20 5b 70 72 65 70 61  ding of.  [prepa
0b10: 72 65 64 20 73 74 61 74 65 6d 65 6e 74 73 5d 20  red statements] 
0b20: 69 73 20 6e 65 65 64 65 64 20 74 6f 20 6d 61 6b  is needed to mak
0b30: 65 20 66 75 6c 6c 20 75 73 65 20 6f 66 20 53 51  e full use of SQ
0b40: 4c 69 74 65 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a  Lite..</p>..<p>.
0b50: 20 20 54 68 65 20 5b 64 61 74 61 62 61 73 65 20    The [database 
0b60: 63 6f 6e 6e 65 63 74 69 6f 6e 5d 20 61 6e 64 20  connection] and 
0b70: 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d  [prepared statem
0b80: 65 6e 74 5d 20 6f 62 6a 65 63 74 73 20 61 72 65  ent] objects are
0b90: 20 63 6f 6e 74 72 6f 6c 6c 65 64 0a 20 20 62 79   controlled.  by
0ba0: 20 61 20 73 6d 61 6c 6c 20 73 65 74 20 6f 66 20   a small set of 
0bb0: 43 2f 43 2b 2b 20 69 6e 74 65 72 66 61 63 65 20  C/C++ interface 
0bc0: 72 6f 75 74 69 6e 65 20 6c 69 73 74 65 64 20 62  routine listed b
0bd0: 65 6c 6f 77 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 3c  elow..</p>..<p><
0be0: 75 6c 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71 6c 69  ul>.  <li> [sqli
0bf0: 74 65 33 5f 6f 70 65 6e 28 29 5d 20 3c 2f 6c 69  te3_open()] </li
0c00: 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65  >.  <li> [sqlite
0c10: 33 5f 70 72 65 70 61 72 65 28 29 5d 20 3c 2f 6c  3_prepare()] </l
0c20: 69 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74  i>.  <li> [sqlit
0c30: 65 33 5f 73 74 65 70 28 29 5d 20 3c 2f 6c 69 3e  e3_step()] </li>
0c40: 0a 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33  .  <li> [sqlite3
0c50: 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 20 7c 20 73 71  _column_int | sq
0c60: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 28 29 5d 20  lite3_column()] 
0c70: 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71  </li>.  <li> [sq
0c80: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 29  lite3_finalize()
0c90: 5d 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 5b  ] </li>.  <li> [
0ca0: 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28 29 5d  sqlite3_close()]
0cb0: 20 3c 2f 6c 69 3e 0a 3c 2f 75 6c 3e 3c 2f 70 3e   </li>.</ul></p>
0cc0: 0a 0a 3c 70 3e 0a 20 20 4e 6f 74 65 20 74 68 61  ..<p>.  Note tha
0cd0: 74 20 74 68 65 20 6c 69 73 74 20 6f 66 20 72 6f  t the list of ro
0ce0: 75 74 69 6e 65 73 20 61 62 6f 76 65 20 69 73 20  utines above is 
0cf0: 63 6f 6e 63 65 70 74 75 61 6c 20 72 61 74 68 65  conceptual rathe
0d00: 72 20 74 68 61 6e 20 61 63 74 75 61 6c 2e 0a 20  r than actual.. 
0d10: 20 4d 61 6e 79 20 6f 66 20 74 68 65 73 65 20 72   Many of these r
0d20: 6f 75 74 69 6e 65 73 20 63 6f 6d 65 20 69 6e 20  outines come in 
0d30: 6d 75 6c 74 69 70 6c 65 20 76 65 72 73 69 6f 6e  multiple version
0d40: 73 2e 0a 20 20 46 6f 72 20 65 78 61 6d 70 6c 65  s..  For example
0d50: 2c 20 74 68 65 20 6c 69 73 74 20 61 62 6f 76 65  , the list above
0d60: 20 73 68 6f 77 73 20 61 20 73 69 6e 67 6c 65 20   shows a single 
0d70: 72 6f 75 74 69 6e 65 0a 20 20 6e 61 6d 65 64 20  routine.  named 
0d80: 5b 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28 29 5d  [sqlite3_open()]
0d90: 20 77 68 65 6e 20 69 6e 20 66 61 63 74 20 74 68   when in fact th
0da0: 65 72 65 20 61 72 65 20 74 68 72 65 65 20 73 65  ere are three se
0db0: 70 61 72 61 74 65 20 72 6f 75 74 69 6e 65 73 0a  parate routines.
0dc0: 20 20 74 68 61 74 20 61 63 63 6f 6d 70 6c 69 73    that accomplis
0dd0: 68 20 74 68 65 20 73 61 6d 65 20 74 68 69 6e 67  h the same thing
0de0: 20 69 6e 20 73 6c 69 67 68 74 6c 79 20 64 69 66   in slightly dif
0df0: 66 65 72 65 6e 74 20 77 61 79 73 3a 0a 20 20 5b  ferent ways:.  [
0e00: 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28 29 5d 2c  sqlite3_open()],
0e10: 20 5b 73 71 6c 69 74 65 33 5f 6f 70 65 6e 31 36   [sqlite3_open16
0e20: 28 29 5d 20 61 6e 64 20 5b 73 71 6c 69 74 65 33  ()] and [sqlite3
0e30: 5f 6f 70 65 6e 5f 76 32 28 29 5d 2e 0a 20 20 54  _open_v2()]..  T
0e40: 68 65 20 6c 69 73 74 20 6d 65 6e 74 69 6f 6e 73  he list mentions
0e50: 20 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e   [sqlite3_column
0e60: 5f 69 6e 74 20 7c 20 73 71 6c 69 74 65 33 5f 63  _int | sqlite3_c
0e70: 6f 6c 75 6d 6e 28 29 5d 0a 20 20 77 68 65 6e 20  olumn()].  when 
0e80: 69 6e 20 66 61 63 74 20 6e 6f 20 73 75 63 68 20  in fact no such 
0e90: 72 6f 75 74 69 6e 65 20 65 78 69 73 74 73 2e 0a  routine exists..
0ea0: 20 20 54 68 65 20 22 73 71 6c 69 74 65 33 5f 63    The "sqlite3_c
0eb0: 6f 6c 75 6d 6e 28 29 22 20 73 68 6f 77 6e 20 69  olumn()" shown i
0ec0: 6e 20 74 68 65 20 6c 69 73 74 20 69 73 20 61 20  n the list is a 
0ed0: 70 6c 61 63 65 68 6f 6c 64 65 72 20 66 6f 72 0a  placeholder for.
0ee0: 20 20 61 6e 20 65 6e 74 69 72 65 20 66 61 6d 69    an entire fami
0ef0: 6c 79 20 6f 66 20 72 6f 75 74 69 6e 65 73 20 74  ly of routines t
0f00: 68 61 74 20 65 78 74 72 61 20 63 6f 6c 75 6d 6e  hat extra column
0f10: 0a 20 20 64 61 74 61 20 69 6e 20 76 61 72 69 6f  .  data in vario
0f20: 75 73 20 64 61 74 61 74 79 70 65 73 2e 0a 3c 2f  us datatypes..</
0f30: 70 3e 0a 0a 3c 70 3e 0a 20 20 48 65 72 65 20 69  p>..<p>.  Here i
0f40: 73 20 61 20 73 75 6d 6d 61 72 79 20 6f 66 20 77  s a summary of w
0f50: 68 61 74 20 74 68 65 20 63 6f 72 65 20 69 6e 74  hat the core int
0f60: 65 72 66 61 63 65 73 20 64 6f 3a 0a 3c 2f 70 3e  erfaces do:.</p>
0f70: 0a 0a 3c 75 6c 3e 0a 0a 3c 6c 69 3e 3c 70 3e 3c  ..<ul>..<li><p><
0f80: 62 3e 5b 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28  b>[sqlite3_open(
0f90: 29 5d 3c 2f 62 3e 0a 3c 70 3e 0a 20 20 54 68 69  )]</b>.<p>.  Thi
0fa0: 73 20 72 6f 75 74 69 6e 65 20 0a 20 20 6f 70 65  s routine .  ope
0fb0: 6e 73 20 61 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  ns a connection 
0fc0: 74 6f 20 61 6e 20 53 51 4c 69 74 65 20 64 61 74  to an SQLite dat
0fd0: 61 62 61 73 65 20 66 69 6c 65 20 61 6e 64 20 72  abase file and r
0fe0: 65 74 75 72 6e 73 20 61 0a 20 20 5b 64 61 74 61  eturns a.  [data
0ff0: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 5d  base connection]
1000: 20 6f 62 6a 65 63 74 2e 20 20 54 68 69 73 20 69   object.  This i
1010: 73 20 6f 66 74 65 6e 20 74 68 65 20 66 69 72 73  s often the firs
1020: 74 20 53 51 4c 69 74 65 20 41 50 49 0a 20 20 63  t SQLite API.  c
1030: 61 6c 6c 20 74 68 61 74 20 61 6e 20 61 70 70 6c  all that an appl
1040: 69 63 61 74 69 6f 6e 20 6d 61 6b 65 73 20 61 6e  ication makes an
1050: 64 20 69 73 20 61 20 70 72 65 72 65 71 75 69 73  d is a prerequis
1060: 69 74 65 20 66 6f 72 20 6d 6f 73 74 20 6f 74 68  ite for most oth
1070: 65 72 0a 20 20 53 51 4c 69 74 65 20 41 50 49 73  er.  SQLite APIs
1080: 2e 20 20 4d 61 6e 79 20 53 51 4c 69 74 65 20 69  .  Many SQLite i
1090: 6e 74 65 72 66 61 63 65 73 20 72 65 71 75 69 72  nterfaces requir
10a0: 65 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 0a 20  e a pointer to. 
10b0: 20 74 68 65 20 5b 64 61 74 61 62 61 73 65 20 63   the [database c
10c0: 6f 6e 6e 65 63 74 69 6f 6e 5d 20 6f 62 6a 65 63  onnection] objec
10d0: 74 20 61 73 20 74 68 65 69 72 20 66 69 72 73 74  t as their first
10e0: 20 70 61 72 61 6d 65 74 65 72 20 61 6e 64 20 63   parameter and c
10f0: 61 6e 0a 20 20 62 65 20 74 68 6f 75 67 68 74 20  an.  be thought 
1100: 6f 66 20 61 73 20 6d 65 74 68 6f 64 73 20 6f 6e  of as methods on
1110: 20 74 68 65 20 5b 64 61 74 61 62 61 73 65 20 63   the [database c
1120: 6f 6e 6e 65 63 74 69 6f 6e 5d 20 6f 62 6a 65 63  onnection] objec
1130: 74 2e 0a 20 20 54 68 69 73 20 72 6f 75 74 69 6e  t..  This routin
1140: 65 20 69 73 20 74 68 65 20 63 6f 6e 73 74 72 75  e is the constru
1150: 63 74 6f 72 20 66 6f 72 20 74 68 65 20 5b 64 61  ctor for the [da
1160: 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f  tabase connectio
1170: 6e 5d 20 6f 62 6a 65 63 74 2e 0a 3c 2f 70 3e 0a  n] object..</p>.
1180: 0a 3c 6c 69 3e 3c 70 3e 3c 62 3e 5b 73 71 6c 69  .<li><p><b>[sqli
1190: 74 65 33 5f 70 72 65 70 61 72 65 28 29 5d 3c 2f  te3_prepare()]</
11a0: 62 3e 0a 3c 70 3e 0a 20 20 54 68 69 73 20 72 6f  b>.<p>.  This ro
11b0: 75 74 69 6e 65 0a 20 20 63 6f 6e 76 65 72 74 73  utine.  converts
11c0: 20 53 51 4c 20 74 65 78 74 20 69 6e 74 6f 20 61   SQL text into a
11d0: 20 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65   [prepared state
11e0: 6d 65 6e 74 5d 20 6f 62 6a 65 63 74 20 61 6e 64  ment] object and
11f0: 20 72 65 74 75 72 6e 73 20 61 20 70 6f 69 6e 74   returns a point
1200: 65 72 0a 20 20 74 6f 20 74 68 61 74 20 6f 62 6a  er.  to that obj
1210: 65 63 74 2e 20 20 54 68 69 73 20 69 6e 74 65 72  ect.  This inter
1220: 66 61 63 65 20 72 65 71 75 69 72 65 73 20 61 20  face requires a 
1230: 5b 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63  [database connec
1240: 74 69 6f 6e 5d 20 70 6f 69 6e 74 65 72 0a 20 20  tion] pointer.  
1250: 63 72 65 61 74 65 64 20 62 79 20 61 20 70 72 69  created by a pri
1260: 6f 72 20 63 61 6c 6c 20 74 6f 20 5b 73 71 6c 69  or call to [sqli
1270: 74 65 33 5f 6f 70 65 6e 28 29 5d 20 61 6e 64 20  te3_open()] and 
1280: 61 20 74 65 78 74 20 73 74 72 69 6e 67 20 63 6f  a text string co
1290: 6e 74 61 69 6e 69 6e 67 0a 20 20 74 68 65 20 53  ntaining.  the S
12a0: 51 4c 20 73 74 61 74 65 6d 65 6e 74 20 74 6f 20  QL statement to 
12b0: 62 65 20 70 72 65 70 61 72 65 64 2e 20 20 54 68  be prepared.  Th
12c0: 69 73 20 41 50 49 20 64 6f 65 73 20 6e 6f 74 20  is API does not 
12d0: 61 63 74 75 61 6c 6c 79 20 65 76 61 6c 75 61 74  actually evaluat
12e0: 65 0a 20 20 74 68 65 20 53 51 4c 20 73 74 61 74  e.  the SQL stat
12f0: 65 6d 65 6e 74 2e 20 20 49 74 20 6d 65 72 65 6c  ement.  It merel
1300: 79 20 70 72 65 70 61 72 65 73 20 74 68 65 20 53  y prepares the S
1310: 51 4c 20 73 74 61 74 65 6d 65 6e 74 20 66 6f 72  QL statement for
1320: 20 65 76 61 6c 75 61 74 69 6f 6e 2e 0a 0a 20 20   evaluation...  
1330: 3c 70 3e 54 68 69 6e 6b 20 6f 66 20 65 61 63 68  <p>Think of each
1340: 20 53 51 4c 20 73 74 61 74 65 6d 65 6e 74 20 61   SQL statement a
1350: 73 20 61 20 73 6d 61 6c 6c 20 63 6f 6d 70 75 74  s a small comput
1360: 65 72 20 70 72 6f 67 72 61 6d 2e 20 20 54 68 65  er program.  The
1370: 20 70 75 72 70 6f 73 65 0a 20 20 6f 66 20 5b 73   purpose.  of [s
1380: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 28 29  qlite3_prepare()
1390: 5d 20 69 73 20 74 6f 20 63 6f 6d 70 69 6c 65 20  ] is to compile 
13a0: 74 68 61 74 20 70 72 6f 67 72 61 6d 20 69 6e 74  that program int
13b0: 6f 20 6f 62 6a 65 63 74 20 63 6f 64 65 2e 0a 20  o object code.. 
13c0: 20 54 68 65 20 5b 70 72 65 70 61 72 65 64 20 73   The [prepared s
13d0: 74 61 74 65 6d 65 6e 74 5d 20 69 73 20 74 68 65  tatement] is the
13e0: 20 6f 62 6a 65 63 74 20 63 6f 64 65 2e 20 20 54   object code.  T
13f0: 68 65 20 5b 73 71 6c 69 74 65 33 5f 73 74 65 70  he [sqlite3_step
1400: 28 29 5d 20 69 6e 74 65 72 66 61 63 65 0a 20 20  ()] interface.  
1410: 74 68 65 6e 20 72 75 6e 73 20 74 68 65 20 6f 62  then runs the ob
1420: 6a 65 63 74 20 63 6f 64 65 20 74 6f 20 67 65 74  ject code to get
1430: 20 61 20 72 65 73 75 6c 74 2e 0a 0a 20 20 3c 70   a result...  <p
1440: 3e 4e 65 77 20 61 70 70 6c 69 63 61 74 69 6f 6e  >New application
1450: 73 20 73 68 6f 75 6c 64 20 61 6c 77 61 79 73 20  s should always 
1460: 69 6e 76 6f 6b 65 20 5b 73 71 6c 69 74 65 33 5f  invoke [sqlite3_
1470: 70 72 65 70 61 72 65 5f 76 32 28 29 5d 20 69 6e  prepare_v2()] in
1480: 73 74 65 61 64 0a 20 20 6f 66 20 5b 73 71 6c 69  stead.  of [sqli
1490: 74 65 33 5f 70 72 65 70 61 72 65 28 29 5d 2e 20  te3_prepare()]. 
14a0: 20 54 68 65 20 6f 6c 64 65 72 20 5b 73 71 6c 69   The older [sqli
14b0: 74 65 33 5f 70 72 65 70 61 72 65 28 29 5d 20 69  te3_prepare()] i
14c0: 73 20 72 65 74 61 69 6e 65 64 20 66 6f 72 0a 20  s retained for. 
14d0: 20 62 61 63 6b 77 61 72 64 73 20 63 6f 6d 70 61   backwards compa
14e0: 74 69 62 69 6c 69 74 79 2e 20 20 42 75 74 20 5b  tibility.  But [
14f0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
1500: 76 32 28 29 5d 20 70 72 6f 76 69 64 65 73 20 61  v2()] provides a
1510: 20 6d 75 63 68 0a 20 20 62 65 74 74 65 72 20 69   much.  better i
1520: 6e 74 65 72 66 61 63 65 2e 3c 2f 70 3e 0a 0a 3c  nterface.</p>..<
1530: 6c 69 3e 3c 70 3e 3c 62 3e 5b 73 71 6c 69 74 65  li><p><b>[sqlite
1540: 33 5f 73 74 65 70 28 29 5d 3c 2f 62 3e 0a 3c 70  3_step()]</b>.<p
1550: 3e 0a 20 20 54 68 69 73 20 72 6f 75 74 69 6e 65  >.  This routine
1560: 20 69 73 20 75 73 65 64 20 74 6f 20 65 76 61 6c   is used to eval
1570: 75 61 74 65 20 61 20 5b 70 72 65 70 61 72 65 64  uate a [prepared
1580: 20 73 74 61 74 65 6d 65 6e 74 5d 20 74 68 61 74   statement] that
1590: 20 68 61 73 20 62 65 65 6e 0a 20 20 70 72 65 76   has been.  prev
15a0: 69 6f 75 73 6c 79 20 63 72 65 61 74 65 64 20 62  iously created b
15b0: 79 20 74 68 65 20 5b 73 71 6c 69 74 65 33 5f 70  y the [sqlite3_p
15c0: 72 65 70 61 72 65 28 29 5d 20 69 6e 74 65 72 66  repare()] interf
15d0: 61 63 65 2e 20 20 54 68 65 20 73 74 61 74 65 6d  ace.  The statem
15e0: 65 6e 74 0a 20 20 69 73 20 65 76 61 6c 75 61 74  ent.  is evaluat
15f0: 65 64 20 75 70 20 74 6f 20 74 68 65 20 70 6f 69  ed up to the poi
1600: 6e 74 20 77 68 65 72 65 20 74 68 65 20 66 69 72  nt where the fir
1610: 73 74 20 72 6f 77 20 6f 66 20 72 65 73 75 6c 74  st row of result
1620: 73 20 61 72 65 20 61 76 61 69 6c 61 62 6c 65 2e  s are available.
1630: 0a 20 20 54 6f 20 61 64 76 61 6e 63 65 20 74 6f  .  To advance to
1640: 20 74 68 65 20 73 65 63 6f 6e 64 20 72 6f 77 20   the second row 
1650: 6f 66 20 72 65 73 75 6c 74 73 2c 20 69 6e 76 6f  of results, invo
1660: 6b 65 20 5b 73 71 6c 69 74 65 33 5f 73 74 65 70  ke [sqlite3_step
1670: 28 29 5d 20 61 67 61 69 6e 2e 0a 20 20 43 6f 6e  ()] again..  Con
1680: 74 69 6e 75 65 20 69 6e 76 6f 6b 69 6e 67 20 5b  tinue invoking [
1690: 73 71 6c 69 74 65 33 5f 73 74 65 70 28 29 5d 20  sqlite3_step()] 
16a0: 75 6e 74 69 6c 20 74 68 65 20 73 74 61 74 65 6d  until the statem
16b0: 65 6e 74 20 69 73 20 63 6f 6d 70 6c 65 74 65 2e  ent is complete.
16c0: 0a 20 20 53 74 61 74 65 6d 65 6e 74 73 20 74 68  .  Statements th
16d0: 61 74 20 64 6f 20 6e 6f 74 20 72 65 74 75 72 6e  at do not return
16e0: 20 72 65 73 75 6c 74 73 20 28 65 78 3a 20 49 4e   results (ex: IN
16f0: 53 45 52 54 2c 20 55 50 44 41 54 45 2c 20 6f 72  SERT, UPDATE, or
1700: 20 44 45 4c 45 54 45 0a 20 20 73 74 61 74 65 6d   DELETE.  statem
1710: 65 6e 74 73 29 20 72 75 6e 20 74 6f 20 63 6f 6d  ents) run to com
1720: 70 6c 65 74 69 6f 6e 20 6f 6e 20 61 20 73 69 6e  pletion on a sin
1730: 67 6c 65 20 63 61 6c 6c 20 74 6f 20 5b 73 71 6c  gle call to [sql
1740: 69 74 65 33 5f 73 74 65 70 28 29 5d 2e 0a 0a 3c  ite3_step()]...<
1750: 6c 69 3e 3c 70 3e 3c 62 3e 5b 73 71 6c 69 74 65  li><p><b>[sqlite
1760: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 20 7c 20 73  3_column_int | s
1770: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 28 29 5d  qlite3_column()]
1780: 3c 2f 62 3e 0a 3c 70 3e 0a 20 20 54 68 69 73 20  </b>.<p>.  This 
1790: 72 6f 75 74 69 6e 65 20 72 65 74 75 72 6e 73 20  routine returns 
17a0: 61 20 73 69 6e 67 6c 65 20 63 6f 6c 75 6d 6e 20  a single column 
17b0: 66 72 6f 6d 20 74 68 65 20 63 75 72 72 65 6e 74  from the current
17c0: 20 72 6f 77 20 6f 66 20 61 20 72 65 73 75 6c 74   row of a result
17d0: 0a 20 20 73 65 74 20 66 6f 72 20 61 20 5b 70 72  .  set for a [pr
17e0: 65 70 61 72 65 64 20 73 74 61 74 65 6d 65 6e 74  epared statement
17f0: 5d 20 74 68 61 74 20 69 73 20 62 65 69 6e 67 20  ] that is being 
1800: 65 76 61 6c 75 61 74 65 64 20 62 79 20 5b 73 71  evaluated by [sq
1810: 6c 69 74 65 33 5f 73 74 65 70 28 29 5d 2e 0a 20  lite3_step()].. 
1820: 20 45 61 63 68 20 74 69 6d 65 20 5b 73 71 6c 69   Each time [sqli
1830: 74 65 33 5f 73 74 65 70 28 29 5d 20 73 74 6f 70  te3_step()] stop
1840: 73 20 77 69 74 68 20 61 20 6e 65 77 20 72 65 73  s with a new res
1850: 75 6c 74 20 73 65 74 20 72 6f 77 2c 20 74 68 69  ult set row, thi
1860: 73 20 72 6f 75 74 69 6e 65 0a 20 20 63 61 6e 20  s routine.  can 
1870: 62 65 20 63 61 6c 6c 65 64 20 6d 75 6c 74 69 70  be called multip
1880: 6c 65 20 74 69 6d 65 73 20 74 6f 20 66 69 6e 64  le times to find
1890: 20 74 68 65 20 76 61 6c 75 65 73 20 6f 66 20 61   the values of a
18a0: 6c 6c 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 74 68  ll columns in th
18b0: 61 74 20 72 6f 77 2e 0a 20 20 0a 20 20 3c 70 3e  at row..  .  <p>
18c0: 41 73 20 6e 6f 74 65 64 20 61 62 6f 76 65 2c 20  As noted above, 
18d0: 74 68 65 72 65 20 72 65 61 6c 6c 79 20 69 73 20  there really is 
18e0: 6e 6f 20 73 75 63 68 20 74 68 69 6e 67 20 61 73  no such thing as
18f0: 20 61 20 22 73 71 6c 69 74 65 33 5f 63 6f 6c 75   a "sqlite3_colu
1900: 6d 6e 28 29 22 0a 20 20 66 75 6e 63 74 69 6f 6e  mn()".  function
1910: 20 69 6e 20 74 68 65 20 53 51 4c 69 74 65 20 41   in the SQLite A
1920: 50 49 2e 20 20 49 6e 73 74 65 61 64 2c 20 77 68  PI.  Instead, wh
1930: 61 74 20 77 65 20 68 65 72 65 20 63 61 6c 6c 20  at we here call 
1940: 22 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 28  "sqlite3_column(
1950: 29 22 0a 20 20 69 73 20 61 20 70 6c 61 63 65 2d  )".  is a place-
1960: 68 6f 6c 64 65 72 20 66 6f 72 20 61 6e 20 65 6e  holder for an en
1970: 74 69 72 65 20 66 61 6d 69 6c 79 20 6f 66 20 66  tire family of f
1980: 75 6e 63 74 69 6f 6e 73 20 74 68 61 74 20 72 65  unctions that re
1990: 74 75 72 6e 0a 20 20 61 20 76 61 6c 75 65 20 66  turn.  a value f
19a0: 72 6f 6d 20 74 68 65 20 72 65 73 75 6c 74 20 73  rom the result s
19b0: 65 74 20 69 6e 20 76 61 72 69 6f 75 73 20 64 61  et in various da
19c0: 74 61 20 74 79 70 65 73 2e 20 20 54 68 65 72 65  ta types.  There
19d0: 20 61 72 65 20 61 6c 73 6f 20 72 6f 75 74 69 6e   are also routin
19e0: 65 73 0a 20 20 69 6e 20 74 68 69 73 20 66 61 6d  es.  in this fam
19f0: 69 6c 79 20 74 68 61 74 20 72 65 74 75 72 6e 20  ily that return 
1a00: 74 68 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20  the size of the 
1a10: 72 65 73 75 6c 74 20 28 69 66 20 69 74 20 69 73  result (if it is
1a20: 20 61 20 73 74 72 69 6e 67 20 6f 72 0a 20 20 42   a string or.  B
1a30: 4c 4f 42 29 20 61 6e 64 20 74 68 65 20 6e 75 6d  LOB) and the num
1a40: 62 65 72 20 6f 66 20 63 6f 6c 75 6d 6e 73 20 69  ber of columns i
1a50: 6e 20 74 68 65 20 72 65 73 75 6c 74 20 73 65 74  n the result set
1a60: 2e 20 20 0a 0a 20 20 3c 70 3e 3c 75 6c 3e 0a 20  .  ..  <p><ul>. 
1a70: 20 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33     <li> [sqlite3
1a80: 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f 62 28 29 5d 20  _column_blob()] 
1a90: 3c 2f 6c 69 3e 0a 20 20 20 20 3c 6c 69 3e 20 5b  </li>.    <li> [
1aa0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62  sqlite3_column_b
1ab0: 79 74 65 73 28 29 5d 20 3c 2f 6c 69 3e 0a 20 20  ytes()] </li>.  
1ac0: 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f    <li> [sqlite3_
1ad0: 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 31 36 28 29  column_bytes16()
1ae0: 5d 20 3c 2f 6c 69 3e 0a 20 20 20 20 3c 6c 69 3e  ] </li>.    <li>
1af0: 20 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e   [sqlite3_column
1b00: 5f 63 6f 75 6e 74 28 29 5d 20 3c 2f 6c 69 3e 0a  _count()] </li>.
1b10: 20 20 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65      <li> [sqlite
1b20: 33 5f 63 6f 6c 75 6d 6e 5f 64 6f 75 62 6c 65 28  3_column_double(
1b30: 29 5d 20 3c 2f 6c 69 3e 0a 20 20 20 20 3c 6c 69  )] </li>.    <li
1b40: 3e 20 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  > [sqlite3_colum
1b50: 6e 5f 69 6e 74 28 29 5d 20 3c 2f 6c 69 3e 0a 20  n_int()] </li>. 
1b60: 20 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33     <li> [sqlite3
1b70: 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 29 5d  _column_int64()]
1b80: 20 3c 2f 6c 69 3e 0a 20 20 20 20 3c 6c 69 3e 20   </li>.    <li> 
1b90: 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  [sqlite3_column_
1ba0: 74 65 78 74 28 29 5d 20 3c 2f 6c 69 3e 0a 20 20  text()] </li>.  
1bb0: 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f    <li> [sqlite3_
1bc0: 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 28 29 5d  column_text16()]
1bd0: 20 3c 2f 6c 69 3e 0a 20 20 20 20 3c 6c 69 3e 20   </li>.    <li> 
1be0: 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  [sqlite3_column_
1bf0: 74 79 70 65 28 29 5d 20 3c 2f 6c 69 3e 0a 20 20  type()] </li>.  
1c00: 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f    <li> [sqlite3_
1c10: 63 6f 6c 75 6d 6e 5f 76 61 6c 75 65 28 29 5d 20  column_value()] 
1c20: 3c 2f 6c 69 3e 0a 20 20 3c 2f 75 6c 3e 3c 2f 70  </li>.  </ul></p
1c30: 3e 0a 3c 2f 74 64 3e 0a 0a 3c 6c 69 3e 3c 70 3e  >.</td>..<li><p>
1c40: 3c 62 3e 5b 73 71 6c 69 74 65 33 5f 66 69 6e 61  <b>[sqlite3_fina
1c50: 6c 69 7a 65 28 29 5d 3c 2f 62 3e 0a 3c 70 3e 0a  lize()]</b>.<p>.
1c60: 20 20 54 68 69 73 20 72 6f 75 74 69 6e 65 20 64    This routine d
1c70: 65 73 74 72 6f 79 73 20 61 20 5b 70 72 65 70 61  estroys a [prepa
1c80: 72 65 64 20 73 74 61 74 65 6d 65 6e 74 5d 20 63  red statement] c
1c90: 72 65 61 74 65 64 20 62 79 20 61 20 70 72 69 6f  reated by a prio
1ca0: 72 20 63 61 6c 6c 0a 20 20 74 6f 20 5b 73 71 6c  r call.  to [sql
1cb0: 69 74 65 33 5f 70 72 65 70 61 72 65 28 29 5d 2e  ite3_prepare()].
1cc0: 20 20 45 76 65 72 79 20 70 72 65 70 61 72 65 64    Every prepared
1cd0: 20 73 74 61 74 65 6d 65 6e 74 20 6d 75 73 74 20   statement must 
1ce0: 62 65 20 64 65 73 74 72 6f 79 65 64 20 75 73 69  be destroyed usi
1cf0: 6e 67 0a 20 20 61 20 63 61 6c 6c 20 74 6f 20 74  ng.  a call to t
1d00: 68 69 73 20 72 6f 75 74 69 6e 65 20 69 6e 20 6f  his routine in o
1d10: 72 64 65 72 20 74 6f 20 61 76 6f 69 64 20 6d 65  rder to avoid me
1d20: 6d 6f 72 79 20 6c 65 61 6b 73 2e 0a 0a 3c 6c 69  mory leaks...<li
1d30: 3e 3c 70 3e 3c 62 3e 5b 73 71 6c 69 74 65 33 5f  ><p><b>[sqlite3_
1d40: 63 6c 6f 73 65 28 29 5d 3c 2f 62 3e 0a 3c 70 3e  close()]</b>.<p>
1d50: 0a 20 20 54 68 69 73 20 72 6f 75 74 69 6e 65 20  .  This routine 
1d60: 63 6c 6f 73 65 73 20 61 20 5b 64 61 74 61 62 61  closes a [databa
1d70: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 5d 20 70  se connection] p
1d80: 72 65 76 69 6f 75 73 6c 79 20 6f 70 65 6e 65 64  reviously opened
1d90: 20 62 79 20 61 20 63 61 6c 6c 0a 20 20 74 6f 20   by a call.  to 
1da0: 5b 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28 29 5d  [sqlite3_open()]
1db0: 2e 20 20 41 6c 6c 20 5b 70 72 65 70 61 72 65 64  .  All [prepared
1dc0: 20 73 74 61 74 65 6d 65 6e 74 73 5d 20 61 73 73   statements] ass
1dd0: 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65  ociated with the
1de0: 0a 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 73 68  .  connection sh
1df0: 6f 75 6c 64 20 62 65 20 5b 73 71 6c 69 74 65 33  ould be [sqlite3
1e00: 5f 66 69 6e 61 6c 69 7a 65 20 7c 20 66 69 6e 61  _finalize | fina
1e10: 6c 69 7a 65 64 5d 20 70 72 69 6f 72 20 74 6f 20  lized] prior to 
1e20: 63 6c 6f 73 69 6e 67 20 74 68 65 0a 20 20 63 6f  closing the.  co
1e30: 6e 6e 65 63 74 69 6f 6e 2e 0a 3c 2f 75 6c 3e 0a  nnection..</ul>.
1e40: 0a 3c 68 31 3e 54 79 70 69 63 61 6c 20 55 73 61  .<h1>Typical Usa
1e50: 67 65 20 4f 66 20 43 6f 72 65 20 52 6f 75 74 69  ge Of Core Routi
1e60: 6e 65 73 20 41 6e 64 20 4f 62 6a 65 63 74 73 3c  nes And Objects<
1e70: 2f 68 31 3e 0a 0a 3c 70 3e 0a 20 20 41 6e 20 61  /h1>..<p>.  An a
1e80: 70 70 6c 69 63 61 74 69 6f 6e 20 77 69 6c 6c 20  pplication will 
1e90: 74 79 70 69 63 61 6c 6c 79 20 75 73 65 0a 20 20  typically use.  
1ea0: 5b 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28 29 5d  [sqlite3_open()]
1eb0: 20 74 6f 20 63 72 65 61 74 65 20 61 20 73 69 6e   to create a sin
1ec0: 67 6c 65 20 5b 64 61 74 61 62 61 73 65 20 63 6f  gle [database co
1ed0: 6e 6e 65 63 74 69 6f 6e 5d 0a 20 20 64 75 72 69  nnection].  duri
1ee0: 6e 67 20 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f  ng initializatio
1ef0: 6e 2e 0a 20 20 4e 6f 74 65 20 74 68 61 74 20 5b  n..  Note that [
1f00: 73 71 6c 69 74 65 33 5f 6f 70 65 6e 28 29 5d 20  sqlite3_open()] 
1f10: 63 61 6e 20 62 65 20 75 73 65 64 20 74 6f 20 65  can be used to e
1f20: 69 74 68 65 72 20 6f 70 65 6e 20 65 78 69 73 74  ither open exist
1f30: 69 6e 67 20 64 61 74 61 62 61 73 65 0a 20 20 66  ing database.  f
1f40: 69 6c 65 73 20 6f 72 20 74 6f 20 63 72 65 61 74  iles or to creat
1f50: 65 20 61 6e 64 20 6f 70 65 6e 20 6e 65 77 20 64  e and open new d
1f60: 61 74 61 62 61 73 65 20 66 69 6c 65 73 2e 0a 20  atabase files.. 
1f70: 20 57 68 69 6c 65 20 6d 61 6e 79 20 61 70 70 6c   While many appl
1f80: 69 63 61 74 69 6f 6e 73 20 75 73 65 20 6f 6e 6c  ications use onl
1f90: 79 20 61 20 73 69 6e 67 6c 65 20 5b 64 61 74 61  y a single [data
1fa0: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 5d  base connection]
1fb0: 2c 20 74 68 65 72 65 20 69 73 0a 20 20 6e 6f 20  , there is.  no 
1fc0: 72 65 61 73 6f 6e 20 77 68 79 20 61 6e 20 61 70  reason why an ap
1fd0: 70 6c 69 63 61 74 69 6f 6e 20 63 61 6e 6e 6f 74  plication cannot
1fe0: 20 63 61 6c 6c 20 5b 73 71 6c 69 74 65 33 5f 6f   call [sqlite3_o
1ff0: 70 65 6e 28 29 5d 20 6d 75 6c 74 69 70 6c 65 20  pen()] multiple 
2000: 74 69 6d 65 73 0a 20 20 69 6e 20 6f 72 64 65 72  times.  in order
2010: 20 74 6f 20 6f 70 65 6e 20 6d 75 6c 74 69 70 6c   to open multipl
2020: 65 20 5b 64 61 74 61 62 61 73 65 20 63 6f 6e 6e  e [database conn
2030: 65 63 74 69 6f 6e 73 5d 20 2d 20 65 69 74 68 65  ections] - eithe
2040: 72 20 74 6f 20 74 68 65 20 73 61 6d 65 0a 20 20  r to the same.  
2050: 64 61 74 61 62 61 73 65 20 6f 72 20 74 6f 20 64  database or to d
2060: 69 66 66 65 72 65 6e 74 20 64 61 74 61 62 61 73  ifferent databas
2070: 65 73 2e 20 20 53 6f 6d 65 74 69 6d 65 73 20 61  es.  Sometimes a
2080: 20 6d 75 6c 74 69 2d 74 68 72 65 61 64 65 64 20   multi-threaded 
2090: 61 70 70 6c 69 63 61 74 69 6f 6e 0a 20 20 77 69  application.  wi
20a0: 6c 6c 20 63 72 65 61 74 65 20 73 65 70 61 72 61  ll create separa
20b0: 74 65 20 5b 64 61 74 61 62 61 73 65 20 63 6f 6e  te [database con
20c0: 6e 65 63 74 69 6f 6e 73 5d 20 66 6f 72 20 65 61  nections] for ea
20d0: 63 68 20 74 68 72 65 61 64 2e 0a 20 20 4e 6f 74  ch thread..  Not
20e0: 65 20 74 68 61 74 20 61 20 73 69 6e 67 6c 65 20  e that a single 
20f0: 5b 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63  [database connec
2100: 74 69 6f 6e 5d 20 63 61 6e 20 61 63 63 65 73 73  tion] can access
2110: 20 74 77 6f 20 6f 72 20 6d 6f 72 65 0a 20 20 64   two or more.  d
2120: 61 74 61 62 61 73 65 73 20 75 73 69 6e 67 20 74  atabases using t
2130: 68 65 20 5b 41 54 54 41 43 48 5d 20 53 51 4c 20  he [ATTACH] SQL 
2140: 63 6f 6d 6d 61 6e 64 2c 20 73 6f 20 69 74 20 69  command, so it i
2150: 73 20 6e 6f 74 20 6e 65 63 65 73 73 61 72 79 20  s not necessary 
2160: 74 6f 0a 20 20 68 61 76 65 20 61 20 73 65 70 61  to.  have a sepa
2170: 72 61 74 65 20 64 61 74 61 62 61 73 65 20 63 6f  rate database co
2180: 6e 6e 65 63 74 69 6f 6e 20 66 6f 72 20 65 61 63  nnection for eac
2190: 68 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  h database file.
21a0: 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a 20 20 4d 61 6e  .</p>..<p>.  Man
21b0: 79 20 61 70 70 6c 69 63 61 74 69 6f 6e 73 20 64  y applications d
21c0: 65 73 74 72 6f 79 20 74 68 65 69 72 20 5b 64 61  estroy their [da
21d0: 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f  tabase connectio
21e0: 6e 73 5d 20 75 73 69 6e 67 20 63 61 6c 6c 73 20  ns] using calls 
21f0: 74 6f 0a 20 20 5b 73 71 6c 69 74 65 33 5f 63 6c  to.  [sqlite3_cl
2200: 6f 73 65 28 29 5d 20 61 74 20 73 68 75 74 64 6f  ose()] at shutdo
2210: 77 6e 2e 20 20 4f 72 2c 20 66 6f 72 20 65 78 61  wn.  Or, for exa
2220: 6d 70 6c 65 2c 20 61 6e 20 61 70 70 6c 69 63 61  mple, an applica
2230: 74 69 6f 6e 20 74 68 61 74 0a 20 20 75 73 65 73  tion that.  uses
2240: 20 53 51 4c 69 74 65 20 61 73 20 69 74 73 20 5b   SQLite as its [
2250: 61 70 70 6c 69 63 61 74 69 6f 6e 20 66 69 6c 65  application file
2260: 20 66 6f 72 6d 61 74 5d 20 6d 69 67 68 74 0a 20   format] might. 
2270: 20 6f 70 65 6e 20 5b 64 61 74 61 62 61 73 65 20   open [database 
2280: 63 6f 6e 6e 65 63 74 69 6f 6e 73 5d 20 69 6e 20  connections] in 
2290: 72 65 73 70 6f 6e 73 65 20 74 6f 20 61 20 46 69  response to a Fi
22a0: 6c 65 2f 4f 70 65 6e 20 6d 65 6e 75 20 61 63 74  le/Open menu act
22b0: 69 6f 6e 0a 20 20 61 6e 64 20 74 68 65 6e 20 64  ion.  and then d
22c0: 65 73 74 72 6f 79 20 74 68 65 20 63 6f 72 72 65  estroy the corre
22d0: 73 70 6f 6e 64 69 6e 67 20 5b 64 61 74 61 62 61  sponding [databa
22e0: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 5d 20 69  se connection] i
22f0: 6e 20 72 65 73 70 6f 6e 73 65 0a 20 20 74 6f 20  n response.  to 
2300: 74 68 65 20 46 69 6c 65 2f 43 6c 6f 73 65 20 6d  the File/Close m
2310: 65 6e 75 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a 20  enu..</p>..<p>. 
2320: 20 54 6f 20 72 75 6e 20 61 6e 20 53 51 4c 20 73   To run an SQL s
2330: 74 61 74 65 6d 65 6e 74 2c 20 74 68 65 20 61 70  tatement, the ap
2340: 70 6c 69 63 61 74 69 6f 6e 20 66 6f 6c 6c 6f 77  plication follow
2350: 73 20 74 68 65 73 65 20 73 74 65 70 73 3a 0a 3c  s these steps:.<
2360: 2f 70 3e 0a 0a 3c 70 3e 3c 6f 6c 3e 0a 20 20 3c  /p>..<p><ol>.  <
2370: 6c 69 3e 20 43 72 65 61 74 65 20 61 20 5b 70 72  li> Create a [pr
2380: 65 70 61 72 65 64 20 73 74 61 74 65 6d 65 6e 74  epared statement
2390: 5d 20 75 73 69 6e 67 20 5b 73 71 6c 69 74 65 33  ] using [sqlite3
23a0: 5f 70 72 65 70 61 72 65 28 29 5d 2e 20 3c 2f 6c  _prepare()]. </l
23b0: 69 3e 0a 20 20 3c 6c 69 3e 20 45 76 61 6c 75 61  i>.  <li> Evalua
23c0: 74 65 20 74 68 65 20 5b 70 72 65 70 61 72 65 64  te the [prepared
23d0: 20 73 74 61 74 65 6d 65 6e 74 5d 20 62 79 20 63   statement] by c
23e0: 61 6c 6c 69 6e 67 20 5b 73 71 6c 69 74 65 33 5f  alling [sqlite3_
23f0: 73 74 65 70 28 29 5d 20 6f 6e 65 0a 20 20 20 20  step()] one.    
2400: 20 20 20 6f 72 20 6d 6f 72 65 20 74 69 6d 65 73     or more times
2410: 2e 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 46  . </li>.  <li> F
2420: 6f 72 20 71 75 65 72 69 65 73 2c 20 65 78 74 72  or queries, extr
2430: 61 63 74 20 72 65 73 75 6c 74 73 20 62 79 20 63  act results by c
2440: 61 6c 6c 69 6e 67 20 0a 20 20 20 20 20 20 20 5b  alling .       [
2450: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69  sqlite3_column_i
2460: 6e 74 20 7c 20 73 71 6c 69 74 65 33 5f 63 6f 6c  nt | sqlite3_col
2470: 75 6d 6e 28 29 5d 20 69 6e 20 62 65 74 77 65 65  umn()] in betwee
2480: 6e 0a 20 20 20 20 20 20 20 74 77 6f 20 63 61 6c  n.       two cal
2490: 6c 73 20 74 6f 20 5b 73 71 6c 69 74 65 33 5f 73  ls to [sqlite3_s
24a0: 74 65 70 28 29 5d 2e 20 3c 2f 6c 69 3e 0a 20 20  tep()]. </li>.  
24b0: 3c 6c 69 3e 20 44 65 73 74 72 6f 79 20 74 68 65  <li> Destroy the
24c0: 20 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65   [prepared state
24d0: 6d 65 6e 74 5d 20 75 73 69 6e 67 20 5b 73 71 6c  ment] using [sql
24e0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 29 5d  ite3_finalize()]
24f0: 2e 20 3c 2f 6c 69 3e 0a 3c 2f 6f 6c 3e 3c 2f 70  . </li>.</ol></p
2500: 3e 0a 0a 3c 70 3e 0a 20 20 54 68 65 20 66 6f 72  >..<p>.  The for
2510: 65 67 6f 69 6e 67 20 69 73 20 61 6c 6c 20 6f 6e  egoing is all on
2520: 65 20 72 65 61 6c 6c 79 20 6e 65 65 64 73 20 74  e really needs t
2530: 6f 20 6b 6e 6f 77 20 69 6e 20 6f 72 64 65 72 20  o know in order 
2540: 74 6f 20 75 73 65 20 53 51 4c 69 74 65 0a 20 20  to use SQLite.  
2550: 65 66 66 65 63 74 69 76 65 6c 79 2e 20 20 41 6c  effectively.  Al
2560: 6c 20 74 68 65 20 72 65 73 74 20 69 73 20 6f 70  l the rest is op
2570: 74 69 6d 69 7a 61 74 69 6f 6e 20 61 6e 64 20 64  timization and d
2580: 65 74 61 69 6c 2e 0a 3c 2f 70 3e 0a 0a 3c 68 31  etail..</p>..<h1
2590: 3e 43 6f 6e 76 65 6e 69 65 6e 63 65 20 57 72 61  >Convenience Wra
25a0: 70 70 65 72 73 20 41 72 6f 75 6e 64 20 43 6f 72  ppers Around Cor
25b0: 65 20 52 6f 75 74 69 6e 65 73 3c 2f 68 31 3e 0a  e Routines</h1>.
25c0: 0a 3c 70 3e 0a 20 20 54 68 65 20 5b 73 71 6c 69  .<p>.  The [sqli
25d0: 74 65 33 5f 65 78 65 63 28 29 5d 20 69 6e 74 65  te3_exec()] inte
25e0: 72 66 61 63 65 20 69 73 20 61 20 63 6f 6e 76 65  rface is a conve
25f0: 6e 69 65 6e 63 65 20 77 72 61 70 70 65 72 20 74  nience wrapper t
2600: 68 61 74 20 63 61 72 72 69 65 73 20 6f 75 74 0a  hat carries out.
2610: 20 20 61 6c 6c 20 66 6f 75 72 20 6f 66 20 74 68    all four of th
2620: 65 20 61 62 6f 76 65 20 73 74 65 70 73 20 77 69  e above steps wi
2630: 74 68 20 61 20 73 69 6e 67 6c 65 20 66 75 6e 63  th a single func
2640: 74 69 6f 6e 20 63 61 6c 6c 2e 20 20 41 20 63 61  tion call.  A ca
2650: 6c 6c 62 61 63 6b 0a 20 20 66 75 6e 63 74 69 6f  llback.  functio
2660: 6e 20 70 61 73 73 65 64 20 69 6e 74 6f 20 5b 73  n passed into [s
2670: 71 6c 69 74 65 33 5f 65 78 65 63 28 29 5d 20 69  qlite3_exec()] i
2680: 73 20 75 73 65 64 20 74 6f 20 70 72 6f 63 65 73  s used to proces
2690: 73 20 65 61 63 68 20 72 6f 77 20 6f 66 0a 20 20  s each row of.  
26a0: 74 68 65 20 72 65 73 75 6c 74 20 73 65 74 2e 20  the result set. 
26b0: 20 54 68 65 20 5b 73 71 6c 69 74 65 33 5f 67 65   The [sqlite3_ge
26c0: 74 5f 74 61 62 6c 65 28 29 5d 20 69 73 20 61 6e  t_table()] is an
26d0: 6f 74 68 65 72 20 63 6f 6e 76 65 6e 69 65 6e 63  other convenienc
26e0: 65 20 77 72 61 70 70 65 72 0a 20 20 74 68 61 74  e wrapper.  that
26f0: 20 64 6f 65 73 20 61 6c 6c 20 66 6f 75 72 20 6f   does all four o
2700: 66 20 74 68 65 20 61 62 6f 76 65 20 73 74 65 70  f the above step
2710: 73 2e 20 20 54 68 65 20 5b 73 71 6c 69 74 65 33  s.  The [sqlite3
2720: 5f 67 65 74 5f 74 61 62 6c 65 28 29 5d 20 69 6e  _get_table()] in
2730: 74 65 72 66 61 63 65 0a 20 20 64 69 66 66 65 72  terface.  differ
2740: 73 20 66 72 6f 6d 20 5b 73 71 6c 69 74 65 33 5f  s from [sqlite3_
2750: 65 78 65 63 28 29 5d 20 69 6e 20 74 68 61 74 20  exec()] in that 
2760: 69 74 20 73 74 6f 72 65 73 20 74 68 65 20 72 65  it stores the re
2770: 73 75 6c 74 73 20 6f 66 20 71 75 65 72 69 65 73  sults of queries
2780: 0a 20 20 69 6e 20 68 65 61 70 20 6d 65 6d 6f 72  .  in heap memor
2790: 79 20 72 61 74 68 65 72 20 74 68 61 6e 20 69 6e  y rather than in
27a0: 76 6f 6b 69 6e 67 20 61 20 63 61 6c 6c 62 61 63  voking a callbac
27b0: 6b 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a 20 20 49  k..</p>..<p>.  I
27c0: 74 20 69 73 20 69 6d 70 6f 72 74 61 6e 74 20 74  t is important t
27d0: 6f 20 72 65 61 6c 69 7a 65 20 74 68 61 74 20 6e  o realize that n
27e0: 65 69 74 68 65 72 20 5b 73 71 6c 69 74 65 33 5f  either [sqlite3_
27f0: 65 78 65 63 28 29 5d 20 6e 6f 72 0a 20 20 5b 73  exec()] nor.  [s
2800: 71 6c 69 74 65 33 5f 67 65 74 5f 74 61 62 6c 65  qlite3_get_table
2810: 28 29 5d 20 64 6f 20 61 6e 79 74 68 69 6e 67 20  ()] do anything 
2820: 74 68 61 74 20 63 61 6e 6e 6f 74 20 62 65 20 61  that cannot be a
2830: 63 63 6f 6d 70 6c 69 73 68 65 64 20 75 73 69 6e  ccomplished usin
2840: 67 0a 20 20 74 68 65 20 63 6f 72 65 20 72 6f 75  g.  the core rou
2850: 74 69 6e 65 73 2e 20 20 49 6e 20 66 61 63 74 2c  tines.  In fact,
2860: 20 74 68 65 73 65 20 77 72 61 70 70 65 72 73 20   these wrappers 
2870: 61 72 65 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20  are implemented 
2880: 70 75 72 65 6c 79 20 69 6e 0a 20 20 74 65 72 6d  purely in.  term
2890: 73 20 6f 66 20 74 68 65 20 63 6f 72 65 20 72 6f  s of the core ro
28a0: 75 74 69 6e 65 73 2e 0a 3c 2f 70 3e 0a 0a 0a 3c  utines..</p>...<
28b0: 68 31 3e 42 69 6e 64 69 6e 67 20 50 61 72 61 6d  h1>Binding Param
28c0: 65 74 65 72 73 20 61 6e 64 20 52 65 75 73 69 6e  eters and Reusin
28d0: 67 20 50 72 65 70 61 72 65 64 20 53 74 61 74 65  g Prepared State
28e0: 6d 65 6e 74 73 3c 2f 68 31 3e 0a 0a 3c 70 3e 0a  ments</h1>..<p>.
28f0: 20 20 49 6e 20 70 72 69 6f 72 20 64 69 73 63 75    In prior discu
2900: 73 73 69 6f 6e 2c 20 69 74 20 77 61 73 20 61 73  ssion, it was as
2910: 73 75 6d 65 64 20 74 68 61 74 20 65 61 63 68 20  sumed that each 
2920: 53 51 4c 20 73 74 61 74 65 6d 65 6e 74 20 69 73  SQL statement is
2930: 20 70 72 65 70 61 72 65 64 0a 20 20 6f 6e 63 65   prepared.  once
2940: 2c 20 65 76 61 6c 75 61 74 65 64 2c 20 74 68 65  , evaluated, the
2950: 6e 20 64 65 73 74 72 6f 79 65 64 2e 20 20 48 6f  n destroyed.  Ho
2960: 77 65 76 65 72 2c 20 53 51 4c 69 74 65 20 61 6c  wever, SQLite al
2970: 6c 6f 77 73 20 74 68 65 20 73 61 6d 65 0a 20 20  lows the same.  
2980: 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d  [prepared statem
2990: 65 6e 74 5d 20 74 6f 20 62 65 20 65 76 61 6c 75  ent] to be evalu
29a0: 61 74 65 64 20 6d 75 6c 74 69 70 6c 65 20 74 69  ated multiple ti
29b0: 6d 65 73 2e 20 20 54 68 69 73 20 69 73 20 61 63  mes.  This is ac
29c0: 63 6f 6d 70 6c 69 73 68 65 64 0a 20 20 75 73 69  complished.  usi
29d0: 6e 67 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  ng the following
29e0: 20 72 6f 75 74 69 6e 65 73 3a 0a 3c 2f 70 3e 0a   routines:.</p>.
29f0: 0a 3c 70 3e 3c 75 6c 3e 0a 20 20 3c 6c 69 3e 20  .<p><ul>.  <li> 
2a00: 5b 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 29  [sqlite3_reset()
2a10: 5d 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 5b  ] </li>.  <li> [
2a20: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74  sqlite3_bind_int
2a30: 20 7c 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 28   | sqlite3_bind(
2a40: 29 5d 20 3c 2f 6c 69 3e 0a 3c 2f 75 6c 3e 3c 2f  )] </li>.</ul></
2a50: 70 3e 0a 0a 3c 70 3e 0a 20 20 41 66 74 65 72 20  p>..<p>.  After 
2a60: 61 20 5b 70 72 65 70 61 72 65 64 20 73 74 61 74  a [prepared stat
2a70: 65 6d 65 6e 74 5d 20 68 61 73 20 62 65 65 6e 20  ement] has been 
2a80: 65 76 61 6c 75 61 74 65 64 20 62 79 20 6f 6e 65  evaluated by one
2a90: 20 6f 72 20 6d 6f 72 65 20 63 61 6c 6c 73 20 74   or more calls t
2aa0: 6f 0a 20 20 5b 73 71 6c 69 74 65 33 5f 73 74 65  o.  [sqlite3_ste
2ab0: 70 28 29 5d 2c 20 69 74 20 63 61 6e 20 62 65 20  p()], it can be 
2ac0: 72 65 73 65 74 20 69 6e 20 6f 72 64 65 72 20 74  reset in order t
2ad0: 6f 20 62 65 20 65 76 61 6c 75 61 74 65 64 20 61  o be evaluated a
2ae0: 67 61 69 6e 20 62 79 20 61 0a 20 20 63 61 6c 6c  gain by a.  call
2af0: 20 74 6f 20 5b 73 71 6c 69 74 65 33 5f 72 65 73   to [sqlite3_res
2b00: 65 74 28 29 5d 2e 0a 20 20 54 68 69 6e 6b 20 6f  et()]..  Think o
2b10: 66 20 5b 73 71 6c 69 74 65 33 5f 72 65 73 65 74  f [sqlite3_reset
2b20: 28 29 5d 20 61 73 20 72 65 77 69 6e 64 69 6e 67  ()] as rewinding
2b30: 20 74 68 65 20 5b 70 72 65 70 61 72 65 64 20 73   the [prepared s
2b40: 74 61 74 65 6d 65 6e 74 5d 20 70 72 6f 67 72 61  tatement] progra
2b50: 6d 0a 20 20 62 61 63 6b 20 74 6f 20 74 68 65 20  m.  back to the 
2b60: 62 65 67 69 6e 6e 69 6e 67 2e 0a 20 20 55 73 69  beginning..  Usi
2b70: 6e 67 20 5b 73 71 6c 69 74 65 33 5f 72 65 73 65  ng [sqlite3_rese
2b80: 74 28 29 5d 20 6f 6e 20 61 6e 20 65 78 69 73 74  t()] on an exist
2b90: 69 6e 67 20 5b 70 72 65 70 61 72 65 64 20 73 74  ing [prepared st
2ba0: 61 74 65 6d 65 6e 74 5d 20 72 61 74 68 65 72 20  atement] rather 
2bb0: 74 68 61 6e 0a 20 20 63 72 65 61 74 69 6e 67 20  than.  creating 
2bc0: 61 20 6e 65 77 20 5b 70 72 65 70 61 72 65 64 20  a new [prepared 
2bd0: 73 74 61 74 65 6d 65 6e 74 5d 20 61 76 6f 69 64  statement] avoid
2be0: 73 20 75 6e 6e 65 63 65 73 73 61 72 79 20 63 61  s unnecessary ca
2bf0: 6c 6c 73 20 74 6f 0a 20 20 5b 73 71 6c 69 74 65  lls to.  [sqlite
2c00: 33 5f 70 72 65 70 61 72 65 28 29 5d 2e 0a 20 20  3_prepare()]..  
2c10: 46 6f 72 20 6d 61 6e 79 20 53 51 4c 20 73 74 61  For many SQL sta
2c20: 74 65 6d 65 6e 74 73 2c 20 74 68 65 20 74 69 6d  tements, the tim
2c30: 65 20 6e 65 65 64 65 64 0a 20 20 74 6f 20 72 75  e needed.  to ru
2c40: 6e 20 5b 73 71 6c 69 74 65 33 5f 70 72 65 70 61  n [sqlite3_prepa
2c50: 72 65 28 29 5d 20 65 71 75 61 6c 73 20 6f 72 20  re()] equals or 
2c60: 65 78 63 65 65 64 73 20 74 68 65 20 74 69 6d 65  exceeds the time
2c70: 20 6e 65 65 64 65 64 20 62 79 0a 20 20 5b 73 71   needed by.  [sq
2c80: 6c 69 74 65 33 5f 73 74 65 70 28 29 5d 2e 20 20  lite3_step()].  
2c90: 53 6f 20 61 76 6f 69 64 69 6e 67 20 63 61 6c 6c  So avoiding call
2ca0: 73 20 74 6f 20 5b 73 71 6c 69 74 65 33 5f 70 72  s to [sqlite3_pr
2cb0: 65 70 61 72 65 28 29 5d 20 63 61 6e 20 67 69 76  epare()] can giv
2cc0: 65 0a 20 20 61 20 73 69 67 6e 69 66 69 63 61 6e  e.  a significan
2cd0: 74 20 70 65 72 66 6f 72 6d 61 6e 63 65 20 69 6d  t performance im
2ce0: 70 72 6f 76 65 6d 65 6e 74 2e 0a 3c 2f 70 3e 0a  provement..</p>.
2cf0: 0a 3c 70 3e 0a 20 20 49 74 20 69 73 20 6e 6f 74  .<p>.  It is not
2d00: 20 63 6f 6d 6d 6f 6e 6c 79 20 75 73 65 66 75 6c   commonly useful
2d10: 20 74 6f 20 65 76 61 6c 75 61 74 65 20 74 68 65   to evaluate the
2d20: 20 3c 65 6d 3e 65 78 61 63 74 3c 2f 65 6d 3e 20   <em>exact</em> 
2d30: 73 61 6d 65 20 53 51 4c 0a 20 20 73 74 61 74 65  same SQL.  state
2d40: 6d 65 6e 74 20 6d 6f 72 65 20 74 68 61 6e 20 6f  ment more than o
2d50: 6e 63 65 2e 20 20 4d 6f 72 65 20 6f 66 74 65 6e  nce.  More often
2d60: 2c 20 6f 6e 65 20 77 61 6e 74 73 20 74 6f 20 65  , one wants to e
2d70: 76 61 6c 75 61 74 65 20 73 69 6d 69 6c 61 72 0a  valuate similar.
2d80: 20 20 73 74 61 74 65 6d 65 6e 74 73 2e 20 20 46    statements.  F
2d90: 6f 72 20 65 78 61 6d 70 6c 65 2c 20 79 6f 75 20  or example, you 
2da0: 6d 69 67 68 74 20 77 61 6e 74 20 74 6f 20 65 76  might want to ev
2db0: 61 6c 75 61 74 65 20 61 6e 20 49 4e 53 45 52 54  aluate an INSERT
2dc0: 20 73 74 61 74 65 6d 65 6e 74 0a 20 20 6d 75 6c   statement.  mul
2dd0: 74 69 70 6c 65 20 74 69 6d 65 73 20 77 69 74 68  tiple times with
2de0: 20 64 69 66 66 65 72 65 6e 74 20 76 61 6c 75 65   different value
2df0: 73 2e 20 20 4f 72 20 79 6f 75 20 6d 69 67 68 74  s.  Or you might
2e00: 20 77 61 6e 74 20 74 6f 20 65 76 61 6c 75 61 74   want to evaluat
2e10: 65 0a 20 20 74 68 65 20 73 61 6d 65 20 71 75 65  e.  the same que
2e20: 72 79 20 6d 75 6c 74 69 70 6c 65 20 74 69 6d 65  ry multiple time
2e30: 73 20 75 73 69 6e 67 20 61 20 64 69 66 66 65 72  s using a differ
2e40: 65 6e 74 20 6b 65 79 20 69 6e 20 74 68 65 20 57  ent key in the W
2e50: 48 45 52 45 20 63 6c 61 75 73 65 2e 0a 20 20 54  HERE clause..  T
2e60: 6f 20 61 63 63 6f 6d 6d 6f 64 61 74 65 0a 20 20  o accommodate.  
2e70: 74 68 69 73 2c 20 53 51 4c 69 74 65 20 61 6c 6c  this, SQLite all
2e80: 6f 77 73 20 53 51 4c 20 73 74 61 74 65 6d 65 6e  ows SQL statemen
2e90: 74 73 20 74 6f 20 63 6f 6e 74 61 69 6e 20 5b 70  ts to contain [p
2ea0: 61 72 61 6d 65 74 65 72 20 7c 20 70 61 72 61 6d  arameter | param
2eb0: 65 74 65 72 73 5d 0a 20 20 77 68 69 63 68 20 61  eters].  which a
2ec0: 72 65 20 22 62 6f 75 6e 64 22 20 74 6f 20 76 61  re "bound" to va
2ed0: 6c 75 65 73 20 70 72 69 6f 72 20 74 6f 20 62 65  lues prior to be
2ee0: 69 6e 67 20 65 76 61 6c 75 61 74 65 64 2e 20 20  ing evaluated.  
2ef0: 54 68 65 73 65 20 76 61 6c 75 65 73 20 63 61 6e  These values can
2f00: 0a 20 20 6c 61 74 65 72 20 62 65 20 63 68 61 6e  .  later be chan
2f10: 67 65 64 20 61 6e 64 20 74 68 65 20 73 61 6d 65  ged and the same
2f20: 20 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65   [prepared state
2f30: 6d 65 6e 74 5d 20 63 61 6e 20 62 65 20 65 76 61  ment] can be eva
2f40: 6c 75 61 74 65 64 0a 20 20 61 20 73 65 63 6f 6e  luated.  a secon
2f50: 64 20 74 69 6d 65 20 75 73 69 6e 67 20 74 68 65  d time using the
2f60: 20 6e 65 77 20 76 61 6c 75 65 73 2e 0a 3c 2f 70   new values..</p
2f70: 3e 0a 0a 3c 70 3e 0a 20 20 53 51 4c 69 74 65 20  >..<p>.  SQLite 
2f80: 61 6c 6c 6f 77 73 20 61 20 5b 70 61 72 61 6d 65  allows a [parame
2f90: 74 65 72 5d 20 77 68 65 72 65 76 65 72 0a 20 20  ter] wherever.  
2fa0: 61 20 73 74 72 69 6e 67 20 6c 69 74 65 72 61 6c  a string literal
2fb0: 2c 20 6e 75 6d 65 72 69 63 20 63 6f 6e 73 74 61  , numeric consta
2fc0: 6e 74 2c 20 6f 72 20 4e 55 4c 4c 20 69 73 20 61  nt, or NULL is a
2fd0: 6c 6c 6f 77 65 64 2e 0a 20 20 28 50 61 72 61 6d  llowed..  (Param
2fe0: 65 74 65 72 73 20 6d 61 79 20 6e 6f 74 20 62 65  eters may not be
2ff0: 20 75 73 65 64 20 66 6f 72 20 63 6f 6c 75 6d 6e   used for column
3000: 20 6f 72 20 74 61 62 6c 65 20 6e 61 6d 65 73 2e   or table names.
3010: 29 0a 20 20 41 20 5b 70 61 72 61 6d 65 74 65 72  ).  A [parameter
3020: 5d 20 74 61 6b 65 73 20 6f 6e 65 20 6f 66 20 74  ] takes one of t
3030: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 66 6f 72  he following for
3040: 6d 73 3a 0a 3c 2f 70 3e 0a 0a 3c 70 3e 3c 75 6c  ms:.</p>..<p><ul
3050: 3e 0a 20 20 3c 6c 69 3e 20 3c 62 3e 3f 3c 2f 62  >.  <li> <b>?</b
3060: 3e 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 3c  > </li>.  <li> <
3070: 62 3e 3f 3c 2f 62 3e 3c 69 3e 4e 4e 4e 3c 2f 69  b>?</b><i>NNN</i
3080: 3e 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 3c  > </li>.  <li> <
3090: 62 3e 3a 3c 2f 62 3e 3c 69 3e 41 41 41 3c 2f 69  b>:</b><i>AAA</i
30a0: 3e 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 3c  > </li>.  <li> <
30b0: 62 3e 24 3c 2f 62 3e 3c 69 3e 41 41 41 3c 2f 69  b>$</b><i>AAA</i
30c0: 3e 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 3c  > </li>.  <li> <
30d0: 62 3e 40 3c 2f 62 3e 3c 69 3e 41 41 41 3c 2f 69  b>@</b><i>AAA</i
30e0: 3e 20 3c 2f 6c 69 3e 0a 3c 2f 75 6c 3e 3c 2f 70  > </li>.</ul></p
30f0: 3e 0a 0a 3c 70 3e 0a 20 20 49 6e 20 74 68 65 20  >..<p>.  In the 
3100: 65 78 61 6d 70 6c 65 73 20 61 62 6f 76 65 2c 20  examples above, 
3110: 3c 69 3e 4e 4e 4e 3c 2f 69 3e 20 69 73 20 61 6e  <i>NNN</i> is an
3120: 20 69 6e 74 65 67 65 72 20 76 61 6c 75 65 20 61   integer value a
3130: 6e 64 0a 20 20 3c 69 3e 41 41 41 3c 2f 69 3e 20  nd.  <i>AAA</i> 
3140: 69 73 20 61 6e 20 69 64 65 6e 74 69 66 69 65 72  is an identifier
3150: 2e 0a 20 20 41 20 70 61 72 61 6d 65 74 65 72 20  ..  A parameter 
3160: 69 6e 69 74 69 61 6c 6c 79 20 68 61 73 20 61 20  initially has a 
3170: 76 61 6c 75 65 20 6f 66 20 4e 55 4c 4c 2e 0a 20  value of NULL.. 
3180: 20 50 72 69 6f 72 20 74 6f 20 63 61 6c 6c 69 6e   Prior to callin
3190: 67 20 5b 73 71 6c 69 74 65 33 5f 73 74 65 70 28  g [sqlite3_step(
31a0: 29 5d 20 66 6f 72 20 74 68 65 20 66 69 72 73 74  )] for the first
31b0: 20 74 69 6d 65 20 6f 72 20 69 6d 6d 65 64 69 61   time or immedia
31c0: 74 65 6c 79 0a 20 20 61 66 74 65 72 20 5b 73 71  tely.  after [sq
31d0: 6c 69 74 65 33 5f 72 65 73 65 74 28 29 5d 2c 20  lite3_reset()], 
31e0: 74 68 65 20 61 70 70 6c 69 63 61 74 69 6f 6e 20  the application 
31f0: 63 61 6e 20 69 6e 76 6f 6b 65 20 74 68 65 0a 20  can invoke the. 
3200: 20 5b 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69   [sqlite3_bind_i
3210: 6e 74 20 7c 20 73 71 6c 69 74 65 33 5f 62 69 6e  nt | sqlite3_bin
3220: 64 28 29 5d 20 69 6e 74 65 72 66 61 63 65 73 20  d()] interfaces 
3230: 74 6f 20 61 74 74 61 63 68 20 76 61 6c 75 65 73  to attach values
3240: 0a 20 20 74 6f 20 74 68 65 20 70 61 72 61 6d 65  .  to the parame
3250: 74 65 72 73 2e 20 20 45 61 63 68 20 63 61 6c 6c  ters.  Each call
3260: 20 74 6f 20 5b 73 71 6c 69 74 65 33 5f 62 69 6e   to [sqlite3_bin
3270: 64 5f 69 6e 74 20 7c 20 73 71 6c 69 74 65 33 5f  d_int | sqlite3_
3280: 62 69 6e 64 28 29 5d 0a 20 20 6f 76 65 72 72 69  bind()].  overri
3290: 64 65 73 20 70 72 69 6f 72 20 62 69 6e 64 69 6e  des prior bindin
32a0: 67 73 20 6f 6e 20 74 68 65 20 73 61 6d 65 20 70  gs on the same p
32b0: 61 72 61 6d 65 74 65 72 2e 0a 3c 2f 70 3e 0a 0a  arameter..</p>..
32c0: 3c 70 3e 0a 20 20 41 6e 20 61 70 70 6c 69 63 61  <p>.  An applica
32d0: 74 69 6f 6e 20 69 73 20 61 6c 6c 6f 77 65 64 20  tion is allowed 
32e0: 74 6f 20 70 72 65 70 61 72 65 20 6d 75 6c 74 69  to prepare multi
32f0: 70 6c 65 20 53 51 4c 20 73 74 61 74 65 6d 65 6e  ple SQL statemen
3300: 74 73 20 69 6e 20 61 64 76 61 6e 63 65 0a 20 20  ts in advance.  
3310: 61 6e 64 20 65 76 61 6c 75 61 74 65 20 74 68 65  and evaluate the
3320: 6d 20 61 73 20 6e 65 65 64 65 64 2e 0a 20 20 54  m as needed..  T
3330: 68 65 72 65 20 69 73 20 6e 6f 20 61 72 62 69 74  here is no arbit
3340: 72 61 72 79 20 6c 69 6d 69 74 20 74 6f 20 74 68  rary limit to th
3350: 65 20 6e 75 6d 62 65 72 20 6f 66 20 6f 75 74 73  e number of outs
3360: 74 61 6e 64 69 6e 67 0a 20 20 5b 70 72 65 70 61  tanding.  [prepa
3370: 72 65 64 20 73 74 61 74 65 6d 65 6e 74 73 5d 2e  red statements].
3380: 0a 20 20 53 6f 6d 65 20 61 70 70 6c 69 63 61 74  .  Some applicat
3390: 69 6f 6e 73 20 63 61 6c 6c 20 5b 73 71 6c 69 74  ions call [sqlit
33a0: 65 33 5f 70 72 65 70 61 72 65 28 29 5d 20 6d 75  e3_prepare()] mu
33b0: 6c 74 69 70 6c 65 20 74 69 6d 65 73 20 61 74 20  ltiple times at 
33c0: 73 74 61 72 74 2d 75 70 20 74 6f 0a 20 20 63 72  start-up to.  cr
33d0: 65 61 74 65 20 61 6c 6c 20 6f 66 20 74 68 65 20  eate all of the 
33e0: 5b 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d  [prepared statem
33f0: 65 6e 74 73 5d 20 74 68 65 79 20 77 69 6c 6c 20  ents] they will 
3400: 65 76 65 72 20 6e 65 65 64 2e 20 20 4f 74 68 65  ever need.  Othe
3410: 72 0a 20 20 61 70 70 6c 69 63 61 74 69 6f 6e 73  r.  applications
3420: 20 6b 65 65 70 20 61 20 63 61 63 68 65 20 6f 66   keep a cache of
3430: 20 74 68 65 20 6d 6f 73 74 20 72 65 63 65 6e 74   the most recent
3440: 6c 79 20 75 73 65 64 20 5b 70 72 65 70 61 72 65  ly used [prepare
3450: 64 20 73 74 61 74 65 6d 65 6e 74 73 5d 0a 20 20  d statements].  
3460: 61 6e 64 20 74 68 65 6e 20 72 65 75 73 65 20 5b  and then reuse [
3470: 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d 65  prepared stateme
3480: 6e 74 73 5d 20 6f 75 74 20 6f 66 20 74 68 65 20  nts] out of the 
3490: 63 61 63 68 65 20 77 68 65 6e 20 61 76 61 69 6c  cache when avail
34a0: 61 62 6c 65 2e 0a 20 20 41 6e 6f 74 68 65 72 20  able..  Another 
34b0: 61 70 70 72 6f 61 63 68 20 69 73 20 74 6f 20 6f  approach is to o
34c0: 6e 6c 79 20 72 65 75 73 65 20 5b 70 72 65 70 61  nly reuse [prepa
34d0: 72 65 64 20 73 74 61 74 65 6d 65 6e 74 73 5d 20  red statements] 
34e0: 77 68 65 6e 20 74 68 65 79 20 61 72 65 0a 20 20  when they are.  
34f0: 69 6e 73 69 64 65 20 6f 66 20 61 20 6c 6f 6f 70  inside of a loop
3500: 2e 0a 3c 2f 70 3e 0a 0a 3c 68 31 3e 43 6f 6e 66  ..</p>..<h1>Conf
3510: 69 67 75 72 69 6e 67 20 53 51 4c 69 74 65 3c 2f  iguring SQLite</
3520: 68 31 3e 0a 0a 3c 70 3e 0a 20 20 54 68 65 20 64  h1>..<p>.  The d
3530: 65 66 61 75 6c 74 20 63 6f 6e 66 69 67 75 72 61  efault configura
3540: 74 69 6f 6e 20 66 6f 72 20 53 51 4c 69 74 65 20  tion for SQLite 
3550: 77 6f 72 6b 73 20 67 72 65 61 74 20 66 6f 72 20  works great for 
3560: 6d 6f 73 74 20 61 70 70 6c 69 63 61 74 69 6f 6e  most application
3570: 73 2e 0a 20 20 42 75 74 20 73 6f 6d 65 74 69 6d  s..  But sometim
3580: 65 73 20 64 65 76 65 6c 6f 70 65 72 73 20 77 61  es developers wa
3590: 6e 74 20 74 6f 20 74 77 65 61 6b 20 74 68 65 20  nt to tweak the 
35a0: 73 65 74 75 70 20 74 6f 20 74 72 79 20 74 6f 20  setup to try to 
35b0: 73 71 75 65 65 7a 65 20 6f 75 74 0a 20 20 61 20  squeeze out.  a 
35c0: 6c 69 74 74 6c 65 20 6d 6f 72 65 20 70 65 72 66  little more perf
35d0: 6f 72 6d 61 6e 63 65 2c 20 6f 72 20 74 61 6b 65  ormance, or take
35e0: 20 61 64 76 61 6e 74 61 67 65 20 6f 66 20 73 6f   advantage of so
35f0: 6d 65 20 6f 62 73 63 75 72 65 20 66 65 61 74 75  me obscure featu
3600: 72 65 2e 0a 3c 70 3e 0a 20 20 54 68 65 20 5b 73  re..<p>.  The [s
3610: 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67 28 29 5d  qlite3_config()]
3620: 20 69 6e 74 65 72 66 61 63 65 20 69 73 20 75 73   interface is us
3630: 65 64 20 74 6f 20 6d 61 6b 65 20 67 6c 6f 62 61  ed to make globa
3640: 6c 2c 20 70 72 6f 63 65 73 73 2d 77 69 64 65 0a  l, process-wide.
3650: 20 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e 20    configuration 
3660: 63 68 61 6e 67 65 73 20 66 6f 72 20 53 51 4c 69  changes for SQLi
3670: 74 65 2e 20 20 54 68 65 20 5b 73 71 6c 69 74 65  te.  The [sqlite
3680: 33 5f 63 6f 6e 66 69 67 28 29 5d 20 69 6e 74 65  3_config()] inte
3690: 72 66 61 63 65 20 6d 75 73 74 0a 20 20 62 65 20  rface must.  be 
36a0: 63 61 6c 6c 65 64 20 62 65 66 6f 72 65 20 61 6e  called before an
36b0: 79 20 5b 64 61 74 61 62 61 73 65 20 63 6f 6e 6e  y [database conn
36c0: 65 63 74 69 6f 6e 73 5d 20 61 72 65 20 63 72 65  ections] are cre
36d0: 61 74 65 64 2e 20 20 54 68 65 0a 20 20 5b 73 71  ated.  The.  [sq
36e0: 6c 69 74 65 33 5f 63 6f 6e 66 69 67 28 29 5d 20  lite3_config()] 
36f0: 69 6e 74 65 72 66 61 63 65 20 61 6c 6c 6f 77 73  interface allows
3700: 20 74 68 65 20 70 72 6f 67 72 61 6d 6d 65 72 20   the programmer 
3710: 74 6f 20 64 6f 20 74 68 69 6e 67 73 20 6c 69 6b  to do things lik
3720: 65 3a 0a 3c 75 6c 3e 0a 3c 6c 69 3e 41 64 6a 75  e:.<ul>.<li>Adju
3730: 73 74 20 68 6f 77 20 53 51 4c 69 74 65 20 64 6f  st how SQLite do
3740: 65 73 20 5b 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63  es [memory alloc
3750: 61 74 69 6f 6e 5d 2c 20 69 6e 63 6c 75 64 69 6e  ation], includin
3760: 67 20 73 65 74 74 69 6e 67 20 75 70 0a 20 20 20  g setting up.   
3770: 20 61 6c 74 65 72 6e 61 74 69 76 65 20 6d 65 6d   alternative mem
3780: 6f 72 79 20 61 6c 6c 6f 63 61 74 6f 72 73 20 61  ory allocators a
3790: 70 70 72 6f 70 72 69 61 74 65 20 66 6f 72 20 73  ppropriate for s
37a0: 61 66 65 74 79 2d 63 72 69 74 69 63 61 6c 0a 20  afety-critical. 
37b0: 20 20 20 72 65 61 6c 2d 74 69 6d 65 20 65 6d 62     real-time emb
37c0: 65 64 64 65 64 20 73 79 73 74 65 6d 73 20 61 6e  edded systems an
37d0: 64 20 61 70 70 6c 69 63 61 74 69 6f 6e 2d 64 65  d application-de
37e0: 66 69 6e 65 64 20 6d 65 6d 6f 72 79 20 61 6c 6c  fined memory all
37f0: 6f 63 61 74 6f 72 73 2e 0a 3c 6c 69 3e 53 65 74  ocators..<li>Set
3800: 20 75 70 20 61 20 70 72 6f 63 65 73 73 2d 77 69   up a process-wi
3810: 64 65 20 5b 65 72 72 6f 72 20 6c 6f 67 5d 2e 0a  de [error log]..
3820: 3c 6c 69 3e 53 70 65 63 69 66 79 20 61 6e 20 61  <li>Specify an a
3830: 70 70 6c 69 63 61 74 69 6f 6e 2d 64 65 66 69 6e  pplication-defin
3840: 65 64 20 70 61 67 65 20 63 61 63 68 65 2e 0a 3c  ed page cache..<
3850: 6c 69 3e 41 64 6a 75 73 74 20 74 68 65 20 75 73  li>Adjust the us
3860: 65 20 6f 66 20 6d 75 74 65 78 65 73 20 73 6f 20  e of mutexes so 
3870: 74 68 61 74 20 74 68 65 79 20 61 72 65 20 61 70  that they are ap
3880: 70 72 6f 70 72 69 61 74 65 20 66 6f 72 20 76 61  propriate for va
3890: 72 69 6f 75 73 0a 20 20 20 20 5b 74 68 72 65 61  rious.    [threa
38a0: 64 69 6e 67 20 6d 6f 64 65 20 7c 20 74 68 72 65  ding mode | thre
38b0: 61 64 69 6e 67 20 6d 6f 64 65 6c 73 5d 2c 20 6f  ading models], o
38c0: 72 20 73 75 62 73 74 69 74 75 74 65 20 61 6e 20  r substitute an 
38d0: 0a 20 20 20 20 61 70 70 6c 69 63 61 74 69 6f 6e  .    application
38e0: 2d 64 65 66 69 6e 65 64 20 6d 75 74 65 78 20 73  -defined mutex s
38f0: 79 73 74 65 6d 2e 0a 3c 2f 75 6c 3e 20 0a 3c 70  ystem..</ul> .<p
3900: 3e 0a 20 20 41 66 74 65 72 20 70 72 6f 63 65 73  >.  After proces
3910: 73 2d 77 69 64 65 20 63 6f 6e 66 69 67 75 72 61  s-wide configura
3920: 74 69 6f 6e 20 69 73 20 63 6f 6d 70 6c 65 74 65  tion is complete
3930: 20 61 6e 64 20 5b 64 61 74 61 62 61 73 65 20 63   and [database c
3940: 6f 6e 6e 65 63 74 69 6f 6e 73 5d 0a 20 20 68 61  onnections].  ha
3950: 76 65 20 62 65 65 6e 20 63 72 65 61 74 65 64 2c  ve been created,
3960: 20 69 6e 64 69 76 69 64 75 61 6c 20 64 61 74 61   individual data
3970: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 73  base connections
3980: 20 63 61 6e 20 62 65 20 63 6f 6e 66 69 67 75 72   can be configur
3990: 65 64 20 75 73 69 6e 67 0a 20 20 63 61 6c 6c 73  ed using.  calls
39a0: 20 74 6f 20 5b 73 71 6c 69 74 65 33 5f 6c 69 6d   to [sqlite3_lim
39b0: 69 74 28 29 5d 20 61 6e 64 20 5b 73 71 6c 69 74  it()] and [sqlit
39c0: 65 33 5f 64 62 5f 63 6f 6e 66 69 67 28 29 5d 2e  e3_db_config()].
39d0: 0a 0a 3c 68 31 3e 45 78 74 65 6e 64 69 6e 67 20  ..<h1>Extending 
39e0: 53 51 4c 69 74 65 3c 2f 68 31 3e 0a 0a 3c 70 3e  SQLite</h1>..<p>
39f0: 0a 20 20 53 51 4c 69 74 65 20 69 6e 63 6c 75 64  .  SQLite includ
3a00: 65 73 20 69 6e 74 65 72 66 61 63 65 73 20 74 68  es interfaces th
3a10: 61 74 20 63 61 6e 20 62 65 20 75 73 65 64 20 74  at can be used t
3a20: 6f 20 65 78 74 65 6e 64 20 69 74 73 20 66 75 6e  o extend its fun
3a30: 63 74 69 6f 6e 61 6c 69 74 79 2e 0a 20 20 53 75  ctionality..  Su
3a40: 63 68 20 72 6f 75 74 69 6e 65 73 20 69 6e 63 6c  ch routines incl
3a50: 75 64 65 3a 0a 3c 2f 70 3e 0a 0a 3c 70 3e 3c 75  ude:.</p>..<p><u
3a60: 6c 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74  l>.  <li> [sqlit
3a70: 65 33 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74  e3_create_collat
3a80: 69 6f 6e 28 29 5d 20 3c 2f 6c 69 3e 0a 20 20 3c  ion()] </li>.  <
3a90: 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f 63 72 65  li> [sqlite3_cre
3aa0: 61 74 65 5f 66 75 6e 63 74 69 6f 6e 28 29 5d 20  ate_function()] 
3ab0: 3c 2f 6c 69 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71  </li>.  <li> [sq
3ac0: 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 6d 6f 64  lite3_create_mod
3ad0: 75 6c 65 28 29 5d 20 3c 2f 6c 69 3e 0a 20 20 3c  ule()] </li>.  <
3ae0: 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f 76 66 73  li> [sqlite3_vfs
3af0: 5f 72 65 67 69 73 74 65 72 28 29 5d 20 3c 2f 6c  _register()] </l
3b00: 69 3e 0a 3c 2f 75 6c 3e 3c 2f 70 3e 0a 0a 3c 70  i>.</ul></p>..<p
3b10: 3e 0a 20 20 54 68 65 20 5b 73 71 6c 69 74 65 33  >.  The [sqlite3
3b20: 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74 69 6f  _create_collatio
3b30: 6e 28 29 5d 20 69 6e 74 65 72 66 61 63 65 20 69  n()] interface i
3b40: 73 20 75 73 65 64 20 74 6f 20 63 72 65 61 74 65  s used to create
3b50: 20 6e 65 77 0a 20 20 5b 63 6f 6c 6c 61 74 69 6e   new.  [collatin
3b60: 67 20 73 65 71 75 65 6e 63 65 73 5d 20 66 6f 72  g sequences] for
3b70: 20 73 6f 72 74 69 6e 67 20 74 65 78 74 2e 0a 20   sorting text.. 
3b80: 20 54 68 65 20 5b 73 71 6c 69 74 65 33 5f 63 72   The [sqlite3_cr
3b90: 65 61 74 65 5f 6d 6f 64 75 6c 65 28 29 5d 20 69  eate_module()] i
3ba0: 6e 74 65 72 66 61 63 65 20 69 73 20 75 73 65 64  nterface is used
3bb0: 20 74 6f 20 72 65 67 69 73 74 65 72 20 6e 65 77   to register new
3bc0: 0a 20 20 5b 76 69 72 74 75 61 6c 20 74 61 62 6c  .  [virtual tabl
3bd0: 65 5d 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  e] implementatio
3be0: 6e 73 2e 0a 20 20 54 68 65 20 5b 73 71 6c 69 74  ns..  The [sqlit
3bf0: 65 33 5f 76 66 73 5f 72 65 67 69 73 74 65 72 28  e3_vfs_register(
3c00: 29 5d 20 69 6e 74 65 72 66 61 63 65 20 63 72 65  )] interface cre
3c10: 61 74 65 73 20 6e 65 77 20 5b 56 46 53 65 73 5d  ates new [VFSes]
3c20: 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a 20 20 54 68  ..</p>..<p>.  Th
3c30: 65 20 5b 73 71 6c 69 74 65 33 5f 63 72 65 61 74  e [sqlite3_creat
3c40: 65 5f 66 75 6e 63 74 69 6f 6e 28 29 5d 20 69 6e  e_function()] in
3c50: 74 65 72 66 61 63 65 20 63 72 65 61 74 65 73 20  terface creates 
3c60: 6e 65 77 20 53 51 4c 20 66 75 6e 63 74 69 6f 6e  new SQL function
3c70: 73 20 2d 20 0a 20 20 65 69 74 68 65 72 20 73 63  s - .  either sc
3c80: 61 6c 61 72 20 6f 72 20 61 67 67 72 65 67 61 74  alar or aggregat
3c90: 65 2e 20 20 54 68 65 20 6e 65 77 20 66 75 6e 63  e.  The new func
3ca0: 74 69 6f 6e 20 69 6d 70 6c 65 6d 65 6e 74 61 74  tion implementat
3cb0: 69 6f 6e 20 74 79 70 69 63 61 6c 6c 79 0a 20 20  ion typically.  
3cc0: 6d 61 6b 65 73 20 75 73 65 20 6f 66 20 74 68 65  makes use of the
3cd0: 20 66 6f 6c 6c 6f 77 69 6e 67 20 61 64 64 69 74   following addit
3ce0: 69 6f 6e 61 6c 20 69 6e 74 65 72 66 61 63 65 73  ional interfaces
3cf0: 3a 0a 3c 2f 70 3e 0a 0a 3c 70 3e 3c 75 6c 3e 0a  :.</p>..<p><ul>.
3d00: 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f    <li> [sqlite3_
3d10: 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78  aggregate_contex
3d20: 74 28 29 5d 20 3c 2f 6c 69 3e 0a 20 20 3c 6c 69  t()] </li>.  <li
3d30: 3e 20 5b 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  > [sqlite3_resul
3d40: 74 5f 69 6e 74 20 7c 20 73 71 6c 69 74 65 33 5f  t_int | sqlite3_
3d50: 72 65 73 75 6c 74 28 29 5d 20 3c 2f 6c 69 3e 0a  result()] </li>.
3d60: 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74 65 33 5f    <li> [sqlite3_
3d70: 75 73 65 72 5f 64 61 74 61 28 29 5d 20 3c 2f 6c  user_data()] </l
3d80: 69 3e 0a 20 20 3c 6c 69 3e 20 5b 73 71 6c 69 74  i>.  <li> [sqlit
3d90: 65 33 5f 76 61 6c 75 65 5f 69 6e 74 20 7c 20 73  e3_value_int | s
3da0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 28 29 5d 20  qlite3_value()] 
3db0: 3c 2f 6c 69 3e 0a 3c 2f 75 6c 3e 3c 2f 70 3e 0a  </li>.</ul></p>.
3dc0: 0a 3c 70 3e 0a 20 20 41 6c 6c 20 6f 66 20 74 68  .<p>.  All of th
3dd0: 65 20 62 75 69 6c 74 2d 69 6e 20 53 51 4c 20 66  e built-in SQL f
3de0: 75 6e 63 74 69 6f 6e 73 20 6f 66 20 53 51 4c 69  unctions of SQLi
3df0: 74 65 20 61 72 65 20 63 72 65 61 74 65 64 20 75  te are created u
3e00: 73 69 6e 67 20 65 78 61 63 74 6c 79 0a 20 20 74  sing exactly.  t
3e10: 68 65 73 65 20 73 61 6d 65 20 69 6e 74 65 72 66  hese same interf
3e20: 61 63 65 73 2e 20 20 52 65 66 65 72 20 74 6f 20  aces.  Refer to 
3e30: 74 68 65 20 53 51 4c 69 74 65 20 73 6f 75 72 63  the SQLite sourc
3e40: 65 20 63 6f 64 65 2c 20 61 6e 64 20 69 6e 20 70  e code, and in p
3e50: 61 72 74 69 63 75 6c 61 72 0a 20 20 74 68 65 20  articular.  the 
3e60: 0a 20 20 5b 68 74 74 70 3a 2f 2f 77 77 77 2e 73  .  [http://www.s
3e70: 71 6c 69 74 65 2e 6f 72 67 2f 73 72 63 2f 64 6f  qlite.org/src/do
3e80: 63 2f 74 72 75 6e 6b 2f 73 72 63 2f 64 61 74 65  c/trunk/src/date
3e90: 2e 63 20 7c 20 64 61 74 65 2e 63 5d 20 61 6e 64  .c | date.c] and
3ea0: 0a 20 20 5b 68 74 74 70 3a 2f 2f 77 77 77 2e 73  .  [http://www.s
3eb0: 71 6c 69 74 65 2e 6f 72 67 2f 73 72 63 2f 64 6f  qlite.org/src/do
3ec0: 63 2f 74 72 75 6e 6b 2f 73 72 63 2f 66 75 6e 63  c/trunk/src/func
3ed0: 2e 63 20 7c 20 66 75 6e 63 2e 63 5d 20 73 6f 75  .c | func.c] sou
3ee0: 72 63 65 20 66 69 6c 65 73 0a 20 20 66 6f 72 20  rce files.  for 
3ef0: 65 78 61 6d 70 6c 65 73 2e 0a 3c 2f 70 3e 0a 0a  examples..</p>..
3f00: 3c 70 3e 0a 20 20 53 68 61 72 65 64 20 6c 69 62  <p>.  Shared lib
3f10: 72 61 72 69 65 73 20 6f 72 20 44 4c 4c 73 20 63  raries or DLLs c
3f20: 61 6e 20 62 65 20 75 73 65 64 20 61 73 20 5b 6c  an be used as [l
3f30: 6f 61 64 61 62 6c 65 20 65 78 74 65 6e 73 69 6f  oadable extensio
3f40: 6e 73 5d 20 74 6f 20 53 51 4c 69 74 65 2e 0a 0a  ns] to SQLite...
3f50: 3c 68 31 3e 4f 74 68 65 72 20 49 6e 74 65 72 66  <h1>Other Interf
3f60: 61 63 65 73 3c 2f 68 31 3e 0a 0a 3c 70 3e 0a 20  aces</h1>..<p>. 
3f70: 20 54 68 69 73 20 61 72 74 69 63 6c 65 20 6f 6e   This article on
3f80: 6c 79 20 6d 65 6e 74 69 6f 6e 73 20 74 68 65 20  ly mentions the 
3f90: 6d 6f 73 74 20 69 6d 70 6f 72 74 61 6e 74 20 61  most important a
3fa0: 6e 64 20 6d 6f 73 74 20 63 6f 6d 6d 6f 6e 6c 79  nd most commonly
3fb0: 0a 20 20 75 73 65 64 20 53 51 4c 69 74 65 20 69  .  used SQLite i
3fc0: 6e 74 65 72 66 61 63 65 73 2e 0a 20 20 54 68 65  nterfaces..  The
3fd0: 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79 20   SQLite library 
3fe0: 69 6e 63 6c 75 64 65 73 20 6d 61 6e 79 20 6f 74  includes many ot
3ff0: 68 65 72 20 41 50 49 73 20 69 6d 70 6c 65 6d 65  her APIs impleme
4000: 6e 74 69 6e 67 20 75 73 65 66 75 6c 0a 20 20 66  nting useful.  f
4010: 65 61 74 75 72 65 73 20 74 68 61 74 20 61 72 65  eatures that are
4020: 20 6e 6f 74 20 64 65 73 63 72 69 62 65 64 20 68   not described h
4030: 65 72 65 2e 20 20 0a 20 20 41 20 5b 63 61 70 69  ere.  .  A [capi
4040: 33 72 65 66 5f 66 75 6e 63 6c 69 73 74 20 7c 20  3ref_funclist | 
4050: 63 6f 6d 70 6c 65 74 65 20 6c 69 73 74 20 6f 66  complete list of
4060: 20 66 75 6e 63 74 69 6f 6e 73 5d 20 74 68 61 74   functions] that
4070: 20 66 6f 72 6d 20 74 68 65 20 53 51 4c 69 74 65   form the SQLite
4080: 0a 20 20 61 70 70 6c 69 63 61 74 69 6f 6e 20 70  .  application p
4090: 72 6f 67 72 61 6d 6d 69 6e 67 20 69 6e 74 65 72  rogramming inter
40a0: 66 61 63 65 20 69 73 20 66 6f 75 6e 64 20 61 74  face is found at
40b0: 20 74 68 65 0a 20 20 5b 63 61 70 69 33 72 65 66   the.  [capi3ref
40c0: 20 7c 20 43 2f 43 2b 2b 20 49 6e 74 65 72 66 61   | C/C++ Interfa
40d0: 63 65 20 53 70 65 63 69 66 69 63 61 74 69 6f 6e  ce Specification
40e0: 5d 2e 0a 20 20 52 65 66 65 72 20 74 6f 20 74 68  ]..  Refer to th
40f0: 61 74 20 64 6f 63 75 6d 65 6e 74 20 66 6f 72 20  at document for 
4100: 63 6f 6d 70 6c 65 74 65 20 61 6e 64 20 61 75 74  complete and aut
4110: 68 6f 72 69 74 61 74 69 76 65 20 69 6e 66 6f 72  horitative infor
4120: 6d 61 74 69 6f 6e 20 61 62 6f 75 74 0a 20 20 61  mation about.  a
4130: 6c 6c 20 53 51 4c 69 74 65 20 69 6e 74 65 72 66  ll SQLite interf
4140: 61 63 65 73 2e 0a 3c 2f 70 3e 0a                 aces..</p>.