Documentation Source Text

Hex Artifact Content
Login

Artifact ed750663d4f4978f8ec77b0fcc0ca50c47cb8c66:


0000: 3c 74 69 74 6c 65 3e 53 51 4c 69 74 65 20 49 73  <title>SQLite Is
0010: 20 53 65 72 76 65 72 6c 65 73 73 3c 2f 74 69 74   Serverless</tit
0020: 6c 65 3e 0a 0a 3c 68 32 3e 53 51 4c 69 74 65 20  le>..<h2>SQLite 
0030: 49 73 20 53 65 72 76 65 72 6c 65 73 73 3c 2f 68  Is Serverless</h
0040: 32 3e 0a 0a 3c 70 3e 0a 4d 6f 73 74 20 53 51 4c  2>..<p>.Most SQL
0050: 20 64 61 74 61 62 61 73 65 20 65 6e 67 69 6e 65   database engine
0060: 73 20 61 72 65 20 69 6d 70 6c 65 6d 65 6e 74 65  s are implemente
0070: 64 20 61 73 20 61 20 73 65 70 61 72 61 74 65 20  d as a separate 
0080: 73 65 72 76 65 72 20 70 72 6f 63 65 73 73 2e 0a  server process..
0090: 50 72 6f 67 72 61 6d 73 20 74 68 61 74 20 77 61  Programs that wa
00a0: 6e 74 20 74 6f 20 61 63 63 65 73 73 20 74 68 65  nt to access the
00b0: 20 64 61 74 61 62 61 73 65 20 63 6f 6d 6d 75 6e   database commun
00c0: 69 63 61 74 65 20 77 69 74 68 20 74 68 65 20 73  icate with the s
00d0: 65 72 76 65 72 0a 75 73 69 6e 67 20 73 6f 6d 65  erver.using some
00e0: 20 6b 69 6e 64 20 6f 66 20 69 6e 74 65 72 70 72   kind of interpr
00f0: 6f 63 65 73 73 20 63 6f 6d 6d 75 6e 63 61 74 69  ocess communcati
0100: 6f 6e 20 28 74 79 70 69 63 61 6c 6c 79 20 54 43  on (typically TC
0110: 50 2f 49 50 29 20 74 6f 20 73 65 6e 64 20 0a 72  P/IP) to send .r
0120: 65 71 75 65 73 74 73 20 74 6f 20 74 68 65 20 73  equests to the s
0130: 65 72 76 65 72 20 61 6e 64 20 74 6f 20 72 65 63  erver and to rec
0140: 65 69 76 65 20 62 61 63 6b 20 72 65 73 75 6c 74  eive back result
0150: 73 2e 20 0a 53 51 4c 69 74 65 20 64 6f 65 73 20  s. .SQLite does 
0160: 6e 6f 74 20 77 6f 72 6b 20 74 68 69 73 20 77 61  not work this wa
0170: 79 2e 20 0a 57 69 74 68 20 53 51 4c 69 74 65 2c  y. .With SQLite,
0180: 20 74 68 65 20 70 72 6f 63 65 73 73 20 74 68 61   the process tha
0190: 74 20 77 61 6e 74 73 20 74 6f 20 61 63 63 65 73  t wants to acces
01a0: 73 20 74 68 65 20 64 61 74 61 62 61 73 65 20 72  s the database r
01b0: 65 61 64 73 20 61 6e 64 20 0a 77 72 69 74 65 73  eads and .writes
01c0: 20 64 69 72 65 63 74 6c 79 20 66 72 6f 6d 20 74   directly from t
01d0: 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  he database file
01e0: 73 20 6f 6e 20 64 69 73 6b 2e 20 0a 54 68 65 72  s on disk. .Ther
01f0: 65 20 69 73 20 6e 6f 20 69 6e 74 65 72 6d 65 64  e is no intermed
0200: 69 61 72 79 20 73 65 72 76 65 72 20 70 72 6f 63  iary server proc
0210: 65 73 73 2e 0a 3c 2f 70 3e 0a 0a 3c 70 3e 0a 54  ess..</p>..<p>.T
0220: 68 65 72 65 20 61 72 65 20 61 64 76 61 6e 74 61  here are advanta
0230: 67 65 73 20 61 6e 64 20 64 69 73 61 64 76 61 6e  ges and disadvan
0240: 74 61 67 65 73 20 74 6f 20 62 65 69 6e 67 20 73  tages to being s
0250: 65 72 76 65 72 6c 65 73 73 2e 0a 54 68 65 20 6d  erverless..The m
0260: 61 69 6e 20 61 64 76 61 6e 74 61 67 65 20 69 73  ain advantage is
0270: 20 74 68 61 74 20 74 68 65 72 65 20 69 73 20 6e   that there is n
0280: 6f 20 73 65 70 61 72 61 74 65 20 73 65 72 76 65  o separate serve
0290: 72 20 70 72 6f 63 65 73 73 0a 74 6f 20 69 6e 73  r process.to ins
02a0: 74 61 6c 6c 2c 20 73 65 74 75 70 2c 20 63 6f 6e  tall, setup, con
02b0: 66 69 67 75 72 65 2c 20 69 6e 69 74 69 61 6c 69  figure, initiali
02c0: 7a 65 2c 20 6d 61 6e 61 67 65 2c 20 61 6e 64 20  ze, manage, and 
02d0: 74 72 6f 75 62 6c 65 73 68 6f 6f 74 2e 20 0a 54  troubleshoot. .T
02e0: 68 69 73 20 69 73 20 6f 6e 65 20 72 65 61 73 6f  his is one reaso
02f0: 6e 20 77 68 79 20 53 51 4c 69 74 65 20 69 73 20  n why SQLite is 
0300: 61 20 0a 22 3c 61 20 68 72 65 66 3d 22 7a 65 72  a ."<a href="zer
0310: 6f 63 6f 6e 66 2e 68 74 6d 6c 22 3e 7a 65 72 6f  oconf.html">zero
0320: 2d 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e 3c 2f  -configuration</
0330: 61 3e 22 20 64 61 74 61 62 61 73 65 20 65 6e 67  a>" database eng
0340: 69 6e 65 2e 20 0a 50 72 6f 67 72 61 6d 73 20 74  ine. .Programs t
0350: 68 61 74 20 75 73 65 20 53 51 4c 69 74 65 20 72  hat use SQLite r
0360: 65 71 75 69 72 65 20 6e 6f 20 61 64 6d 69 6e 69  equire no admini
0370: 73 74 72 61 74 69 76 65 20 73 75 70 70 6f 72 74  strative support
0380: 20 66 6f 72 20 0a 73 65 74 74 69 6e 67 20 75 70   for .setting up
0390: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 65 6e   the database en
03a0: 67 69 6e 65 20 62 65 66 6f 72 65 20 74 68 65 79  gine before they
03b0: 20 61 72 65 20 72 75 6e 2e 0a 41 6e 79 20 70 72   are run..Any pr
03c0: 6f 67 72 61 6d 20 74 68 61 74 20 69 73 20 61 62  ogram that is ab
03d0: 6c 65 20 74 6f 20 61 63 63 65 73 73 20 74 68 65  le to access the
03e0: 20 64 69 73 6b 20 69 73 20 61 62 6c 65 20 74 6f   disk is able to
03f0: 20 75 73 65 20 61 6e 20 53 51 4c 69 74 65 20 64   use an SQLite d
0400: 61 74 61 62 61 73 65 2e 0a 3c 2f 70 3e 0a 0a 3c  atabase..</p>..<
0410: 70 3e 0a 4f 6e 20 74 68 65 20 6f 74 68 65 72 20  p>.On the other 
0420: 68 61 6e 64 2c 20 61 20 64 61 74 61 62 61 73 65  hand, a database
0430: 20 65 6e 67 69 6e 65 20 74 68 61 74 20 75 73 65   engine that use
0440: 73 20 61 20 73 65 72 76 65 72 20 63 61 6e 20 0a  s a server can .
0450: 70 72 6f 76 69 64 65 20 62 65 74 74 65 72 20 70  provide better p
0460: 72 6f 74 65 63 74 69 6f 6e 20 66 72 6f 6d 20 62  rotection from b
0470: 75 67 73 20 69 6e 20 74 68 65 20 63 6c 69 65 6e  ugs in the clien
0480: 74 20 0a 61 70 70 6c 69 63 61 74 69 6f 6e 20 2d  t .application -
0490: 20 73 74 72 61 79 20 70 6f 69 6e 74 65 72 73 20   stray pointers 
04a0: 69 6e 20 61 20 63 6c 69 65 6e 74 20 63 61 6e 6e  in a client cann
04b0: 6f 74 20 63 6f 72 72 75 70 74 20 6d 65 6d 6f 72  ot corrupt memor
04c0: 79 20 0a 6f 6e 20 74 68 65 20 73 65 72 76 65 72  y .on the server
04d0: 2e 20 0a 41 6e 64 20 62 65 63 61 75 73 65 20 61  . .And because a
04e0: 20 73 65 72 76 65 72 20 69 73 20 61 20 73 69 6e   server is a sin
04f0: 67 6c 65 20 70 65 72 73 69 73 74 65 6e 74 20 70  gle persistent p
0500: 72 6f 63 65 73 73 2c 0a 69 74 20 69 73 20 61 62  rocess,.it is ab
0510: 6c 65 20 63 6f 6e 74 72 6f 6c 20 64 61 74 61 62  le control datab
0520: 61 73 65 20 61 63 63 65 73 73 20 77 69 74 68 20  ase access with 
0530: 6d 6f 72 65 20 70 72 65 63 69 73 69 6f 6e 2c 20  more precision, 
0540: 0a 61 6c 6c 6f 77 69 6e 67 20 66 6f 72 20 66 69  .allowing for fi
0550: 6e 65 72 20 67 72 61 69 6e 20 6c 6f 63 6b 69 6e  ner grain lockin
0560: 67 20 61 6e 64 20 62 65 74 74 65 72 20 63 6f 6e  g and better con
0570: 63 75 72 72 61 6e 63 79 2e 0a 3c 2f 70 3e 0a 0a  currancy..</p>..
0580: 3c 70 3e 0a 4d 6f 73 74 20 53 51 4c 20 64 61 74  <p>.Most SQL dat
0590: 61 62 61 73 65 20 65 6e 67 69 6e 65 73 20 61 72  abase engines ar
05a0: 65 20 63 6c 69 65 6e 74 2f 73 65 72 76 65 72 20  e client/server 
05b0: 62 61 73 65 64 2e 20 0a 4f 66 20 74 68 6f 73 65  based. .Of those
05c0: 20 74 68 61 74 20 61 72 65 20 73 65 72 76 65 72   that are server
05d0: 6c 65 73 73 2c 20 53 51 4c 69 74 65 20 69 73 20  less, SQLite is 
05e0: 74 68 65 20 6f 6e 6c 79 20 6f 6e 65 20 74 68 61  the only one tha
05f0: 74 20 0a 6b 6e 6f 77 6e 20 74 6f 20 74 68 69 73  t .known to this
0600: 20 61 75 74 68 6f 72 20 74 68 61 74 20 61 6c 6c   author that all
0610: 6f 77 73 20 6d 75 6c 74 69 70 6c 65 20 61 70 70  ows multiple app
0620: 6c 69 63 61 74 69 6f 6e 73 0a 74 6f 20 61 63 63  lications.to acc
0630: 65 73 73 20 74 68 65 20 73 61 6d 65 20 64 61 74  ess the same dat
0640: 61 62 61 73 65 20 61 74 20 74 68 65 20 73 61 6d  abase at the sam
0650: 65 20 74 69 6d 65 2e 20 0a 3c 2f 70 3e 0a        e time. .</p>.