/ Hex Artifact Content
Login

Artifact 829b393d1ab187fd7a5e978631b3429318885c49:


0000: 23 0a 23 20 52 75 6e 20 74 68 69 73 20 54 63 6c  #.# Run this Tcl
0010: 20 73 63 72 69 70 74 20 74 6f 20 67 65 6e 65 72   script to gener
0020: 61 74 65 20 74 68 65 20 74 63 6c 73 71 6c 69 74  ate the tclsqlit
0030: 65 2e 68 74 6d 6c 20 66 69 6c 65 2e 0a 23 0a 73  e.html file..#.s
0040: 65 74 20 72 63 73 69 64 20 7b 24 49 64 3a 20 74  et rcsid {$Id: t
0050: 63 6c 73 71 6c 69 74 65 2e 74 63 6c 2c 76 20 31  clsqlite.tcl,v 1
0060: 2e 36 20 32 30 30 32 2f 30 31 2f 31 36 20 32 31  .6 2002/01/16 21
0070: 3a 30 30 3a 32 38 20 64 72 68 20 45 78 70 20 24  :00:28 drh Exp $
0080: 7d 0a 0a 70 75 74 73 20 7b 3c 68 74 6d 6c 3e 0a  }..puts {<html>.
0090: 3c 68 65 61 64 3e 0a 20 20 3c 74 69 74 6c 65 3e  <head>.  <title>
00a0: 54 68 65 20 54 63 6c 20 69 6e 74 65 72 66 61 63  The Tcl interfac
00b0: 65 20 74 6f 20 74 68 65 20 53 51 4c 69 74 65 20  e to the SQLite 
00c0: 6c 69 62 72 61 72 79 3c 2f 74 69 74 6c 65 3e 0a  library</title>.
00d0: 3c 2f 68 65 61 64 3e 0a 3c 62 6f 64 79 20 62 67  </head>.<body bg
00e0: 63 6f 6c 6f 72 3d 77 68 69 74 65 3e 0a 3c 68 31  color=white>.<h1
00f0: 20 61 6c 69 67 6e 3d 63 65 6e 74 65 72 3e 0a 54   align=center>.T
0100: 68 65 20 54 63 6c 20 69 6e 74 65 72 66 61 63 65  he Tcl interface
0110: 20 74 6f 20 74 68 65 20 53 51 4c 69 74 65 20 6c   to the SQLite l
0120: 69 62 72 61 72 79 0a 3c 2f 68 31 3e 7d 0a 70 75  ibrary.</h1>}.pu
0130: 74 73 20 22 3c 70 20 61 6c 69 67 6e 3d 63 65 6e  ts "<p align=cen
0140: 74 65 72 3e 0a 28 54 68 69 73 20 70 61 67 65 20  ter>.(This page 
0150: 77 61 73 20 6c 61 73 74 20 6d 6f 64 69 66 69 65  was last modifie
0160: 64 20 6f 6e 20 5b 6c 72 61 6e 67 65 20 24 72 63  d on [lrange $rc
0170: 73 69 64 20 33 20 34 5d 20 55 54 43 29 0a 3c 2f  sid 3 4] UTC).</
0180: 70 3e 22 0a 0a 70 75 74 73 20 7b 0a 3c 70 3e 54  p>"..puts {.<p>T
0190: 68 65 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72  he SQLite librar
01a0: 79 20 69 73 20 64 65 73 69 67 6e 65 64 20 74 6f  y is designed to
01b0: 20 62 65 20 76 65 72 79 20 65 61 73 79 20 74 6f   be very easy to
01c0: 20 75 73 65 20 66 72 6f 6d 0a 61 20 54 63 6c 20   use from.a Tcl 
01d0: 6f 72 20 54 63 6c 2f 54 6b 20 73 63 72 69 70 74  or Tcl/Tk script
01e0: 2e 20 20 54 68 69 73 20 64 6f 63 75 6d 65 6e 74  .  This document
01f0: 20 67 69 76 65 73 20 61 6e 20 6f 76 65 72 76 69   gives an overvi
0200: 65 77 20 6f 66 20 74 68 65 20 54 63 6c 0a 70 72  ew of the Tcl.pr
0210: 6f 67 72 61 6d 6d 69 6e 67 20 69 6e 74 65 72 66  ogramming interf
0220: 61 63 65 2e 3c 2f 70 3e 0a 0a 3c 68 32 3e 54 68  ace.</p>..<h2>Th
0230: 65 20 41 50 49 3c 2f 68 32 3e 0a 0a 3c 70 3e 54  e API</h2>..<p>T
0240: 68 65 20 69 6e 74 65 72 66 61 63 65 20 74 6f 20  he interface to 
0250: 74 68 65 20 53 51 4c 69 74 65 20 6c 69 62 72 61  the SQLite libra
0260: 72 79 20 63 6f 6e 73 69 73 74 73 20 6f 66 20 73  ry consists of s
0270: 69 6e 67 6c 65 0a 74 63 6c 20 63 6f 6d 6d 61 6e  ingle.tcl comman
0280: 64 20 6e 61 6d 65 64 20 3c 62 3e 73 71 6c 69 74  d named <b>sqlit
0290: 65 3c 2f 62 3e 2e 20 20 42 65 63 61 75 73 65 20  e</b>.  Because 
02a0: 74 68 65 72 65 20 69 73 20 6f 6e 6c 79 20 74 68  there is only th
02b0: 69 73 0a 6f 6e 65 20 69 6e 74 65 72 66 61 63 65  is.one interface
02c0: 20 63 6f 6d 6d 61 6e 64 2c 20 74 68 65 20 69 6e   command, the in
02d0: 74 65 72 66 61 63 65 20 69 73 20 6e 6f 74 20 70  terface is not p
02e0: 6c 61 63 65 64 20 69 6e 20 61 20 73 65 70 61 72  laced in a separ
02f0: 61 74 65 0a 6e 61 6d 65 73 70 61 63 65 2e 3c 2f  ate.namespace.</
0300: 70 3e 0a 0a 3c 70 3e 54 68 65 20 3c 62 3e 73 71  p>..<p>The <b>sq
0310: 6c 69 74 65 3c 2f 62 3e 20 63 6f 6d 6d 61 6e 64  lite</b> command
0320: 20 69 73 20 75 73 65 64 20 61 73 20 66 6f 6c 6c   is used as foll
0330: 6f 77 73 3a 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b  ows:</p>..<block
0340: 71 75 6f 74 65 3e 0a 3c 62 3e 73 71 6c 69 74 65  quote>.<b>sqlite
0350: 3c 2f 62 3e 26 6e 62 73 70 3b 26 6e 62 73 70 3b  </b>&nbsp;&nbsp;
0360: 3c 69 3e 64 62 63 6d 64 26 6e 62 73 70 3b 26 6e  <i>dbcmd&nbsp;&n
0370: 62 73 70 3b 64 61 74 61 62 61 73 65 2d 6e 61 6d  bsp;database-nam
0380: 65 3c 2f 69 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f  e</i>.</blockquo
0390: 74 65 3e 0a 0a 3c 70 3e 0a 54 68 65 20 3c 62 3e  te>..<p>.The <b>
03a0: 73 71 6c 69 74 65 3c 2f 62 3e 20 63 6f 6d 6d 61  sqlite</b> comma
03b0: 6e 64 20 6f 70 65 6e 73 20 74 68 65 20 64 61 74  nd opens the dat
03c0: 61 62 61 73 65 20 6e 61 6d 65 64 20 69 6e 20 74  abase named in t
03d0: 68 65 20 73 65 63 6f 6e 64 0a 61 72 67 75 6d 65  he second.argume
03e0: 6e 74 2e 20 20 49 66 20 74 68 65 20 64 61 74 61  nt.  If the data
03f0: 62 61 73 65 20 64 6f 65 73 20 6e 6f 74 20 61 6c  base does not al
0400: 72 65 61 64 79 20 65 78 69 73 74 2c 20 69 74 20  ready exist, it 
0410: 69 73 0a 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79  is.automatically
0420: 20 63 72 65 61 74 65 64 2e 0a 54 68 65 20 3c 62   created..The <b
0430: 3e 73 71 6c 69 74 65 3c 2f 62 3e 20 63 6f 6d 6d  >sqlite</b> comm
0440: 61 6e 64 20 61 6c 73 6f 20 63 72 65 61 74 65 73  and also creates
0450: 20 61 20 6e 65 77 20 54 63 6c 0a 63 6f 6d 6d 61   a new Tcl.comma
0460: 6e 64 20 74 6f 20 63 6f 6e 74 72 6f 6c 20 74 68  nd to control th
0470: 65 20 64 61 74 61 62 61 73 65 2e 20 20 54 68 65  e database.  The
0480: 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 6e 65 77   name of the new
0490: 20 54 63 6c 20 63 6f 6d 6d 61 6e 64 0a 69 73 20   Tcl command.is 
04a0: 67 69 76 65 6e 20 62 79 20 74 68 65 20 66 69 72  given by the fir
04b0: 73 74 20 61 72 67 75 6d 65 6e 74 2e 20 20 54 68  st argument.  Th
04c0: 69 73 20 61 70 70 72 6f 61 63 68 20 69 73 20 73  is approach is s
04d0: 69 6d 69 6c 61 72 20 74 6f 20 74 68 65 0a 77 61  imilar to the.wa
04e0: 79 20 77 69 64 67 65 74 73 20 61 72 65 20 63 72  y widgets are cr
04f0: 65 61 74 65 64 20 69 6e 20 54 6b 2e 0a 3c 2f 70  eated in Tk..</p
0500: 3e 0a 0a 3c 70 3e 0a 54 68 65 20 6e 61 6d 65 20  >..<p>.The name 
0510: 6f 66 20 74 68 65 20 64 61 74 61 62 61 73 65 20  of the database 
0520: 69 73 20 6a 75 73 74 20 74 68 65 20 6e 61 6d 65  is just the name
0530: 20 6f 66 20 61 20 64 69 73 6b 20 66 69 6c 65 20   of a disk file 
0540: 69 6e 20 77 68 69 63 68 0a 74 68 65 20 64 61 74  in which.the dat
0550: 61 62 61 73 65 20 69 73 20 73 74 6f 72 65 64 2e  abase is stored.
0560: 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a 4f 6e 63 65 20  .</p>..<p>.Once 
0570: 61 6e 20 53 51 4c 69 74 65 20 64 61 74 61 62 61  an SQLite databa
0580: 73 65 20 69 73 20 6f 70 65 6e 2c 20 69 74 20 63  se is open, it c
0590: 61 6e 20 62 65 20 63 6f 6e 74 72 6f 6c 6c 65 64  an be controlled
05a0: 20 75 73 69 6e 67 20 0a 6d 65 74 68 6f 64 73 20   using .methods 
05b0: 6f 66 20 74 68 65 20 3c 69 3e 64 62 63 6d 64 3c  of the <i>dbcmd<
05c0: 2f 69 3e 2e 20 20 54 68 65 72 65 20 61 72 65 20  /i>.  There are 
05d0: 63 75 72 72 65 6e 74 6c 79 20 36 20 6d 65 74 68  currently 6 meth
05e0: 6f 64 73 0a 64 65 66 69 6e 65 64 3a 3c 2f 70 3e  ods.defined:</p>
05f0: 0a 0a 3c 70 3e 0a 3c 75 6c 3e 0a 3c 6c 69 3e 20  ..<p>.<ul>.<li> 
0600: 62 75 73 79 0a 3c 6c 69 3e 20 63 6c 6f 73 65 0a  busy.<li> close.
0610: 3c 6c 69 3e 20 63 6f 6d 70 6c 65 74 65 0a 3c 6c  <li> complete.<l
0620: 69 3e 20 65 76 61 6c 0a 3c 6c 69 3e 20 6c 61 73  i> eval.<li> las
0630: 74 5f 69 6e 73 65 72 74 5f 72 6f 77 69 64 0a 3c  t_insert_rowid.<
0640: 6c 69 3e 20 74 69 6d 65 6f 75 74 0a 3c 2f 75 6c  li> timeout.</ul
0650: 3e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 57 65 20 77 69  >.</p>..<p>We wi
0660: 6c 6c 20 65 78 70 6c 61 69 6e 20 61 6c 6c 20 6f  ll explain all o
0670: 66 20 74 68 65 73 65 20 6d 65 74 68 6f 64 73 2c  f these methods,
0680: 20 74 68 6f 75 67 68 20 6e 6f 74 20 69 6e 20 74   though not in t
0690: 68 61 74 20 6f 72 64 65 72 2e 0a 57 65 20 77 69  hat order..We wi
06a0: 6c 6c 20 62 65 20 62 65 67 69 6e 20 77 69 74 68  ll be begin with
06b0: 20 74 68 65 20 22 63 6c 6f 73 65 22 20 6d 65 74   the "close" met
06c0: 68 6f 64 2e 3c 2f 70 3e 0a 0a 3c 68 32 3e 54 68  hod.</p>..<h2>Th
06d0: 65 20 22 63 6c 6f 73 65 22 20 6d 65 74 68 6f 64  e "close" method
06e0: 3c 2f 68 32 3e 0a 0a 3c 70 3e 0a 41 73 20 69 74  </h2>..<p>.As it
06f0: 73 20 6e 61 6d 65 20 73 75 67 67 65 73 74 73 2c  s name suggests,
0700: 20 74 68 65 20 22 63 6c 6f 73 65 22 20 6d 65 74   the "close" met
0710: 68 6f 64 20 74 6f 20 61 6e 20 53 51 4c 69 74 65  hod to an SQLite
0720: 20 64 61 74 61 62 61 73 65 20 6a 75 73 74 0a 63   database just.c
0730: 6c 6f 73 65 73 20 74 68 65 20 64 61 74 61 62 61  loses the databa
0740: 73 65 2e 20 20 54 68 69 73 20 68 61 73 20 74 68  se.  This has th
0750: 65 20 73 69 64 65 2d 65 66 66 65 63 74 20 6f 66  e side-effect of
0760: 20 64 65 6c 65 74 69 6e 67 20 74 68 65 0a 3c 69   deleting the.<i
0770: 3e 64 62 63 6d 64 3c 2f 69 3e 20 54 63 6c 20 63  >dbcmd</i> Tcl c
0780: 6f 6d 6d 61 6e 64 2e 20 20 48 65 72 65 20 69 73  ommand.  Here is
0790: 20 61 6e 20 65 78 61 6d 70 6c 65 20 6f 66 20 6f   an example of o
07a0: 70 65 6e 69 6e 67 20 61 6e 64 20 74 68 65 6e 0a  pening and then.
07b0: 69 6d 6d 65 64 69 61 74 65 6c 79 20 63 6c 6f 73  immediately clos
07c0: 69 6e 67 20 61 20 64 61 74 61 62 61 73 65 3a 0a  ing a database:.
07d0: 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b 71 75 6f 74  </p>..<blockquot
07e0: 65 3e 0a 3c 62 3e 73 71 6c 69 74 65 20 64 62 31  e>.<b>sqlite db1
07f0: 20 2e 2f 74 65 73 74 64 62 3c 62 72 3e 0a 64 62   ./testdb<br>.db
0800: 31 20 63 6c 6f 73 65 3c 2f 62 3e 0a 3c 2f 62 6c  1 close</b>.</bl
0810: 6f 63 6b 71 75 6f 74 65 3e 0a 0a 3c 70 3e 0a 49  ockquote>..<p>.I
0820: 66 20 79 6f 75 20 64 65 6c 65 74 65 20 74 68 65  f you delete the
0830: 20 3c 69 3e 64 62 63 6d 64 3c 2f 69 3e 20 64 69   <i>dbcmd</i> di
0840: 72 65 63 74 6c 79 2c 20 74 68 61 74 20 68 61 73  rectly, that has
0850: 20 74 68 65 20 73 61 6d 65 20 65 66 66 65 63 74   the same effect
0860: 0a 61 73 20 69 6e 76 6f 6b 69 6e 67 20 74 68 65  .as invoking the
0870: 20 22 63 6c 6f 73 65 22 20 6d 65 74 68 6f 64 2e   "close" method.
0880: 20 20 53 6f 20 74 68 65 20 66 6f 6c 6c 6f 77 69    So the followi
0890: 6e 67 20 63 6f 64 65 20 69 73 20 65 71 75 69 76  ng code is equiv
08a0: 61 6c 65 6e 74 0a 74 6f 20 74 68 65 20 70 72 65  alent.to the pre
08b0: 76 69 6f 75 73 3a 3c 2f 70 3e 0a 0a 3c 62 6c 6f  vious:</p>..<blo
08c0: 63 6b 71 75 6f 74 65 3e 0a 3c 62 3e 73 71 6c 69  ckquote>.<b>sqli
08d0: 74 65 20 64 62 31 20 2e 2f 74 65 73 74 64 62 3c  te db1 ./testdb<
08e0: 62 72 3e 0a 72 65 6e 61 6d 65 20 64 62 31 20 7b  br>.rename db1 {
08f0: 7d 3c 2f 62 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f  }</b>.</blockquo
0900: 74 65 3e 0a 0a 3c 68 32 3e 54 68 65 20 22 65 76  te>..<h2>The "ev
0910: 61 6c 22 20 6d 65 74 68 6f 64 3c 2f 68 32 3e 0a  al" method</h2>.
0920: 0a 3c 70 3e 0a 54 68 65 20 6d 6f 73 74 20 75 73  .<p>.The most us
0930: 65 66 75 6c 20 3c 69 3e 64 62 63 6d 64 3c 2f 69  eful <i>dbcmd</i
0940: 3e 20 6d 65 74 68 6f 64 20 69 73 20 22 65 76 61  > method is "eva
0950: 6c 22 2e 20 20 54 68 65 20 65 76 61 6c 20 6d 65  l".  The eval me
0960: 74 68 6f 64 20 69 73 20 75 73 65 64 0a 74 6f 20  thod is used.to 
0970: 65 78 65 63 75 74 65 20 53 51 4c 20 6f 6e 20 74  execute SQL on t
0980: 68 65 20 64 61 74 61 62 61 73 65 2e 20 20 54 68  he database.  Th
0990: 65 20 73 79 6e 74 61 78 20 6f 66 20 74 68 65 20  e syntax of the 
09a0: 65 76 61 6c 20 6d 65 74 68 6f 64 20 6c 6f 6f 6b  eval method look
09b0: 73 0a 6c 69 6b 65 20 74 68 69 73 3a 3c 2f 70 3e  s.like this:</p>
09c0: 0a 0a 3c 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c  ..<blockquote>.<
09d0: 69 3e 64 62 63 6d 64 3c 2f 69 3e 26 6e 62 73 70  i>dbcmd</i>&nbsp
09e0: 3b 26 6e 62 73 70 3b 3c 62 3e 65 76 61 6c 3c 2f  ;&nbsp;<b>eval</
09f0: 62 3e 26 6e 62 73 70 3b 26 6e 62 73 70 3b 3c 69  b>&nbsp;&nbsp;<i
0a00: 3e 73 71 6c 3c 2f 69 3e 0a 26 6e 62 73 70 3b 26  >sql</i>.&nbsp;&
0a10: 6e 62 73 70 3b 3f 3c 69 3e 61 72 72 61 79 2d 6e  nbsp;?<i>array-n
0a20: 61 6d 65 26 6e 62 73 70 3b 26 6e 62 73 70 3b 73  ame&nbsp;&nbsp;s
0a30: 63 72 69 70 74 3c 2f 69 3e 3f 0a 3c 2f 62 6c 6f  cript</i>?.</blo
0a40: 63 6b 71 75 6f 74 65 3e 0a 0a 3c 70 3e 0a 54 68  ckquote>..<p>.Th
0a50: 65 20 6a 6f 62 20 6f 66 20 74 68 65 20 65 76 61  e job of the eva
0a60: 6c 20 6d 65 74 68 6f 64 20 69 73 20 74 6f 20 65  l method is to e
0a70: 78 65 63 75 74 65 20 74 68 65 20 53 51 4c 20 73  xecute the SQL s
0a80: 74 61 74 65 6d 65 6e 74 20 6f 72 20 73 74 61 74  tatement or stat
0a90: 65 6d 65 6e 74 73 0a 67 69 76 65 6e 20 69 6e 20  ements.given in 
0aa0: 74 68 65 20 73 65 63 6f 6e 64 20 61 72 67 75 6d  the second argum
0ab0: 65 6e 74 2e 20 20 46 6f 72 20 65 78 61 6d 70 6c  ent.  For exampl
0ac0: 65 2c 20 74 6f 20 63 72 65 61 74 65 20 61 20 6e  e, to create a n
0ad0: 65 77 20 74 61 62 6c 65 20 69 6e 0a 61 20 64 61  ew table in.a da
0ae0: 74 61 62 61 73 65 2c 20 79 6f 75 20 63 61 6e 20  tabase, you can 
0af0: 64 6f 20 74 68 69 73 3a 3c 2f 70 3e 0a 0a 3c 62  do this:</p>..<b
0b00: 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 62 3e 73 71  lockquote>.<b>sq
0b10: 6c 69 74 65 20 64 62 31 20 2e 2f 74 65 73 74 64  lite db1 ./testd
0b20: 62 3c 62 72 3e 0a 64 62 31 20 65 76 61 6c 20 7b  b<br>.db1 eval {
0b30: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
0b40: 61 20 69 6e 74 2c 20 62 20 74 65 78 74 29 7d 3c  a int, b text)}<
0b50: 2f 62 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65  /b>.</blockquote
0b60: 3e 0a 0a 3c 70 3e 54 68 65 20 61 62 6f 76 65 20  >..<p>The above 
0b70: 63 6f 64 65 20 63 72 65 61 74 65 73 20 61 20 6e  code creates a n
0b80: 65 77 20 74 61 62 6c 65 20 6e 61 6d 65 64 20 3c  ew table named <
0b90: 62 3e 74 31 3c 2f 62 3e 20 77 69 74 68 20 63 6f  b>t1</b> with co
0ba0: 6c 75 6d 6e 73 0a 3c 62 3e 61 3c 2f 62 3e 20 61  lumns.<b>a</b> a
0bb0: 6e 64 20 3c 62 3e 62 3c 2f 62 3e 2e 20 20 57 68  nd <b>b</b>.  Wh
0bc0: 61 74 20 63 6f 75 6c 64 20 62 65 20 73 69 6d 70  at could be simp
0bd0: 6c 65 72 3f 3c 2f 70 3e 0a 0a 3c 70 3e 51 75 65  ler?</p>..<p>Que
0be0: 72 79 20 72 65 73 75 6c 74 73 20 61 72 65 20 72  ry results are r
0bf0: 65 74 75 72 6e 65 64 20 61 73 20 61 20 6c 69 73  eturned as a lis
0c00: 74 20 6f 66 20 63 6f 6c 75 6d 6e 20 76 61 6c 75  t of column valu
0c10: 65 73 2e 20 20 49 66 20 61 0a 71 75 65 72 79 20  es.  If a.query 
0c20: 72 65 71 75 65 73 74 73 20 32 20 63 6f 6c 75 6d  requests 2 colum
0c30: 6e 73 20 61 6e 64 20 74 68 65 72 65 20 61 72 65  ns and there are
0c40: 20 33 20 72 6f 77 73 20 6d 61 74 63 68 69 6e 67   3 rows matching
0c50: 20 74 68 65 20 71 75 65 72 79 2c 0a 74 68 65 6e   the query,.then
0c60: 20 74 68 65 20 72 65 74 75 72 6e 65 64 20 6c 69   the returned li
0c70: 73 74 20 77 69 6c 6c 20 63 6f 6e 74 61 69 6e 20  st will contain 
0c80: 36 20 65 6c 65 6d 65 6e 74 73 2e 20 20 46 6f 72  6 elements.  For
0c90: 20 65 78 61 6d 70 6c 65 3a 3c 2f 70 3e 0a 0a 3c   example:</p>..<
0ca0: 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 62 3e 64  blockquote>.<b>d
0cb0: 62 31 20 65 76 61 6c 20 7b 49 4e 53 45 52 54 20  b1 eval {INSERT 
0cc0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31  INTO t1 VALUES(1
0cd0: 2c 27 68 65 6c 6c 6f 27 29 7d 3c 62 72 3e 0a 64  ,'hello')}<br>.d
0ce0: 62 31 20 65 76 61 6c 20 7b 49 4e 53 45 52 54 20  b1 eval {INSERT 
0cf0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 32  INTO t1 VALUES(2
0d00: 2c 27 67 6f 6f 64 62 79 65 27 29 7d 3c 62 72 3e  ,'goodbye')}<br>
0d10: 0a 64 62 31 20 65 76 61 6c 20 7b 49 4e 53 45 52  .db1 eval {INSER
0d20: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
0d30: 28 33 2c 27 68 6f 77 64 79 21 27 29 7d 3c 62 72  (3,'howdy!')}<br
0d40: 3e 0a 73 65 74 20 78 20 5b 64 62 31 20 65 76 61  >.set x [db1 eva
0d50: 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  l {SELECT * FROM
0d60: 20 74 31 20 4f 52 44 45 52 20 42 59 20 61 7d 5d   t1 ORDER BY a}]
0d70: 3c 2f 62 3e 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74  </b>.</blockquot
0d80: 65 3e 0a 0a 3c 70 3e 54 68 65 20 76 61 72 69 61  e>..<p>The varia
0d90: 62 6c 65 20 3c 62 3e 24 78 3c 2f 62 3e 20 69 73  ble <b>$x</b> is
0da0: 20 73 65 74 20 62 79 20 74 68 65 20 61 62 6f 76   set by the abov
0db0: 65 20 63 6f 64 65 20 74 6f 3c 2f 70 3e 0a 0a 3c  e code to</p>..<
0dc0: 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 3c 62 3e 31  blockquote>.<b>1
0dd0: 20 68 65 6c 6c 6f 20 32 20 67 6f 6f 64 62 79 65   hello 2 goodbye
0de0: 20 33 20 68 6f 77 64 79 21 3c 2f 62 3e 0a 3c 2f   3 howdy!</b>.</
0df0: 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 0a 3c 70 3e  blockquote>..<p>
0e00: 59 6f 75 20 63 61 6e 20 61 6c 73 6f 20 70 72 6f  You can also pro
0e10: 63 65 73 73 20 74 68 65 20 72 65 73 75 6c 74 73  cess the results
0e20: 20 6f 66 20 61 20 71 75 65 72 79 20 6f 6e 65 20   of a query one 
0e30: 72 6f 77 20 61 74 20 61 20 74 69 6d 65 0a 62 79  row at a time.by
0e40: 20 73 70 65 63 69 66 79 69 6e 67 20 74 68 65 20   specifying the 
0e50: 6e 61 6d 65 20 6f 66 20 61 6e 20 61 72 72 61 79  name of an array
0e60: 20 76 61 72 69 61 62 6c 65 20 61 6e 64 20 61 20   variable and a 
0e70: 73 63 72 69 70 74 20 66 6f 6c 6c 6f 77 69 6e 67  script following
0e80: 0a 74 68 65 20 53 51 4c 20 63 6f 64 65 2e 20 20  .the SQL code.  
0e90: 46 6f 72 20 65 61 63 68 20 72 6f 77 20 6f 66 20  For each row of 
0ea0: 74 68 65 20 71 75 65 72 79 20 72 65 73 75 6c 74  the query result
0eb0: 2c 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20 65  , the value of e
0ec0: 61 63 68 0a 63 6f 6c 75 6d 6e 20 77 69 6c 6c 20  ach.column will 
0ed0: 62 65 20 69 6e 73 65 72 74 65 64 20 69 6e 74 6f  be inserted into
0ee0: 20 74 68 65 20 61 72 72 61 79 20 76 61 72 69 61   the array varia
0ef0: 62 6c 65 20 61 6e 64 20 74 68 65 20 73 63 72 69  ble and the scri
0f00: 70 74 20 77 69 6c 6c 0a 62 65 20 65 78 65 63 75  pt will.be execu
0f10: 74 65 64 2e 20 20 46 6f 72 20 69 6e 73 74 61 6e  ted.  For instan
0f20: 63 65 3a 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b 71  ce:</p>..<blockq
0f30: 75 6f 74 65 3e 0a 3c 62 3e 64 62 31 20 65 76 61  uote>.<b>db1 eva
0f40: 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d  l {SELECT * FROM
0f50: 20 74 31 20 4f 52 44 45 52 20 42 59 20 61 7d 20   t1 ORDER BY a} 
0f60: 76 61 6c 75 65 73 20 7b 3c 62 72 3e 0a 26 6e 62  values {<br>.&nb
0f70: 73 70 3b 26 6e 62 73 70 3b 26 6e 62 73 70 3b 26  sp;&nbsp;&nbsp;&
0f80: 6e 62 73 70 3b 70 61 72 72 61 79 20 76 61 6c 75  nbsp;parray valu
0f90: 65 73 3c 62 72 3e 0a 26 6e 62 73 70 3b 26 6e 62  es<br>.&nbsp;&nb
0fa0: 73 70 3b 26 6e 62 73 70 3b 26 6e 62 73 70 3b 70  sp;&nbsp;&nbsp;p
0fb0: 75 74 73 20 22 22 3c 62 72 3e 0a 7d 3c 2f 62 3e  uts ""<br>.}</b>
0fc0: 0a 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 0a  .</blockquote>..
0fd0: 3c 70 3e 54 68 69 73 20 6c 61 73 74 20 63 6f 64  <p>This last cod
0fe0: 65 20 77 69 6c 6c 20 67 69 76 65 20 74 68 65 20  e will give the 
0ff0: 66 6f 6c 6c 6f 77 69 6e 67 20 6f 75 74 70 75 74  following output
1000: 3a 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b 71 75 6f  :</p>..<blockquo
1010: 74 65 3e 3c 62 3e 0a 76 61 6c 75 65 73 28 2a 29  te><b>.values(*)
1020: 20 3d 20 61 20 62 3c 62 72 3e 0a 76 61 6c 75 65   = a b<br>.value
1030: 73 28 61 29 20 3d 20 31 3c 62 72 3e 0a 76 61 6c  s(a) = 1<br>.val
1040: 75 65 73 28 62 29 20 3d 20 68 65 6c 6c 6f 3c 70  ues(b) = hello<p
1050: 3e 0a 0a 76 61 6c 75 65 73 28 2a 29 20 3d 20 61  >..values(*) = a
1060: 20 62 3c 62 72 3e 0a 76 61 6c 75 65 73 28 61 29   b<br>.values(a)
1070: 20 3d 20 32 3c 62 72 3e 0a 76 61 6c 75 65 73 28   = 2<br>.values(
1080: 62 29 20 3d 20 67 6f 6f 64 62 79 65 3c 70 3e 0a  b) = goodbye<p>.
1090: 0a 76 61 6c 75 65 73 28 2a 29 20 3d 20 61 20 62  .values(*) = a b
10a0: 3c 62 72 3e 0a 76 61 6c 75 65 73 28 61 29 20 3d  <br>.values(a) =
10b0: 20 33 3c 62 72 3e 0a 76 61 6c 75 65 73 28 62 29   3<br>.values(b)
10c0: 20 3d 20 68 6f 77 64 79 21 3c 2f 62 3e 0a 3c 2f   = howdy!</b>.</
10d0: 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 0a 3c 70 3e  blockquote>..<p>
10e0: 0a 46 6f 72 20 65 61 63 68 20 63 6f 6c 75 6d 6e  .For each column
10f0: 20 69 6e 20 61 20 72 6f 77 20 6f 66 20 74 68 65   in a row of the
1100: 20 72 65 73 75 6c 74 2c 20 74 68 65 20 6e 61 6d   result, the nam
1110: 65 20 6f 66 20 74 68 61 74 20 63 6f 6c 75 6d 6e  e of that column
1120: 0a 69 73 20 75 73 65 64 20 61 73 20 61 6e 20 69  .is used as an i
1130: 6e 64 65 78 20 69 6e 20 74 6f 20 61 72 72 61 79  ndex in to array
1140: 2e 20 20 54 68 65 20 76 61 6c 75 65 20 6f 66 20  .  The value of 
1150: 74 68 65 20 63 6f 6c 75 6d 6e 20 69 73 20 73 74  the column is st
1160: 6f 72 65 64 0a 69 6e 20 74 68 65 20 63 6f 72 72  ored.in the corr
1170: 65 73 70 6f 6e 64 69 6e 67 20 61 72 72 61 79 20  esponding array 
1180: 65 6e 74 72 79 2e 20 20 54 68 65 20 73 70 65 63  entry.  The spec
1190: 69 61 6c 20 61 72 72 61 79 20 69 6e 64 65 78 20  ial array index 
11a0: 2a 20 69 73 0a 75 73 65 64 20 74 6f 20 73 74 6f  * is.used to sto
11b0: 72 65 20 61 20 6c 69 73 74 20 6f 66 20 63 6f 6c  re a list of col
11c0: 75 6d 6e 20 6e 61 6d 65 73 20 69 6e 20 74 68 65  umn names in the
11d0: 20 6f 72 64 65 72 20 74 68 61 74 20 74 68 65 79   order that they
11e0: 20 61 70 70 65 61 72 2e 0a 3c 2f 70 3e 0a 0a 3c   appear..</p>..<
11f0: 70 3e 0a 49 66 20 74 68 65 20 61 72 72 61 79 20  p>.If the array 
1200: 76 61 72 69 61 62 6c 65 20 6e 61 6d 65 20 69 73  variable name is
1210: 20 74 68 65 20 65 6d 70 74 79 20 73 74 72 69 6e   the empty strin
1220: 67 2c 20 74 68 65 6e 20 74 68 65 20 76 61 6c 75  g, then the valu
1230: 65 20 6f 66 0a 65 61 63 68 20 63 6f 6c 75 6d 6e  e of.each column
1240: 20 69 73 20 73 74 6f 72 65 64 20 69 6e 20 61 20   is stored in a 
1250: 76 61 72 69 61 62 6c 65 20 77 69 74 68 20 74 68  variable with th
1260: 65 20 73 61 6d 65 20 6e 61 6d 65 20 61 73 20 74  e same name as t
1270: 68 65 20 63 6f 6c 75 6d 6e 0a 69 74 73 65 6c 66  he column.itself
1280: 2e 20 20 46 6f 72 20 65 78 61 6d 70 6c 65 3a 0a  .  For example:.
1290: 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b 71 75 6f 74  </p>..<blockquot
12a0: 65 3e 0a 3c 62 3e 64 62 31 20 65 76 61 6c 20 7b  e>.<b>db1 eval {
12b0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31  SELECT * FROM t1
12c0: 20 4f 52 44 45 52 20 42 59 20 61 7d 20 7b 7d 20   ORDER BY a} {} 
12d0: 7b 3c 62 72 3e 0a 26 6e 62 73 70 3b 26 6e 62 73  {<br>.&nbsp;&nbs
12e0: 70 3b 26 6e 62 73 70 3b 26 6e 62 73 70 3b 70 75  p;&nbsp;&nbsp;pu
12f0: 74 73 20 22 61 3d 24 61 20 62 3d 24 62 22 3c 62  ts "a=$a b=$b"<b
1300: 72 3e 0a 7d 3c 2f 62 3e 0a 3c 2f 62 6c 6f 63 6b  r>.}</b>.</block
1310: 71 75 6f 74 65 3e 0a 0a 3c 70 3e 0a 46 72 6f 6d  quote>..<p>.From
1320: 20 74 68 69 73 20 77 65 20 67 65 74 20 74 68 65   this we get the
1330: 20 66 6f 6c 6c 6f 77 69 6e 67 20 6f 75 74 70 75   following outpu
1340: 74 0a 3c 2f 70 3e 0a 0a 3c 62 6c 6f 63 6b 71 75  t.</p>..<blockqu
1350: 6f 74 65 3e 3c 62 3e 0a 61 3d 31 20 62 3d 68 65  ote><b>.a=1 b=he
1360: 6c 6c 6f 3c 62 72 3e 0a 61 3d 32 20 62 3d 67 6f  llo<br>.a=2 b=go
1370: 6f 64 62 79 65 3c 62 72 3e 0a 61 3d 33 20 62 3d  odbye<br>.a=3 b=
1380: 68 6f 77 64 79 21 3c 2f 62 3e 0a 3c 2f 62 6c 6f  howdy!</b>.</blo
1390: 63 6b 71 75 6f 74 65 3e 0a 0a 3c 68 32 3e 54 68  ckquote>..<h2>Th
13a0: 65 20 22 63 6f 6d 70 6c 65 74 65 22 20 6d 65 74  e "complete" met
13b0: 68 6f 64 3c 2f 68 32 3e 0a 0a 3c 70 3e 0a 54 68  hod</h2>..<p>.Th
13c0: 65 20 22 63 6f 6d 70 6c 65 74 65 22 20 6d 65 74  e "complete" met
13d0: 68 6f 64 20 74 61 6b 65 73 20 61 20 73 74 72 69  hod takes a stri
13e0: 6e 67 20 6f 66 20 73 75 70 70 6f 73 65 64 20 53  ng of supposed S
13f0: 51 4c 20 61 73 20 69 74 73 20 6f 6e 6c 79 20 61  QL as its only a
1400: 72 67 75 6d 65 6e 74 2e 0a 49 74 20 72 65 74 75  rgument..It retu
1410: 72 6e 73 20 54 52 55 45 20 69 66 20 74 68 65 20  rns TRUE if the 
1420: 73 74 72 69 6e 67 20 69 73 20 61 20 63 6f 6d 70  string is a comp
1430: 6c 65 74 65 20 73 74 61 74 65 6d 65 6e 74 20 6f  lete statement o
1440: 66 20 53 51 4c 20 61 6e 64 20 46 41 4c 53 45 20  f SQL and FALSE 
1450: 69 66 0a 74 68 65 72 65 20 69 73 20 6d 6f 72 65  if.there is more
1460: 20 74 6f 20 62 65 20 65 6e 74 65 72 65 64 2e 3c   to be entered.<
1470: 2f 70 3e 0a 0a 3c 70 3e 54 68 65 20 22 63 6f 6d  /p>..<p>The "com
1480: 70 6c 65 74 65 22 20 6d 65 74 68 6f 64 20 69 73  plete" method is
1490: 20 75 73 65 66 75 6c 20 77 68 65 6e 20 62 75 69   useful when bui
14a0: 6c 64 69 6e 67 20 69 6e 74 65 72 61 63 74 69 76  lding interactiv
14b0: 65 20 61 70 70 6c 69 63 61 74 69 6f 6e 73 0a 69  e applications.i
14c0: 6e 20 6f 72 64 65 72 20 74 6f 20 6b 6e 6f 77 20  n order to know 
14d0: 77 68 65 6e 20 74 68 65 20 75 73 65 72 20 68 61  when the user ha
14e0: 73 20 66 69 6e 69 73 68 65 64 20 65 6e 74 65 72  s finished enter
14f0: 69 6e 67 20 61 20 6c 69 6e 65 20 6f 66 20 53 51  ing a line of SQ
1500: 4c 20 63 6f 64 65 2e 0a 54 68 69 73 20 69 73 20  L code..This is 
1510: 72 65 61 6c 6c 79 20 6a 75 73 74 20 61 6e 20 69  really just an i
1520: 6e 74 65 72 66 61 63 65 20 74 6f 20 74 68 65 20  nterface to the 
1530: 3c 62 3e 73 71 6c 69 74 65 5f 63 6f 6d 70 6c 65  <b>sqlite_comple
1540: 74 65 28 29 3c 2f 62 3e 20 43 0a 66 75 6e 63 74  te()</b> C.funct
1550: 69 6f 6e 2e 20 20 52 65 66 65 72 20 74 6f 20 74  ion.  Refer to t
1560: 68 65 20 3c 61 20 68 72 65 66 3d 22 63 5f 69 6e  he <a href="c_in
1570: 74 65 72 66 61 63 65 2e 68 74 6d 6c 22 3e 43 2f  terface.html">C/
1580: 43 2b 2b 20 69 6e 74 65 72 66 61 63 65 3c 2f 61  C++ interface</a
1590: 3e 0a 73 70 65 63 69 66 69 63 61 74 69 6f 6e 20  >.specification 
15a0: 66 6f 72 20 61 64 64 69 74 69 6f 6e 61 6c 20 69  for additional i
15b0: 6e 66 6f 72 6d 61 74 69 6f 6e 2e 3c 2f 70 3e 0a  nformation.</p>.
15c0: 0a 3c 68 32 3e 54 68 65 20 22 74 69 6d 65 6f 75  .<h2>The "timeou
15d0: 74 22 20 6d 65 74 68 6f 64 3c 2f 68 32 3e 0a 0a  t" method</h2>..
15e0: 3c 70 3e 54 68 65 20 22 74 69 6d 65 6f 75 74 22  <p>The "timeout"
15f0: 20 6d 65 74 68 6f 64 20 69 73 20 75 73 65 64 20   method is used 
1600: 74 6f 20 63 6f 6e 74 72 6f 6c 20 68 6f 77 20 6c  to control how l
1610: 6f 6e 67 20 74 68 65 20 53 51 4c 69 74 65 20 6c  ong the SQLite l
1620: 69 62 72 61 72 79 0a 77 69 6c 6c 20 77 61 69 74  ibrary.will wait
1630: 20 66 6f 72 20 6c 6f 63 6b 73 20 74 6f 20 63 6c   for locks to cl
1640: 65 61 72 20 62 65 66 6f 72 65 20 67 69 76 69 6e  ear before givin
1650: 67 20 75 70 20 6f 6e 20 61 20 64 61 74 61 62 61  g up on a databa
1660: 73 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e 0a  se transaction..
1670: 54 68 65 20 64 65 66 61 75 6c 74 20 74 69 6d 65  The default time
1680: 6f 75 74 20 69 73 20 30 20 6d 69 6c 6c 69 73 65  out is 0 millise
1690: 63 6f 6e 64 2e 20 20 28 49 6e 20 6f 74 68 65 72  cond.  (In other
16a0: 20 77 6f 72 64 73 2c 20 74 68 65 20 64 65 66 61   words, the defa
16b0: 75 6c 74 20 62 65 68 61 76 69 6f 72 0a 69 73 20  ult behavior.is 
16c0: 6e 6f 74 20 74 6f 20 77 61 69 74 20 61 74 20 61  not to wait at a
16d0: 6c 6c 2e 29 3c 2f 70 3e 0a 0a 3c 70 3e 54 68 65  ll.)</p>..<p>The
16e0: 20 53 51 6c 69 74 65 20 64 61 74 61 62 61 73 65   SQlite database
16f0: 20 61 6c 6c 6f 77 73 20 6d 75 6c 74 69 70 6c 65   allows multiple
1700: 20 73 69 6d 75 6c 74 61 6e 65 6f 75 73 0a 72 65   simultaneous.re
1710: 61 64 65 72 73 20 6f 72 20 61 20 73 69 6e 67 6c  aders or a singl
1720: 65 20 77 72 69 74 65 72 20 62 75 74 20 6e 6f 74  e writer but not
1730: 20 62 6f 74 68 2e 20 20 49 66 20 61 6e 79 20 70   both.  If any p
1740: 72 6f 63 65 73 73 20 69 73 20 77 72 69 74 69 6e  rocess is writin
1750: 67 20 74 6f 0a 74 68 65 20 64 61 74 61 62 61 73  g to.the databas
1760: 65 20 6e 6f 20 6f 74 68 65 72 20 70 72 6f 63 65  e no other proce
1770: 73 73 20 69 73 20 61 6c 6c 6f 77 73 20 74 6f 20  ss is allows to 
1780: 72 65 61 64 20 6f 72 20 77 72 69 74 65 2e 20 20  read or write.  
1790: 49 66 20 61 6e 79 20 70 72 6f 63 65 73 73 0a 69  If any process.i
17a0: 73 20 72 65 61 64 69 6e 67 20 74 68 65 20 64 61  s reading the da
17b0: 74 61 62 61 73 65 20 6f 74 68 65 72 20 70 72 6f  tabase other pro
17c0: 63 65 73 73 65 73 20 61 72 65 20 61 6c 6c 6f 77  cesses are allow
17d0: 65 64 20 74 6f 20 72 65 61 64 20 62 75 74 20 6e  ed to read but n
17e0: 6f 74 20 77 72 69 74 65 2e 0a 54 68 65 20 65 6e  ot write..The en
17f0: 74 69 72 65 20 64 61 74 61 62 61 73 65 20 73 68  tire database sh
1800: 61 72 65 64 20 61 20 73 69 6e 67 6c 65 20 6c 6f  ared a single lo
1810: 63 6b 2e 3c 2f 70 3e 0a 0a 3c 70 3e 57 68 65 6e  ck.</p>..<p>When
1820: 20 53 51 4c 69 74 65 20 74 72 69 65 73 20 74 6f   SQLite tries to
1830: 20 6f 70 65 6e 20 61 20 64 61 74 61 62 61 73 65   open a database
1840: 20 61 6e 64 20 66 69 6e 64 73 20 74 68 61 74 20   and finds that 
1850: 69 74 20 69 73 20 6c 6f 63 6b 65 64 2c 20 69 74  it is locked, it
1860: 0a 63 61 6e 20 6f 70 74 69 6f 6e 61 6c 6c 79 20  .can optionally 
1870: 64 65 6c 61 79 20 66 6f 72 20 61 20 73 68 6f 72  delay for a shor
1880: 74 20 77 68 69 6c 65 20 61 6e 64 20 74 72 79 20  t while and try 
1890: 74 6f 20 6f 70 65 6e 20 74 68 65 20 66 69 6c 65  to open the file
18a0: 20 61 67 61 69 6e 2e 0a 54 68 69 73 20 70 72 6f   again..This pro
18b0: 63 65 73 73 20 72 65 70 65 61 74 73 20 75 6e 74  cess repeats unt
18c0: 69 6c 20 74 68 65 20 71 75 65 72 79 20 74 69 6d  il the query tim
18d0: 65 73 20 6f 75 74 20 61 6e 64 20 53 51 4c 69 74  es out and SQLit
18e0: 65 20 72 65 74 75 72 6e 73 20 61 0a 66 61 69 6c  e returns a.fail
18f0: 75 72 65 2e 20 20 54 68 65 20 74 69 6d 65 6f 75  ure.  The timeou
1900: 74 20 69 73 20 61 64 6a 75 73 74 61 62 6c 65 2e  t is adjustable.
1910: 20 20 49 74 20 69 73 20 73 65 74 20 74 6f 20 30    It is set to 0
1920: 20 62 79 20 64 65 66 61 75 6c 74 20 73 6f 20 74   by default so t
1930: 68 61 74 0a 69 66 20 74 68 65 20 64 61 74 61 62  hat.if the datab
1940: 61 73 65 20 69 73 20 6c 6f 63 6b 65 64 2c 20 74  ase is locked, t
1950: 68 65 20 53 51 4c 20 73 74 61 74 65 6d 65 6e 74  he SQL statement
1960: 20 66 61 69 6c 73 20 69 6d 6d 65 64 69 61 74 65   fails immediate
1970: 6c 79 2e 20 20 42 75 74 20 79 6f 75 0a 63 61 6e  ly.  But you.can
1980: 20 75 73 65 20 74 68 65 20 22 74 69 6d 65 6f 75   use the "timeou
1990: 74 22 20 6d 65 74 68 6f 64 20 74 6f 20 63 68 61  t" method to cha
19a0: 6e 67 65 20 74 68 65 20 74 69 6d 65 6f 75 74 20  nge the timeout 
19b0: 76 61 6c 75 65 20 74 6f 20 61 20 70 6f 73 69 74  value to a posit
19c0: 69 76 65 0a 6e 75 6d 62 65 72 2e 20 20 46 6f 72  ive.number.  For
19d0: 20 65 78 61 6d 70 6c 65 3a 3c 2f 70 3e 0a 0a 3c   example:</p>..<
19e0: 62 6c 6f 63 6b 71 75 6f 74 65 3e 3c 62 3e 64 62  blockquote><b>db
19f0: 31 20 74 69 6d 65 6f 75 74 20 32 30 30 30 3c 2f  1 timeout 2000</
1a00: 62 3e 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a  b></blockquote>.
1a10: 0a 3c 70 3e 54 68 65 20 61 72 67 75 6d 65 6e 74  .<p>The argument
1a20: 20 74 6f 20 74 68 65 20 74 69 6d 65 6f 75 74 20   to the timeout 
1a30: 6d 65 74 68 6f 64 20 69 73 20 74 68 65 20 6d 61  method is the ma
1a40: 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20  ximum number of 
1a50: 6d 69 6c 6c 69 73 65 63 6f 6e 64 73 0a 74 6f 20  milliseconds.to 
1a60: 77 61 69 74 20 66 6f 72 20 74 68 65 20 6c 6f 63  wait for the loc
1a70: 6b 20 74 6f 20 63 6c 65 61 72 2e 20 20 53 6f 20  k to clear.  So 
1a80: 69 6e 20 74 68 65 20 65 78 61 6d 70 6c 65 20 61  in the example a
1a90: 62 6f 76 65 2c 20 74 68 65 20 6d 61 78 69 6d 75  bove, the maximu
1aa0: 6d 20 64 65 6c 61 79 0a 77 6f 75 6c 64 20 62 65  m delay.would be
1ab0: 20 32 20 73 65 63 6f 6e 64 73 2e 3c 2f 70 3e 0a   2 seconds.</p>.
1ac0: 0a 3c 68 32 3e 54 68 65 20 22 62 75 73 79 22 20  .<h2>The "busy" 
1ad0: 6d 65 74 68 6f 64 3c 2f 68 32 3e 0a 0a 3c 70 3e  method</h2>..<p>
1ae0: 54 68 65 20 22 62 75 73 79 22 20 6d 65 74 68 6f  The "busy" metho
1af0: 64 2c 20 6c 69 6b 65 20 22 74 69 6d 65 6f 75 74  d, like "timeout
1b00: 22 2c 20 6f 6e 6c 79 20 63 6f 6d 65 73 20 69 6e  ", only comes in
1b10: 74 6f 20 70 6c 61 79 20 77 68 65 6e 20 74 68 65  to play when the
1b20: 0a 64 61 74 61 62 61 73 65 20 69 73 20 6c 6f 63  .database is loc
1b30: 6b 65 64 2e 20 20 42 75 74 20 74 68 65 20 22 62  ked.  But the "b
1b40: 75 73 79 22 20 6d 65 74 68 6f 64 20 67 69 76 65  usy" method give
1b50: 73 20 74 68 65 20 70 72 6f 67 72 61 6d 6d 65 72  s the programmer
1b60: 20 6d 75 63 68 20 6d 6f 72 65 0a 63 6f 6e 74 72   much more.contr
1b70: 6f 6c 20 6f 76 65 72 20 77 68 61 74 20 61 63 74  ol over what act
1b80: 69 6f 6e 20 74 6f 20 74 61 6b 65 2e 20 20 54 68  ion to take.  Th
1b90: 65 20 22 62 75 73 79 22 20 6d 65 74 68 6f 64 20  e "busy" method 
1ba0: 73 70 65 63 69 66 69 65 73 20 61 20 63 61 6c 6c  specifies a call
1bb0: 62 61 63 6b 0a 54 63 6c 20 70 72 6f 63 65 64 75  back.Tcl procedu
1bc0: 72 65 20 74 68 61 74 20 69 73 20 69 6e 76 6f 6b  re that is invok
1bd0: 65 64 20 77 68 65 6e 65 76 65 72 20 53 51 4c 69  ed whenever SQLi
1be0: 74 65 20 74 72 69 65 73 20 74 6f 20 6f 70 65 6e  te tries to open
1bf0: 20 61 20 6c 6f 63 6b 65 64 0a 64 61 74 61 62 61   a locked.databa
1c00: 73 65 2e 20 20 54 68 69 73 20 63 61 6c 6c 62 61  se.  This callba
1c10: 63 6b 20 63 61 6e 20 64 6f 20 77 68 61 74 65 76  ck can do whatev
1c20: 65 72 20 69 73 20 64 65 73 69 72 65 64 2e 20 20  er is desired.  
1c30: 50 72 65 73 75 6d 61 62 6c 79 2c 20 74 68 65 0a  Presumably, the.
1c40: 63 61 6c 6c 62 61 63 6b 20 77 69 6c 6c 20 64 6f  callback will do
1c50: 20 73 6f 6d 65 20 6f 74 68 65 72 20 75 73 65 66   some other usef
1c60: 75 6c 20 77 6f 72 6b 20 66 6f 72 20 61 20 73 68  ul work for a sh
1c70: 6f 72 74 20 77 68 69 6c 65 20 74 68 65 6e 20 72  ort while then r
1c80: 65 74 75 72 6e 0a 73 6f 20 74 68 61 74 20 74 68  eturn.so that th
1c90: 65 20 6c 6f 63 6b 20 63 61 6e 20 62 65 20 74 72  e lock can be tr
1ca0: 69 65 64 20 61 67 61 69 6e 2e 20 20 54 68 65 20  ied again.  The 
1cb0: 63 61 6c 6c 62 61 63 6b 20 70 72 6f 63 65 64 75  callback procedu
1cc0: 72 65 20 73 68 6f 75 6c 64 0a 72 65 74 75 72 6e  re should.return
1cd0: 20 22 30 22 20 69 66 20 69 74 20 77 61 6e 74 73   "0" if it wants
1ce0: 20 53 51 4c 69 74 65 20 74 6f 20 74 72 79 20 61   SQLite to try a
1cf0: 67 61 69 6e 20 74 6f 20 6f 70 65 6e 20 74 68 65  gain to open the
1d00: 20 64 61 74 61 62 61 73 65 20 61 6e 64 0a 73 68   database and.sh
1d10: 6f 75 6c 64 20 72 65 74 75 72 6e 20 22 31 22 20  ould return "1" 
1d20: 69 66 20 69 74 20 77 61 6e 74 73 20 53 51 4c 69  if it wants SQLi
1d30: 74 65 20 74 6f 20 61 62 61 6e 64 6f 6e 20 74 68  te to abandon th
1d40: 65 20 63 75 72 72 65 6e 74 20 6f 70 65 72 61 74  e current operat
1d50: 69 6f 6e 2e 0a 0a 3c 68 32 3e 54 68 65 20 22 6c  ion...<h2>The "l
1d60: 61 73 74 5f 69 6e 73 65 72 74 5f 72 6f 77 69 64  ast_insert_rowid
1d70: 22 20 6d 65 74 68 6f 64 3c 2f 68 32 3e 0a 0a 3c  " method</h2>..<
1d80: 70 3e 54 68 65 20 22 6c 61 73 74 5f 69 6e 73 65  p>The "last_inse
1d90: 72 74 5f 72 6f 77 69 64 22 20 6d 65 74 68 6f 64  rt_rowid" method
1da0: 20 72 65 74 75 72 6e 73 20 61 6e 20 69 6e 74 65   returns an inte
1db0: 67 65 72 20 77 68 69 63 68 20 69 73 20 74 68 65  ger which is the
1dc0: 20 52 4f 57 49 44 0a 6f 66 20 74 68 65 20 6d 6f   ROWID.of the mo
1dd0: 73 74 20 72 65 63 65 6e 74 6c 79 20 69 6e 73 65  st recently inse
1de0: 72 74 65 64 20 64 61 74 61 62 61 73 65 20 72 6f  rted database ro
1df0: 77 2e 3c 2f 70 3e 0a 0a 7d 0a 0a 70 75 74 73 20  w.</p>..}..puts 
1e00: 7b 0a 3c 70 3e 3c 68 72 20 2f 3e 3c 2f 70 3e 0a  {.<p><hr /></p>.
1e10: 3c 70 3e 3c 61 20 68 72 65 66 3d 22 69 6e 64 65  <p><a href="inde
1e20: 78 2e 68 74 6d 6c 22 3e 3c 69 6d 67 20 73 72 63  x.html"><img src
1e30: 3d 22 2f 67 6f 62 61 63 6b 2e 6a 70 67 22 20 62  ="/goback.jpg" b
1e40: 6f 72 64 65 72 3d 30 20 2f 3e 0a 42 61 63 6b 20  order=0 />.Back 
1e50: 74 6f 20 74 68 65 20 53 51 4c 69 74 65 20 48 6f  to the SQLite Ho
1e60: 6d 65 20 50 61 67 65 3c 2f 61 3e 0a 3c 2f 70 3e  me Page</a>.</p>
1e70: 0a 0a 3c 2f 62 6f 64 79 3e 3c 2f 68 74 6d 6c 3e  ..</body></html>
1e80: 7d 0a                                            }.