System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 51e381a1c7c0431bc569dd4d7ada0de77bf8d16b:


0000: 3c 21 44 4f 43 54 59 50 45 20 48 54 4d 4c 20 50  <!DOCTYPE HTML P
0010: 55 42 4c 49 43 20 22 2d 2f 2f 57 33 43 2f 2f 44  UBLIC "-//W3C//D
0020: 54 44 20 48 54 4d 4c 20 34 2e 30 31 20 54 72 61  TD HTML 4.01 Tra
0030: 6e 73 69 74 69 6f 6e 61 6c 2f 2f 45 4e 22 3e 0a  nsitional//EN">.
0040: 3c 68 74 6d 6c 3e 0a 09 3c 68 65 61 64 3e 0a 09  <html>..<head>..
0050: 09 3c 74 69 74 6c 65 3e 3c 2f 74 69 74 6c 65 3e  .<title></title>
0060: 0a 09 3c 2f 68 65 61 64 3e 0a 09 3c 62 6f 64 79  ..</head>..<body
0070: 3e 0a 20 20 20 20 41 44 4f 2e 4e 45 54 20 32 2e  >.    ADO.NET 2.
0080: 30 20 53 51 4c 69 74 65 20 44 61 74 61 20 50 72  0 SQLite Data Pr
0090: 6f 76 69 64 65 72 3c 62 72 20 2f 3e 0a 20 20 20  ovider<br />.   
00a0: 20 56 65 72 73 69 6f 6e 20 31 2e 30 2e 36 20 2d   Version 1.0.6 -
00b0: 20 46 65 62 20 32 38 2c 20 32 30 30 35 3c 62 72   Feb 28, 2005<br
00c0: 20 2f 3e 0a 20 20 20 20 57 72 69 74 74 65 6e 20   />.    Written 
00d0: 62 79 20 52 6f 62 65 72 74 20 53 69 6d 70 73 6f  by Robert Simpso
00e0: 6e 20 28 3c 61 20 68 72 65 66 3d 22 6d 61 69 6c  n (<a href="mail
00f0: 74 6f 3a 72 6f 62 65 72 74 40 62 6c 61 63 6b 63  to:robert@blackc
0100: 61 73 74 6c 65 73 6f 66 74 2e 63 6f 6d 22 3e 72  astlesoft.com">r
0110: 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73 74 6c  obert@blackcastl
0120: 65 73 6f 66 74 2e 63 6f 6d 3c 2f 61 3e 29 3c 62  esoft.com</a>)<b
0130: 72 20 2f 3e 0a 20 20 20 20 52 65 6c 65 61 73 65  r />.    Release
0140: 64 20 74 6f 20 74 68 65 20 70 75 62 6c 69 63 20  d to the public 
0150: 64 6f 6d 61 69 6e 2c 20 75 73 65 20 61 74 20 79  domain, use at y
0160: 6f 75 72 20 6f 77 6e 20 72 69 73 6b 21 3c 62 72  our own risk!<br
0170: 20 2f 3e 0a 20 20 20 20 3c 62 72 20 2f 3e 0a 20   />.    <br />. 
0180: 20 20 20 54 68 69 73 20 70 72 6f 76 69 64 65 72     This provider
0190: 20 77 61 73 20 77 72 69 74 74 65 6e 20 61 6e 64   was written and
01a0: 20 76 65 72 69 66 69 65 64 20 75 73 69 6e 67 20   verified using 
01b0: 74 68 65 20 56 69 73 75 61 6c 20 53 74 75 64 69  the Visual Studi
01c0: 6f 20 32 30 30 35 20 4e 6f 76 65 6d 62 65 72 20  o 2005 November 
01d0: 61 6e 64 0a 20 20 20 20 44 65 63 65 6d 62 65 72  and.    December
01e0: 20 43 54 50 27 73 2e 3c 62 72 20 2f 3e 0a 20 20   CTP's.<br />.  
01f0: 20 20 3c 62 72 20 2f 3e 0a 20 20 20 20 54 68 65    <br />.    The
0200: 20 6c 61 74 65 73 74 20 76 65 72 73 69 6f 6e 20   latest version 
0210: 63 61 6e 20 62 65 20 64 6f 77 6e 6c 6f 61 64 65  can be downloade
0220: 64 20 3c 61 20 68 72 65 66 3d 22 68 74 74 70 3a  d <a href="http:
0230: 2f 2f 77 77 77 2e 62 6c 61 63 6b 63 61 73 74 6c  //www.blackcastl
0240: 65 73 6f 66 74 2e 63 6f 6d 2f 66 69 6c 65 73 2f  esoft.com/files/
0250: 73 79 73 74 65 6d 2e 64 61 74 61 2e 73 71 6c 69  system.data.sqli
0260: 74 65 2e 7a 69 70 22 3e 68 65 72 65 3c 2f 61 3e  te.zip">here</a>
0270: 0a 20 20 20 20 3c 62 72 20 2f 3e 0a 20 20 20 20  .    <br />.    
0280: 3c 62 72 20 2f 3e 0a 0a 20 20 20 20 3c 62 3e 46  <br />..    <b>F
0290: 65 61 74 75 72 65 73 3a 3c 2f 62 3e 3c 62 72 20  eatures:</b><br 
02a0: 2f 3e 0a 20 20 20 20 3c 75 6c 3e 0a 20 20 20 20  />.    <ul>.    
02b0: 20 20 3c 6c 69 3e 44 62 50 72 6f 76 69 64 65 72    <li>DbProvider
02c0: 46 61 63 74 6f 72 79 20 73 75 70 70 6f 72 74 2c  Factory support,
02d0: 20 6a 75 73 74 20 61 64 64 20 74 68 65 20 58 4d   just add the XM
02e0: 4c 20 62 65 6c 6f 77 20 61 74 20 74 68 65 20 6d  L below at the m
02f0: 61 63 68 69 6e 65 2e 63 6f 6e 66 69 67 20 61 6e  achine.config an
0300: 64 2f 6f 72 20 61 70 70 2e 63 6f 6e 66 69 67 20  d/or app.config 
0310: 6c 65 76 65 6c 2e 20 3c 2f 6c 69 3e 0a 20 20 20  level. </li>.   
0320: 20 20 20 3c 6c 69 3e 46 75 6c 6c 20 73 75 70 70     <li>Full supp
0330: 6f 72 74 20 66 6f 72 20 41 54 54 41 43 48 27 65  ort for ATTACH'e
0340: 64 20 64 61 74 61 62 61 73 65 73 2e 26 6e 62 73  d databases.&nbs
0350: 70 3b 20 45 78 70 6f 73 65 64 20 61 73 20 3c 69  p; Exposed as <i
0360: 3e 43 61 74 61 6c 6f 67 73 3c 2f 69 3e 20 69 6e  >Catalogs</i> in
0370: 20 74 68 65 0a 20 20 20 20 20 20 20 20 73 63 68   the.        sch
0380: 65 6d 61 2e 26 6e 62 73 70 3b 20 57 68 65 6e 20  ema.&nbsp; When 
0390: 63 6c 6f 6e 69 6e 67 20 61 20 63 6f 6e 6e 65 63  cloning a connec
03a0: 74 69 6f 6e 2c 20 61 6c 6c 20 61 74 74 61 63 68  tion, all attach
03b0: 65 64 20 64 61 74 61 62 61 73 65 73 20 61 72 65  ed databases are
03c0: 20 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79 0a 20   automatically. 
03d0: 20 20 20 20 20 20 20 72 65 2d 61 74 74 61 63 68         re-attach
03e0: 65 64 20 74 6f 20 74 68 65 20 6e 65 77 20 63 6f  ed to the new co
03f0: 6e 6e 65 63 74 69 6f 6e 2e 3c 2f 6c 69 3e 0a 20  nnection.</li>. 
0400: 20 20 20 20 20 3c 6c 69 3e 44 62 43 6f 6e 6e 65       <li>DbConne
0410: 63 74 69 6f 6e 2e 47 65 74 53 63 68 65 6d 61 28  ction.GetSchema(
0420: 2e 2e 2e 29 20 73 75 70 70 6f 72 74 20 69 6e 63  ...) support inc
0430: 6c 75 64 65 73 20 74 68 65 20 3c 69 3e 4d 65 74  ludes the <i>Met
0440: 61 44 61 74 61 43 6f 6c 6c 65 63 74 69 6f 6e 73  aDataCollections
0450: 3c 2f 69 3e 2c 20 3c 69 3e 0a 20 20 20 20 20 20  </i>, <i>.      
0460: 20 20 44 61 74 61 53 6f 75 72 63 65 49 6e 66 6f    DataSourceInfo
0470: 72 6d 61 74 69 6f 6e 3c 2f 69 3e 2c 20 3c 69 3e  rmation</i>, <i>
0480: 43 6f 6c 75 6d 6e 73 3c 2f 69 3e 2c 20 3c 69 3e  Columns</i>, <i>
0490: 54 61 62 6c 65 73 3c 2f 69 3e 2c 20 3c 69 3e 56  Tables</i>, <i>V
04a0: 69 65 77 73 3c 2f 69 3e 2c 20 3c 69 3e 43 61 74  iews</i>, <i>Cat
04b0: 61 6c 6f 67 73 3c 2f 69 3e 0a 20 20 20 20 20 20  alogs</i>.      
04c0: 20 20 61 6e 64 20 3c 69 3e 49 6e 64 65 78 65 73    and <i>Indexes
04d0: 3c 2f 69 3e 20 6b 65 79 77 6f 72 64 73 2e 3c 2f  </i> keywords.</
04e0: 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 45 6e  li>.      <li>En
04f0: 68 61 6e 63 65 64 20 44 62 44 61 74 61 52 65 61  hanced DbDataRea
0500: 64 65 72 2e 47 65 74 53 63 68 65 6d 61 54 61 62  der.GetSchemaTab
0510: 6c 65 28 29 20 66 75 6e 63 74 69 6f 6e 61 6c 69  le() functionali
0520: 74 79 20 72 65 74 75 72 6e 73 20 63 61 74 61 6c  ty returns catal
0530: 6f 67 2c 20 6e 61 6d 65 73 70 61 63 65 0a 20 20  og, namespace.  
0540: 20 20 20 20 20 20 61 6e 64 20 64 65 74 61 69 6c        and detail
0550: 65 64 20 73 63 68 65 6d 61 20 69 6e 66 6f 72 6d  ed schema inform
0560: 61 74 69 6f 6e 20 65 76 65 6e 20 66 6f 72 20 63  ation even for c
0570: 6f 6d 70 6c 65 78 20 71 75 65 72 69 65 73 2e 3c  omplex queries.<
0580: 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 4e  /li>.      <li>N
0590: 61 6d 65 64 20 61 6e 64 20 75 6e 6e 61 6d 65 64  amed and unnamed
05a0: 20 70 61 72 61 6d 65 74 65 72 73 2e 3c 2f 6c 69   parameters.</li
05b0: 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 46 75 6c 6c  >.      <li>Full
05c0: 20 55 54 46 2d 38 20 61 6e 64 20 55 54 46 2d 31   UTF-8 and UTF-1
05d0: 36 20 73 75 70 70 6f 72 74 2e 3c 2f 6c 69 3e 0a  6 support.</li>.
05e0: 20 20 20 20 20 20 3c 6c 69 3e 4d 75 6c 74 69 70        <li>Multip
05f0: 6c 65 20 73 69 6d 75 6c 74 61 6e 65 6f 75 73 20  le simultaneous 
0600: 44 61 74 61 52 65 61 64 65 72 73 20 28 6f 6e 65  DataReaders (one
0610: 20 44 61 74 61 52 65 61 64 65 72 20 70 65 72 20   DataReader per 
0620: 43 6f 6d 6d 61 6e 64 20 68 6f 77 65 76 65 72 29  Command however)
0630: 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69  .</li>.      <li
0640: 3e 46 75 6c 6c 20 73 75 70 70 6f 72 74 20 66 6f  >Full support fo
0650: 72 20 75 73 65 72 2d 64 65 66 69 6e 65 64 20 73  r user-defined s
0660: 63 61 6c 61 72 20 61 6e 64 20 61 67 67 72 65 67  calar and aggreg
0670: 61 74 65 20 66 75 6e 63 74 69 6f 6e 73 2c 20 65  ate functions, e
0680: 6e 63 61 70 73 75 6c 61 74 65 64 20 69 6e 74 6f  ncapsulated into
0690: 0a 20 20 20 20 20 20 20 20 61 6e 0a 20 20 20 20  .        an.    
06a0: 20 20 20 20 65 61 73 79 2d 74 6f 2d 75 73 65 20      easy-to-use 
06b0: 62 61 73 65 20 63 6c 61 73 73 20 69 6e 20 77 68  base class in wh
06c0: 69 63 68 20 6f 6e 6c 79 20 61 20 63 6f 75 70 6c  ich only a coupl
06d0: 65 20 6f 66 20 6f 76 65 72 72 69 64 65 73 20 61  e of overrides a
06e0: 72 65 20 6e 65 63 65 73 73 61 72 79 20 74 6f 20  re necessary to 
06f0: 69 6d 70 6c 65 6d 65 6e 74 0a 20 20 20 20 20 20  implement.      
0700: 20 20 6e 65 77 20 53 51 4c 20 66 75 6e 63 74 69    new SQL functi
0710: 6f 6e 73 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20  ons.</li>.      
0720: 3c 6c 69 3e 46 75 6c 6c 20 73 75 70 70 6f 72 74  <li>Full support
0730: 20 66 6f 72 20 75 73 65 72 2d 64 65 66 69 6e 65   for user-define
0740: 64 20 63 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75  d collating sequ
0750: 65 6e 63 65 73 2c 20 65 76 65 72 79 20 62 69 74  ences, every bit
0760: 20 61 73 20 73 69 6d 70 6c 65 20 74 6f 20 69 6d   as simple to im
0770: 70 6c 65 6d 65 6e 74 0a 20 20 20 20 20 20 20 20  plement.        
0780: 61 73 20 75 73 65 72 2d 64 65 66 69 6e 65 64 20  as user-defined 
0790: 66 75 6e 63 74 69 6f 6e 73 20 61 6e 64 20 75 73  functions and us
07a0: 65 73 20 74 68 65 20 73 61 6d 65 20 62 61 73 65  es the same base
07b0: 20 63 6c 61 73 73 2e 3c 2f 6c 69 3e 3c 2f 75 6c   class.</li></ul
07c0: 3e 0a 20 20 20 20 49 6e 20 6f 72 64 65 72 20 74  >.    In order t
07d0: 6f 20 75 73 65 20 74 68 65 20 53 51 4c 69 74 65  o use the SQLite
07e0: 46 61 63 74 6f 72 79 20 61 6e 64 20 68 61 76 65  Factory and have
07f0: 20 74 68 65 20 53 51 4c 69 74 65 20 64 61 74 61   the SQLite data
0800: 20 70 72 6f 76 69 64 65 72 20 65 6e 75 6d 65 72   provider enumer
0810: 61 74 65 64 20 69 6e 0a 20 20 20 20 74 68 65 20  ated in.    the 
0820: 44 62 50 72 6f 76 69 64 65 72 46 61 63 74 6f 72  DbProviderFactor
0830: 69 65 73 20 6d 65 74 68 6f 64 73 2c 20 79 6f 75  ies methods, you
0840: 20 6d 75 73 74 20 61 64 64 20 74 68 65 20 66 6f   must add the fo
0850: 6c 6c 6f 77 69 6e 67 20 73 65 67 6d 65 6e 74 20  llowing segment 
0860: 69 6e 74 6f 20 65 69 74 68 65 72 0a 20 20 20 20  into either.    
0870: 79 6f 75 72 20 61 70 70 6c 69 63 61 74 69 6f 6e  your application
0880: 27 73 20 61 70 70 2e 63 6f 6e 66 69 67 20 6f 72  's app.config or
0890: 20 74 68 65 20 73 79 73 74 65 6d 27 73 20 6d 61   the system's ma
08a0: 63 68 69 6e 65 2e 63 6f 6e 66 69 67 20 6c 6f 63  chine.config loc
08b0: 61 74 65 64 20 69 6e 20 74 68 65 20 25 53 79 73  ated in the %Sys
08c0: 74 65 6d 52 6f 6f 74 25 5c 4d 69 63 72 6f 73 6f  temRoot%\Microso
08d0: 66 74 2e 4e 65 74 5c 46 72 61 6d 65 77 6f 72 6b  ft.Net\Framework
08e0: 5c 76 32 2e 78 78 78 78 5c 43 6f 6e 66 69 67 0a  \v2.xxxx\Config.
08f0: 20 20 20 20 66 6f 6c 64 65 72 3a 3c 62 72 20 2f      folder:<br /
0900: 3e 0a 20 20 20 20 3c 62 72 20 2f 3e 0a 20 20 20  >.    <br />.   
0910: 20 3c 70 72 65 3e 0a 26 6c 74 3b 63 6f 6e 66 69   <pre>.&lt;confi
0920: 67 75 72 61 74 69 6f 6e 26 67 74 3b 0a 20 20 26  guration&gt;.  &
0930: 6c 74 3b 73 79 73 74 65 6d 2e 64 61 74 61 26 67  lt;system.data&g
0940: 74 3b 0a 20 20 20 20 26 6c 74 3b 44 62 50 72 6f  t;.    &lt;DbPro
0950: 76 69 64 65 72 46 61 63 74 6f 72 69 65 73 26 67  viderFactories&g
0960: 74 3b 0a 20 20 20 20 20 20 26 6c 74 3b 61 64 64  t;.      &lt;add
0970: 20 6e 61 6d 65 3d 22 53 51 4c 69 74 65 20 44 61   name="SQLite Da
0980: 74 61 20 50 72 6f 76 69 64 65 72 22 20 69 6e 76  ta Provider" inv
0990: 61 72 69 61 6e 74 3d 22 53 79 73 74 65 6d 2e 44  ariant="System.D
09a0: 61 74 61 2e 53 51 4c 69 74 65 22 20 73 75 70 70  ata.SQLite" supp
09b0: 6f 72 74 3d 22 33 46 22 20 64 65 73 63 72 69 70  ort="3F" descrip
09c0: 74 69 6f 6e 3d 22 2e 4e 65 74 20 46 72 61 6d 65  tion=".Net Frame
09d0: 77 6f 72 6b 20 44 61 74 61 20 50 72 6f 76 69 64  work Data Provid
09e0: 65 72 20 66 6f 72 20 53 51 4c 69 74 65 22 20 74  er for SQLite" t
09f0: 79 70 65 3d 22 53 79 73 74 65 6d 2e 44 61 74 61  ype="System.Data
0a00: 2e 53 51 4c 69 74 65 2e 53 51 4c 69 74 65 46 61  .SQLite.SQLiteFa
0a10: 63 74 6f 72 79 2c 20 53 79 73 74 65 6d 2e 44 61  ctory, System.Da
0a20: 74 61 2e 53 51 4c 69 74 65 22 20 2f 26 67 74 3b  ta.SQLite" /&gt;
0a30: 0a 20 20 20 20 26 6c 74 3b 2f 44 62 50 72 6f 76  .    &lt;/DbProv
0a40: 69 64 65 72 46 61 63 74 6f 72 69 65 73 26 67 74  iderFactories&gt
0a50: 3b 0a 20 20 26 6c 74 3b 2f 73 79 73 74 65 6d 2e  ;.  &lt;/system.
0a60: 64 61 74 61 26 67 74 3b 0a 26 6c 74 3b 2f 63 6f  data&gt;.&lt;/co
0a70: 6e 66 69 67 75 72 61 74 69 6f 6e 26 67 74 3b 0a  nfiguration&gt;.
0a80: 3c 2f 70 72 65 3e 0a 20 20 20 20 3c 62 72 20 2f  </pre>.    <br /
0a90: 3e 0a 20 20 20 20 3c 62 3e 44 65 76 65 6c 6f 70  >.    <b>Develop
0aa0: 6d 65 6e 74 20 4e 6f 74 65 73 20 52 65 67 61 72  ment Notes Regar
0ab0: 64 69 6e 67 20 74 68 65 20 53 51 4c 69 74 65 20  ding the SQLite 
0ac0: 33 20 53 6f 75 72 63 65 20 43 6f 64 65 3c 62 72  3 Source Code<br
0ad0: 20 2f 3e 0a 20 20 20 20 3c 2f 62 3e 2a 2a 2a 20   />.    </b>*** 
0ae0: 41 74 20 74 68 69 73 20 74 69 6d 65 2c 20 74 68  At this time, th
0af0: 65 20 6e 65 63 65 73 73 61 72 79 20 63 68 61 6e  e necessary chan
0b00: 67 65 73 20 74 6f 20 74 68 65 20 44 4c 4c 20 74  ges to the DLL t
0b10: 6f 20 73 75 70 70 6f 72 74 20 57 69 6e 64 6f 77  o support Window
0b20: 73 20 43 45 20 68 61 76 65 0a 20 20 20 20 6e 6f  s CE have.    no
0b30: 74 20 62 65 65 6e 20 63 6f 6d 70 6c 65 74 65 64  t been completed
0b40: 2e 26 6e 62 73 70 3b 20 41 6c 6c 20 66 75 6e 63  .&nbsp; All func
0b50: 74 69 6f 6e 20 63 61 6c 6c 73 20 74 68 61 74 20  tion calls that 
0b60: 72 65 74 75 72 6e 20 6f 72 20 70 61 73 73 20 61  return or pass a
0b70: 20 36 34 2d 62 69 74 20 76 61 6c 75 65 0a 20 20   64-bit value.  
0b80: 20 20 68 61 76 65 20 62 65 65 6e 20 77 72 61 70    have been wrap
0b90: 70 65 64 2c 20 62 75 74 20 74 68 65 20 6e 65 63  ped, but the nec
0ba0: 65 73 73 61 72 79 20 4f 53 20 63 68 61 6e 67 65  essary OS change
0bb0: 73 20 68 61 76 65 20 6e 6f 74 20 62 65 65 6e 20  s have not been 
0bc0: 66 69 6e 69 73 68 65 64 2e 3c 62 72 20 2f 3e 0a  finished.<br />.
0bd0: 20 20 20 20 3c 62 72 20 2f 3e 0a 20 20 20 20 20      <br />.     
0be0: 20 3c 70 3e 3c 2f 70 3e 0a 20 20 20 20 3c 70 3e   <p></p>.    <p>
0bf0: 0a 20 20 20 20 20 20 53 74 65 70 73 20 66 6f 72  .      Steps for
0c00: 20 6d 65 72 67 69 6e 67 20 74 68 65 20 73 71 6c   merging the sql
0c10: 69 74 65 33 20 63 6f 72 65 20 63 6f 64 65 62 61  ite3 core codeba
0c20: 73 65 3a 3c 2f 70 3e 0a 20 20 20 20 3c 6f 6c 3e  se:</p>.    <ol>
0c30: 0a 20 20 20 20 20 20 3c 6c 69 3e 44 6f 77 6e 6c  .      <li>Downl
0c40: 6f 61 64 20 74 68 65 20 6c 61 74 65 73 74 20 73  oad the latest s
0c50: 71 6c 69 74 65 33 20 73 6f 75 72 63 65 20 66 72  qlite3 source fr
0c60: 6f 6d 20 3c 61 20 68 72 65 66 3d 22 68 74 74 70  om <a href="http
0c70: 3a 2f 2f 77 77 77 2e 73 71 6c 69 74 65 2e 6f 72  ://www.sqlite.or
0c80: 67 2f 64 6f 77 6e 6c 6f 61 64 2e 68 74 6d 6c 22  g/download.html"
0c90: 3e 0a 20 20 20 20 20 20 20 20 68 74 74 70 3a 2f  >.        http:/
0ca0: 2f 77 77 77 2e 73 71 6c 69 74 65 2e 6f 72 67 2f  /www.sqlite.org/
0cb0: 64 6f 77 6e 6c 6f 61 64 2e 68 74 6d 6c 3c 2f 61  download.html</a
0cc0: 3e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69  ></li>.      <li
0cd0: 3e 45 78 74 72 61 63 74 20 74 68 65 20 73 6f 75  >Extract the sou
0ce0: 72 63 65 20 63 6f 64 65 20 74 6f 20 74 68 65 20  rce code to the 
0cf0: 3c 62 3e 53 51 4c 69 74 65 2e 49 6e 74 65 72 6f  <b>SQLite.Intero
0d00: 70 5c 73 72 63 3c 2f 62 3e 20 64 69 72 65 63 74  p\src</b> direct
0d10: 6f 72 79 20 6f 66 20 74 68 69 73 20 70 72 6f 6a  ory of this proj
0d20: 65 63 74 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c  ect</li>.      <
0d30: 6c 69 3e 4f 70 65 6e 20 74 68 65 20 3c 62 3e 73  li>Open the <b>s
0d40: 72 63 5c 73 65 6c 65 63 74 2e 63 3c 2f 62 3e 20  rc\select.c</b> 
0d50: 66 69 6c 65 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20  file.</li>.     
0d60: 20 3c 6c 69 3e 41 64 64 20 3c 62 3e 23 69 6e 63   <li>Add <b>#inc
0d70: 6c 75 64 65 20 22 2e 2e 2f 69 6e 74 65 72 6f 70  lude "../interop
0d80: 2e 68 22 20 3c 2f 62 3e 74 6f 20 74 68 65 20 74  .h" </b>to the t
0d90: 6f 70 20 6f 66 20 74 68 65 20 66 69 6c 65 20 77  op of the file w
0da0: 68 65 72 65 20 74 68 65 20 6f 74 68 65 72 20 69  here the other i
0db0: 6e 63 6c 75 64 65 27 73 0a 20 20 20 20 20 20 20  nclude's.       
0dc0: 20 61 72 65 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20   are.</li>.     
0dd0: 20 3c 6c 69 3e 53 63 72 6f 6c 6c 20 64 6f 77 6e   <li>Scroll down
0de0: 20 74 68 65 20 3c 62 3e 73 65 6c 65 63 74 2e 63   the <b>select.c
0df0: 3c 2f 62 3e 20 66 69 6c 65 20 74 6f 20 61 72 6f  </b> file to aro
0e00: 75 6e 64 20 6c 69 6e 65 20 3c 62 3e 37 34 38 3c  und line <b>748<
0e10: 2f 62 3e 2e 26 6e 62 73 70 3b 20 43 68 61 6e 67  /b>.&nbsp; Chang
0e20: 65 20 74 68 65 20 6e 61 6d 65 20 6f 66 20 74 68  e the name of th
0e30: 65 20 66 75 6e 63 74 69 6f 6e 20 3c 62 3e 73 74  e function <b>st
0e40: 61 74 69 63 20 76 6f 69 64 20 67 65 6e 65 72 61  atic void genera
0e50: 74 65 43 6f 6c 75 6d 6e 4e 61 6d 65 73 20 3c 2f  teColumnNames </
0e60: 62 3e 74 6f 0a 20 20 20 20 3c 62 3e 73 74 61 74  b>to.    <b>stat
0e70: 69 63 20 76 6f 69 64 20 5f 67 65 6e 65 72 61 74  ic void _generat
0e80: 65 43 6f 6c 75 6d 6e 4e 61 6d 65 73 3c 2f 62 3e  eColumnNames</b>
0e90: 20 28 3c 69 3e 6e 6f 74 65 20 74 68 65 20 75 6e   (<i>note the un
0ea0: 64 65 72 73 63 6f 72 65 20 69 6e 20 66 72 6f 6e  derscore in fron
0eb0: 74 20 6f 66 20 74 68 65 20 6e 61 6d 65 3c 2f 69  t of the name</i
0ec0: 3e 29 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c  >).</li>.      <
0ed0: 6c 69 3e 43 6f 6d 70 69 6c 65 20 69 74 2e 3c 2f  li>Compile it.</
0ee0: 6c 69 3e 0a 20 20 20 20 3c 2f 6f 6c 3e 0a 20 20  li>.    </ol>.  
0ef0: 20 20 20 20 3c 62 3e 56 65 72 73 69 6f 6e 20 48      <b>Version H
0f00: 69 73 74 6f 72 79 3c 62 72 20 2f 3e 0a 20 20 20  istory<br />.   
0f10: 20 20 20 20 20 31 2e 30 36 20 2d 20 46 65 62 20       1.06 - Feb 
0f20: 32 38 2c 20 32 30 30 35 3c 62 72 20 2f 3e 0a 20  28, 2005<br />. 
0f30: 20 20 20 20 20 3c 2f 62 3e 0a 20 20 20 20 3c 75       </b>.    <u
0f40: 6c 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 53 70 65  l>.      <li>Spe
0f50: 65 64 2d 75 70 73 20 74 6f 20 53 51 4c 69 74 65  ed-ups to SQLite
0f60: 44 61 74 61 52 65 61 64 65 72 2e 26 6e 62 73 70  DataReader.&nbsp
0f70: 3b 20 49 74 20 77 61 73 20 69 6e 74 65 72 6f 70  ; It was interop
0f80: 27 69 6e 67 20 65 76 65 72 79 20 74 69 6d 65 20  'ing every time 
0f90: 69 74 20 74 72 69 65 64 20 74 6f 0a 20 20 20 20  it tried to.    
0fa0: 20 20 20 20 66 65 74 63 68 20 61 20 66 69 65 6c      fetch a fiel
0fb0: 64 20 64 75 65 20 74 6f 20 61 20 6c 6f 67 69 63  d due to a logic
0fc0: 20 65 72 72 6f 72 2e 3c 2f 6c 69 3e 0a 20 20 20   error.</li>.   
0fd0: 20 20 20 3c 6c 69 3e 43 68 61 6e 67 65 64 2f 41     <li>Changed/A
0fe0: 64 64 65 64 20 73 6f 6d 65 20 63 6f 64 65 20 74  dded some code t
0ff0: 6f 20 53 51 4c 69 74 65 43 6f 6e 76 65 72 74 27  o SQLiteConvert'
1000: 73 20 69 6e 74 65 72 6e 61 6c 20 44 62 54 79 70  s internal DbTyp
1010: 65 2c 20 54 79 70 65 20 61 6e 64 20 54 79 70 65  e, Type and Type
1020: 41 66 66 69 6e 69 74 79 0a 20 20 20 20 20 20 20  Affinity.       
1030: 20 66 75 6e 63 74 69 6f 6e 73 2e 3c 2f 6c 69 3e   functions.</li>
1040: 0a 20 20 20 20 20 20 3c 6c 69 3e 46 69 78 65 64  .      <li>Fixed
1050: 20 74 68 65 20 53 51 4c 69 74 65 44 61 74 61 52   the SQLiteDataR
1060: 65 61 64 65 72 20 74 6f 20 6f 62 65 79 20 74 68  eader to obey th
1070: 65 20 66 6c 61 67 73 20 73 65 74 20 69 6e 20 74  e flags set in t
1080: 68 65 20 6f 70 74 69 6f 6e 61 6c 20 43 6f 6d 6d  he optional Comm
1090: 61 6e 64 42 65 68 61 76 69 6f 72 0a 20 20 20 20  andBehavior.    
10a0: 20 20 20 20 66 6c 61 67 20 66 72 6f 6d 20 53 51      flag from SQ
10b0: 4c 69 74 65 43 6f 6d 6d 61 6e 64 2e 45 78 65 63  LiteCommand.Exec
10c0: 75 74 65 52 65 61 64 65 72 28 29 2e 3c 2f 6c 69  uteReader().</li
10d0: 3e 0a 09 09 3c 6c 69 3e 43 68 61 6e 67 65 64 20  >...<li>Changed 
10e0: 74 68 65 20 64 65 66 61 75 6c 74 20 70 61 67 65  the default page
10f0: 20 73 69 7a 65 20 74 6f 20 31 30 32 34 20 74 6f   size to 1024 to
1100: 20 72 65 66 6c 65 63 74 20 74 68 65 20 64 65 66   reflect the def
1110: 61 75 6c 74 73 20 6f 66 20 0a 09 09 53 51 4c 69  aults of ...SQLi
1120: 74 65 2e 26 6e 62 73 70 3b 20 49 67 6e 6f 72 65  te.&nbsp; Ignore
1130: 73 20 74 68 65 20 26 71 75 6f 74 3b 50 61 67 65  s the &quot;Page
1140: 20 53 69 7a 65 26 71 75 6f 74 3b 20 63 6f 6e 6e   Size&quot; conn
1150: 65 63 74 69 6f 6e 20 73 74 72 69 6e 67 20 6f 70  ection string op
1160: 74 69 6f 6e 20 66 6f 72 20 0a 09 09 6d 65 6d 6f  tion for ...memo
1170: 72 79 20 64 61 74 61 62 61 73 65 73 2c 20 61 73  ry databases, as
1180: 20 74 65 73 74 73 20 72 65 76 65 61 6c 65 64 20   tests revealed 
1190: 74 68 61 74 20 63 68 61 6e 67 69 6e 67 20 69 74  that changing it
11a0: 20 72 65 73 75 6c 74 65 64 20 69 6e 20 6d 65 6d   resulted in mem
11b0: 6f 72 79 20 0a 09 09 63 6f 72 72 75 70 74 69 6f  ory ...corruptio
11c0: 6e 20 65 72 72 6f 72 73 2e 3c 2f 6c 69 3e 0a 20  n errors.</li>. 
11d0: 20 20 20 20 20 3c 6c 69 3e 50 65 72 66 6f 72 6d       <li>Perform
11e0: 61 6e 63 65 20 65 6e 68 61 6e 63 65 6d 65 6e 74  ance enhancement
11f0: 73 20 74 6f 20 74 68 65 20 53 51 4c 69 74 65 43  s to the SQLiteC
1200: 6f 6d 6d 61 6e 64 20 61 6e 64 20 53 51 4c 69 74  ommand and SQLit
1210: 65 53 74 61 74 65 6d 65 6e 74 20 63 6c 61 73 73  eStatement class
1220: 65 73 20 77 68 69 63 68 0a 20 20 20 20 20 20 20  es which.       
1230: 20 72 65 64 75 63 65 64 20 74 68 65 20 31 30 30   reduced the 100
1240: 2c 30 30 30 20 72 6f 77 20 69 6e 73 65 72 74 20  ,000 row insert 
1250: 65 78 65 63 75 74 69 6f 6e 20 74 69 6d 65 20 61  execution time a
1260: 73 20 77 65 6c 6c 20 61 73 20 74 68 65 20 76 61  s well as the va
1270: 72 69 6f 75 73 20 46 75 6e 63 74 69 6f 6e 20 65  rious Function e
1280: 78 65 63 75 74 69 6f 6e 0a 20 20 20 20 20 20 20  xecution.       
1290: 20 74 69 6d 65 73 20 73 69 67 6e 69 66 69 63 61   times significa
12a0: 6e 74 6c 79 2e 3c 2f 6c 69 3e 0a 20 20 20 20 3c  ntly.</li>.    <
12b0: 2f 75 6c 3e 0a 20 20 20 20 3c 62 3e 0a 20 20 20  /ul>.    <b>.   
12c0: 20 20 20 3c 62 72 20 2f 3e 0a 20 20 20 20 20 20     <br />.      
12d0: 20 20 31 2e 30 35 20 2d 20 46 65 62 20 32 35 2c    1.05 - Feb 25,
12e0: 20 32 30 30 35 3c 2f 62 3e 0a 20 20 20 20 3c 75   2005</b>.    <u
12f0: 6c 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 46 69 78  l>.      <li>Fix
1300: 65 64 20 74 68 65 20 53 51 4c 69 74 65 33 20 43  ed the SQLite3 C
1310: 23 20 63 6c 61 73 73 20 73 74 65 70 2f 72 65 73  # class step/res
1320: 65 74 20 66 75 6e 63 74 69 6f 6e 73 20 74 6f 20  et functions to 
1330: 61 63 63 6f 6d 6f 64 61 74 65 20 73 63 68 65 6d  accomodate schem
1340: 61 20 63 68 61 6e 67 65 73 0a 20 20 20 20 20 20  a changes.      
1350: 20 20 74 68 61 74 20 69 6e 76 61 6c 69 64 61 74    that invalidat
1360: 65 20 61 20 70 72 65 70 61 72 65 64 20 73 74 61  e a prepared sta
1370: 74 65 6d 65 6e 74 2e 26 6e 62 73 70 3b 20 53 74  tement.&nbsp; St
1380: 61 74 65 6d 65 6e 74 73 20 61 72 65 20 72 65 63  atements are rec
1390: 6f 6d 70 69 6c 65 64 20 74 72 61 6e 73 70 61 72  ompiled transpar
13a0: 65 6e 74 6c 79 2e 3c 2f 6c 69 3e 0a 20 20 20 20  ently.</li>.    
13b0: 20 20 3c 6c 69 3e 4d 6f 76 65 64 20 61 6c 6c 20    <li>Moved all 
13c0: 6e 61 74 69 76 65 20 44 4c 4c 20 64 65 63 6c 61  native DLL decla
13d0: 72 61 74 69 6f 6e 73 20 74 6f 20 61 6e 20 55 6e  rations to an Un
13e0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
13f0: 73 20 63 6c 61 73 73 2e 3c 2f 6c 69 3e 0a 20 20  s class.</li>.  
1400: 20 20 20 20 3c 6c 69 3e 53 70 6c 69 74 20 73 65      <li>Split se
1410: 76 65 72 61 6c 20 63 6c 61 73 73 65 73 20 69 6e  veral classes in
1420: 74 6f 20 74 68 65 69 72 20 6f 77 6e 20 6d 6f 64  to their own mod
1430: 75 6c 65 73 20 66 6f 72 20 72 65 61 64 61 62 69  ules for readabi
1440: 6c 69 74 79 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20  lity.</li>.     
1450: 20 3c 6c 69 3e 52 65 6e 61 6d 65 64 20 6d 61 6e   <li>Renamed man
1460: 79 20 69 6e 74 65 72 6e 61 6c 20 76 61 72 69 61  y internal varia
1470: 62 6c 65 73 2c 20 72 65 76 69 65 77 65 64 20 61  bles, reviewed a
1480: 63 63 65 73 73 20 74 6f 20 76 61 72 69 61 62 6c  ccess to variabl
1490: 65 73 20 6d 61 72 6b 65 64 20 61 73 20 69 6e 74  es marked as int
14a0: 65 72 6e 61 6c 0a 20 20 20 20 20 20 20 20 61 6e  ernal.        an
14b0: 64 20 61 6c 74 65 72 65 64 20 74 68 65 69 72 20  d altered their 
14c0: 70 72 6f 74 65 63 74 69 6f 6e 20 6c 65 76 65 6c  protection level
14d0: 73 20 61 63 63 6f 72 64 69 6e 67 6c 79 2e 3c 2f  s accordingly.</
14e0: 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 44 75  li>.      <li>Du
14f0: 65 20 74 6f 20 74 68 65 20 70 72 65 73 65 6e 63  e to the presenc
1500: 65 20 6f 66 20 74 68 65 20 61 6c 74 65 72 65 64  e of the altered
1510: 20 73 71 6c 69 74 65 33 20 63 6f 64 65 62 61 73   sqlite3 codebas
1520: 65 20 61 6e 64 20 73 6f 20 6d 61 6e 79 20 61 64  e and so many ad
1530: 64 65 64 20 69 6e 74 65 72 6f 70 0a 20 20 20 20  ded interop.    
1540: 20 20 20 20 66 75 6e 63 74 69 6f 6e 73 2c 20 49      functions, I
1550: 20 64 65 63 69 64 65 64 20 74 6f 20 72 65 6e 61   decided to rena
1560: 6d 65 20 74 68 65 20 73 71 6c 69 74 65 33 20 43  me the sqlite3 C
1570: 20 70 72 6f 6a 65 63 74 20 61 6e 64 20 74 68 65   project and the
1580: 20 44 4c 4c 20 74 6f 20 53 51 4c 69 74 65 2e 49   DLL to SQLite.I
1590: 6e 74 65 72 6f 70 2e 44 4c 4c 2e 26 6e 62 73 70  nterop.DLL.&nbsp
15a0: 3b 0a 20 20 20 20 20 20 20 20 54 68 69 73 20 69  ;.        This i
15b0: 73 20 74 68 65 20 73 61 6d 65 20 63 6f 72 65 20  s the same core 
15c0: 73 71 6c 69 74 65 33 20 63 6f 64 65 62 61 73 65  sqlite3 codebase
15d0: 20 62 75 74 20 64 65 73 69 67 6e 65 64 20 73 70   but designed sp
15e0: 65 63 69 66 69 63 61 6c 6c 79 20 66 6f 72 20 74  ecifically for t
15f0: 68 69 73 0a 20 20 20 20 20 20 20 20 41 44 4f 2e  his.        ADO.
1600: 4e 45 54 20 70 72 6f 76 69 64 65 72 2e 26 6e 62  NET provider.&nb
1610: 73 70 3b 20 54 68 69 73 20 65 6c 69 6d 69 6e 61  sp; This elimina
1620: 74 65 73 20 61 6e 79 20 70 6f 73 73 69 62 69 6c  tes any possibil
1630: 69 74 79 20 6f 66 20 73 6f 6d 65 6f 6e 65 20 64  ity of someone d
1640: 72 6f 70 70 69 6e 67 20 61 6e 6f 74 68 65 72 0a  ropping another.
1650: 20 20 20 20 20 20 20 20 62 75 69 6c 64 20 6f 66          build of
1660: 20 73 71 6c 69 74 65 33 2e 64 6c 6c 20 69 6e 74   sqlite3.dll int
1670: 6f 20 74 68 65 20 73 79 73 74 65 6d 20 61 6e 64  o the system and
1680: 20 72 65 6e 64 65 72 69 6e 67 20 74 68 65 20 70   rendering the p
1690: 72 6f 76 69 64 65 72 20 69 6e 6f 70 65 72 61 62  rovider inoperab
16a0: 6c 65 2e 26 6e 62 73 70 3b 0a 20 20 20 20 20 20  le.&nbsp;.      
16b0: 20 20 49 6e 20 74 68 65 20 66 75 74 75 72 65 20    In the future 
16c0: 69 66 20 74 68 65 20 66 6f 6c 6b 73 20 61 74 20  if the folks at 
16d0: 73 71 6c 69 74 65 2e 6f 72 67 20 66 69 6e 61 6c  sqlite.org final
16e0: 6c 79 20 69 6e 74 72 6f 64 75 63 65 20 61 20 6d  ly introduce a m
16f0: 65 74 68 6f 64 20 6f 66 20 72 65 74 72 69 65 76  ethod of retriev
1700: 69 6e 67 0a 20 20 20 20 20 20 20 20 63 6f 6c 75  ing.        colu
1710: 6d 6e 20 75 73 61 67 65 20 66 6f 72 20 61 6e 20  mn usage for an 
1720: 61 72 62 69 74 72 61 72 79 20 70 72 65 70 61 72  arbitrary prepar
1730: 65 64 20 73 74 61 74 65 6d 65 6e 74 2c 20 49 27  ed statement, I'
1740: 6c 6c 20 72 65 74 6f 6f 6c 20 74 68 69 73 20 6c  ll retool this l
1750: 69 62 72 61 72 79 20 74 6f 20 62 65 0a 20 20 20  ibrary to be.   
1760: 20 20 20 20 20 61 20 6c 69 67 68 74 77 65 69 67       a lightweig
1770: 68 74 20 66 75 6e 63 74 69 6f 6e 20 63 61 6c 6c  ht function call
1780: 20 77 72 61 70 70 65 72 20 61 72 6f 75 6e 64 20   wrapper around 
1790: 74 68 65 20 63 6f 72 65 20 62 69 6e 61 72 79 20  the core binary 
17a0: 64 69 73 74 72 69 62 75 74 69 6f 6e 2e 3c 2f 6c  distribution.</l
17b0: 69 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 41 64 64  i>.      <li>Add
17c0: 65 64 20 5b 53 75 70 70 72 65 73 73 55 6e 6d 61  ed [SuppressUnma
17d0: 6e 61 67 65 64 43 6f 64 65 53 65 63 75 72 69 74  nagedCodeSecurit
17e0: 79 5d 20 61 74 74 72 69 62 75 74 65 20 74 6f 20  y] attribute to 
17f0: 74 68 65 20 55 6e 73 61 66 65 4e 61 74 69 76 65  the UnsafeNative
1800: 4d 65 74 68 6f 64 73 20 63 6c 61 73 73 0a 20 20  Methods class.  
1810: 20 20 20 20 20 20 77 68 69 63 68 20 62 72 69 6e        which brin
1820: 67 73 20 56 53 32 30 30 35 20 4e 6f 76 65 6d 62  gs VS2005 Novemb
1830: 65 72 20 43 54 50 20 65 78 65 63 75 74 69 6f 6e  er CTP execution
1840: 20 73 70 65 65 64 73 20 69 6e 6c 69 6e 65 20 77   speeds inline w
1850: 69 74 68 20 74 68 65 20 44 65 63 65 6d 62 65 72  ith the December
1860: 20 43 54 50 2e 3c 2f 6c 69 3e 0a 09 09 3c 6c 69   CTP.</li>...<li
1870: 3e 41 64 64 65 64 20 61 20 3c 62 3e 62 69 6e 3c  >Added a <b>bin<
1880: 2f 62 3e 20 64 69 72 65 63 74 6f 72 79 20 74 6f  /b> directory to
1890: 20 74 68 65 20 70 72 6f 6a 65 63 74 20 72 6f 6f   the project roo
18a0: 74 20 77 68 65 72 65 20 70 72 65 2d 63 6f 6d 70  t where pre-comp
18b0: 69 6c 65 64 20 0a 09 09 62 69 6e 61 72 69 65 73  iled ...binaries
18c0: 20 63 61 6e 20 62 65 20 66 6f 75 6e 64 2e 3c 2f   can be found.</
18d0: 6c 69 3e 0a 09 09 3c 6c 69 3e 41 64 64 65 64 20  li>...<li>Added 
18e0: 61 20 3c 62 3e 64 6f 63 3c 2f 62 3e 20 64 69 72  a <b>doc</b> dir
18f0: 65 63 74 6f 72 79 20 77 68 65 72 65 20 70 72 65  ectory where pre
1900: 6c 69 6d 69 6e 61 72 79 20 64 6f 63 75 6d 65 6e  liminary documen
1910: 74 61 74 69 6f 6e 20 6f 6e 20 74 68 65 20 0a 09  tation on the ..
1920: 09 63 6c 61 73 73 20 6c 69 62 72 61 72 79 20 63  .class library c
1930: 61 6e 20 62 65 20 66 6f 75 6e 64 2e 3c 2f 6c 69  an be found.</li
1940: 3e 0a 09 09 3c 6c 69 3e 44 6f 63 75 6d 65 6e 74  >...<li>Document
1950: 65 64 20 61 20 6c 6f 74 20 6d 6f 72 65 20 6f 66  ed a lot more of
1960: 20 74 68 65 20 63 6c 61 73 73 65 73 20 69 6e 74   the classes int
1970: 65 72 6e 61 6c 6c 79 2e 3c 2f 6c 69 3e 0a 20 20  ernally.</li>.  
1980: 20 20 3c 2f 75 6c 3e 0a 20 20 20 20 20 20 3c 62    </ul>.      <b
1990: 3e 0a 20 20 20 20 20 20 20 20 3c 62 72 20 2f 3e  >.        <br />
19a0: 0a 20 20 20 20 20 20 20 20 31 2e 30 34 20 2d 20  .        1.04 - 
19b0: 46 65 62 20 32 34 2c 20 32 30 30 35 3c 2f 62 3e  Feb 24, 2005</b>
19c0: 0a 20 20 20 20 3c 75 6c 3e 0a 20 20 20 20 20 20  .    <ul>.      
19d0: 3c 6c 69 3e 52 65 6d 6f 76 65 64 20 74 68 65 20  <li>Removed the 
19e0: 53 51 4c 69 74 65 43 6f 6e 74 65 78 74 20 63 6c  SQLiteContext cl
19f0: 61 73 73 20 61 6e 64 20 72 65 76 61 6d 70 65 64  ass and revamped
1a00: 20 74 68 65 20 77 61 79 20 55 73 65 72 46 75 6e   the way UserFun
1a10: 63 74 69 6f 6e 73 20 77 6f 72 6b 20 74 6f 20 73  ctions work to s
1a20: 69 6d 70 6c 69 66 79 0a 20 20 20 20 20 20 20 20  implify.        
1a30: 74 68 65 20 69 6d 6c 65 6d 65 6e 74 61 74 69 6f  the imlementatio
1a40: 6e 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c  n.</li>.      <l
1a50: 69 3e 46 69 78 65 64 20 61 20 63 6f 75 6e 74 69  i>Fixed a counti
1a60: 6e 67 20 62 75 67 20 69 6e 20 74 68 65 20 54 65  ng bug in the Te
1a70: 73 74 43 61 73 65 73 20 63 6c 61 73 73 2c 20 73  stCases class, s
1a80: 70 65 63 69 66 69 63 61 6c 6c 79 20 69 6e 20 74  pecifically in t
1a90: 68 65 20 66 75 6e 63 74 69 6f 6e 20 74 65 73 74  he function test
1aa0: 73 0a 20 20 20 20 20 20 20 20 77 68 65 72 65 20  s.        where 
1ab0: 49 20 77 61 73 6e 27 74 20 72 65 73 65 74 74 69  I wasn't resetti
1ac0: 6e 67 20 74 68 65 20 63 6f 75 6e 74 65 72 20 61  ng the counter a
1ad0: 6e 64 20 69 74 20 77 61 73 20 63 6f 6e 73 65 71  nd it was conseq
1ae0: 75 65 6e 74 6c 79 20 72 65 70 6f 72 74 69 6e 67  uently reporting
1af0: 20 69 6e 74 72 69 6e 73 69 63 0a 20 20 20 20 20   intrinsic.     
1b00: 20 20 20 61 6e 64 20 72 61 77 20 73 65 6c 65 63     and raw selec
1b10: 74 20 63 61 6c 6c 73 20 61 73 20 62 65 69 6e 67  t calls as being
1b20: 20 6d 75 63 68 20 6d 75 63 68 20 66 61 73 74 65   much much faste
1b30: 72 20 74 68 61 6e 20 74 68 65 79 20 61 63 74 75  r than they actu
1b40: 61 6c 6c 79 20 77 65 72 65 2e 26 6e 62 73 70 3b  ally were.&nbsp;
1b50: 20 54 68 65 0a 20 20 20 20 20 20 20 20 6e 75 6d   The.        num
1b60: 62 65 72 73 20 61 72 65 20 6e 6f 77 20 6d 75 63  bers are now muc
1b70: 68 20 63 6c 6f 73 65 72 20 74 6f 20 77 68 61 74  h closer to what
1b80: 20 49 20 65 78 70 65 63 74 65 64 20 66 6f 72 20   I expected for 
1b90: 70 65 72 66 6f 72 6d 61 6e 63 65 2c 20 77 69 74  performance, wit
1ba0: 68 20 2e 4e 45 54 20 75 73 65 72 2d 66 75 6e 63  h .NET user-func
1bb0: 74 69 6f 6e 73 0a 20 20 20 20 20 20 20 20 73 74  tions.        st
1bc0: 69 6c 6c 20 62 65 69 6e 67 20 74 68 65 20 73 6c  ill being the sl
1bd0: 6f 77 65 73 74 2c 20 62 75 74 20 6f 6e 6c 79 20  owest, but only 
1be0: 62 79 20 61 20 73 6d 61 6c 6c 20 6d 61 72 67 69  by a small margi
1bf0: 6e 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c  n.</li>.      <l
1c00: 69 3e 53 6d 61 6c 6c 20 70 65 72 66 6f 72 6d 61  i>Small performa
1c10: 6e 63 65 20 74 77 65 61 6b 73 20 74 6f 20 53 51  nce tweaks to SQ
1c20: 4c 69 74 65 44 61 74 61 52 65 61 64 65 72 2e 3c  LiteDataReader.<
1c30: 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69 3e 41  /li>.      <li>A
1c40: 64 64 65 64 20 50 61 67 65 53 69 7a 65 20 74 6f  dded PageSize to
1c50: 20 74 68 65 20 53 51 4c 69 74 65 43 6f 6e 6e 65   the SQLiteConne
1c60: 63 74 69 6f 6e 53 74 72 69 6e 67 42 75 69 6c 64  ctionStringBuild
1c70: 65 72 20 61 6e 64 20 73 75 62 73 65 71 75 65 6e  er and subsequen
1c80: 74 6c 79 20 74 6f 20 74 68 65 20 53 51 4c 69 74  tly to the SQLit
1c90: 65 43 6f 6e 6e 65 63 74 69 6f 6e 3c 2f 6c 69 3e  eConnection</li>
1ca0: 0a 20 20 20 20 20 20 3c 6c 69 3e 41 64 64 65 64  .      <li>Added
1cb0: 20 61 20 50 52 41 47 4d 41 20 65 6e 63 6f 64 69   a PRAGMA encodi
1cc0: 6e 67 3d 58 58 58 20 65 78 65 63 75 74 69 6f 6e  ng=XXX execution
1cd0: 20 73 74 61 74 65 6d 65 6e 74 20 74 6f 20 74 68   statement to th
1ce0: 65 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  e SQLiteConnecti
1cf0: 6f 6e 20 61 66 74 65 72 0a 20 20 20 20 20 20 20  on after.       
1d00: 20 6f 70 65 6e 69 6e 67 20 61 20 63 6f 6e 6e 65   opening a conne
1d10: 63 74 69 6f 6e 2e 3c 2f 6c 69 3e 0a 20 20 20 20  ction.</li>.    
1d20: 3c 2f 75 6c 3e 0a 20 20 20 20 20 20 3c 62 3e 0a  </ul>.      <b>.
1d30: 20 20 20 20 20 20 20 20 31 2e 30 33 20 2d 20 46          1.03 - F
1d40: 65 62 20 32 33 2c 20 32 30 30 35 3c 2f 62 3e 0a  eb 23, 2005</b>.
1d50: 20 20 20 20 3c 75 6c 3e 0a 20 20 20 20 20 20 3c      <ul>.      <
1d60: 6c 69 3e 46 69 78 65 64 20 75 70 20 53 51 4c 69  li>Fixed up SQLi
1d70: 74 65 43 6f 6d 6d 61 6e 64 42 75 69 6c 64 65 72  teCommandBuilder
1d80: 20 74 6f 20 63 6f 72 72 65 63 74 20 69 6d 70 6c   to correct impl
1d90: 65 6d 65 6e 74 61 74 69 6f 6e 20 65 72 72 6f 72  ementation error
1da0: 73 2c 20 77 68 69 63 68 20 72 65 73 75 6c 74 65  s, which resulte
1db0: 64 0a 20 20 20 20 20 20 20 20 69 6e 20 61 6e 20  d.        in an 
1dc0: 65 6e 6f 72 6d 6f 75 73 20 70 65 72 66 6f 72 6d  enormous perform
1dd0: 61 6e 63 65 20 62 6f 6f 73 74 20 69 6e 20 74 68  ance boost in th
1de0: 65 20 49 6e 73 65 72 74 4d 61 6e 79 20 74 65 73  e InsertMany tes
1df0: 74 2e 26 6e 62 73 70 3b 26 6e 62 73 70 3b 20 31  t.&nbsp;&nbsp; 1
1e00: 30 2c 30 30 30 20 72 6f 77 0a 20 20 20 20 20 20  0,000 row.      
1e10: 20 20 69 6e 73 65 72 74 20 74 68 61 74 20 65 78    insert that ex
1e20: 65 63 75 74 65 64 20 69 6e 20 31 35 30 30 6d 73  ecuted in 1500ms
1e30: 20 6e 6f 77 20 65 78 65 63 75 74 65 73 20 69 6e   now executes in
1e40: 20 35 30 30 6d 73 2e 3c 2f 6c 69 3e 0a 20 20 20   500ms.</li>.   
1e50: 20 20 20 3c 6c 69 3e 46 69 78 65 64 20 73 65 76     <li>Fixed sev
1e60: 65 72 61 6c 20 65 72 72 6f 72 73 20 69 6e 20 74  eral errors in t
1e70: 68 65 20 53 51 4c 69 74 65 33 5f 55 54 46 31 36  he SQLite3_UTF16
1e80: 20 63 6c 61 73 73 2e 26 6e 62 73 70 3b 20 54 6f   class.&nbsp; To
1e90: 53 74 72 69 6e 67 28 29 20 77 61 73 20 77 6f 72  String() was wor
1ea0: 6b 69 6e 67 0a 20 20 20 20 20 20 20 20 69 6e 63  king.        inc
1eb0: 6f 72 72 65 63 74 6c 79 20 61 6e 64 20 74 68 65  orrectly and the
1ec0: 20 4f 70 65 6e 28 29 20 6d 65 74 68 6f 64 20 66   Open() method f
1ed0: 61 69 6c 65 64 20 74 6f 20 72 65 67 69 73 74 65  ailed to registe
1ee0: 72 20 75 73 65 72 20 64 65 66 69 6e 65 64 20 66  r user defined f
1ef0: 75 6e 63 74 69 6f 6e 73 20 61 6e 64 0a 20 20 20  unctions and.   
1f00: 20 20 20 20 20 63 6f 6c 6c 61 74 69 6f 6e 73 2e       collations.
1f10: 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c 69 3e  </li>.      <li>
1f20: 46 69 78 65 64 20 61 20 62 75 67 20 69 6e 20 53  Fixed a bug in S
1f30: 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 2e 43 6c 65  QLiteCommand.Cle
1f40: 61 72 43 6f 6d 6d 61 6e 64 73 28 29 20 77 68 65  arCommands() whe
1f50: 72 65 62 79 20 6f 6e 6c 79 20 74 68 65 20 66 69  reby only the fi
1f60: 72 73 74 20 73 74 61 74 65 6d 65 6e 74 0a 20 20  rst statement.  
1f70: 20 20 20 20 20 20 77 61 73 20 62 65 69 6e 67 20        was being 
1f80: 70 72 6f 70 65 72 6c 79 20 63 6c 65 61 6e 65 64  properly cleaned
1f90: 20 75 70 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20   up.</li>.      
1fa0: 3c 6c 69 3e 46 69 78 65 64 20 61 20 62 75 67 20  <li>Fixed a bug 
1fb0: 69 6e 20 53 51 4c 69 74 65 44 61 74 61 52 65 61  in SQLiteDataRea
1fc0: 64 65 72 20 77 68 65 72 65 62 79 20 63 61 6c 6c  der whereby call
1fd0: 69 6e 67 20 4e 65 78 74 52 65 73 75 6c 74 28 29  ing NextResult()
1fe0: 20 77 6f 75 6c 64 20 6e 6f 74 20 70 72 6f 70 65   would not prope
1ff0: 72 6c 79 0a 20 20 20 20 20 20 20 20 72 65 73 65  rly.        rese
2000: 74 20 74 68 65 20 70 72 65 76 69 6f 75 73 6c 79  t the previously
2010: 2d 65 78 65 63 75 74 65 64 20 63 6f 6d 6d 61 6e  -executed comman
2020: 64 20 69 6e 20 74 68 65 20 73 65 71 75 65 6e 63  d in the sequenc
2030: 65 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20 3c 6c  e.</li>.      <l
2040: 69 3e 41 64 64 65 64 20 61 6e 20 49 6e 73 65 72  i>Added an Inser
2050: 74 4d 61 6e 79 57 69 74 68 49 64 65 6e 74 69 74  tManyWithIdentit
2060: 79 46 65 74 63 68 20 74 65 73 74 2c 20 77 68 69  yFetch test, whi
2070: 63 68 20 61 70 70 65 6e 64 73 20 61 20 73 65 6c  ch appends a sel
2080: 65 63 74 20 63 6c 61 75 73 65 20 74 6f 20 70 6f  ect clause to po
2090: 70 75 6c 61 74 65 0a 20 20 20 20 20 20 20 20 74  pulate.        t
20a0: 68 65 20 49 44 20 6f 66 20 74 68 65 20 6c 61 73  he ID of the las
20b0: 74 20 69 6e 73 65 72 74 65 64 20 72 6f 77 20 69  t inserted row i
20c0: 6e 74 6f 20 74 68 65 20 49 6e 73 65 72 74 43 6f  nto the InsertCo
20d0: 6d 6d 61 6e 64 2c 20 64 65 6d 6f 6e 73 74 72 61  mmand, demonstra
20e0: 74 69 6e 67 20 41 44 4f 2e 4e 45 54 27 73 0a 20  ting ADO.NET's. 
20f0: 20 20 20 20 20 20 20 61 62 69 6c 69 74 79 20 74         ability t
2100: 6f 20 61 75 74 6f 2d 66 65 74 63 68 20 69 64 65  o auto-fetch ide
2110: 6e 74 69 74 79 20 63 6f 6c 75 6d 6e 73 20 6f 6e  ntity columns on
2120: 20 69 6e 73 65 72 74 2e 3c 2f 6c 69 3e 0a 20 20   insert.</li>.  
2130: 20 20 3c 2f 75 6c 3e 0a 20 20 20 20 3c 70 3e 0a    </ul>.    <p>.
2140: 20 20 20 20 20 20 3c 62 3e 0a 20 20 20 20 20 20        <b>.      
2150: 20 20 31 2e 30 32 20 2d 20 46 65 62 20 32 31 2c    1.02 - Feb 21,
2160: 20 32 30 30 35 3c 2f 62 3e 3c 2f 70 3e 0a 20 20   2005</b></p>.  
2170: 20 20 3c 75 6c 3e 0a 20 20 20 20 20 20 3c 6c 69    <ul>.      <li
2180: 3e 54 77 65 61 6b 73 20 74 6f 20 74 68 65 20 78  >Tweaks to the x
2190: 78 78 5f 69 6e 74 65 72 6f 70 20 66 75 6e 63 74  xx_interop funct
21a0: 69 6f 6e 73 20 74 68 61 74 20 72 65 74 75 72 6e  ions that return
21b0: 20 63 68 61 72 20 2a 27 73 2c 20 73 6f 20 74 68   char *'s, so th
21c0: 65 79 20 61 6c 73 6f 20 72 65 74 75 72 6e 0a 20  ey also return. 
21d0: 20 20 20 20 20 20 20 74 68 65 20 6c 65 6e 67 74         the lengt
21e0: 68 2e 26 6e 62 73 70 3b 20 53 61 76 65 73 20 61  h.&nbsp; Saves a
21f0: 6e 20 69 6e 74 65 72 6f 70 20 63 61 6c 6c 20 74  n interop call t
2200: 6f 20 67 65 74 20 74 68 65 20 55 54 46 2d 38 20  o get the UTF-8 
2210: 73 74 72 69 6e 67 20 6c 65 6e 67 74 68 20 64 75  string length du
2220: 72 69 6e 67 20 63 6f 6e 76 65 72 73 69 6f 6e 0a  ring conversion.
2230: 20 20 20 20 20 20 20 20 74 6f 20 61 20 2e 4e 45          to a .NE
2240: 54 20 73 74 72 69 6e 67 2e 3c 2f 6c 69 3e 0a 20  T string.</li>. 
2250: 20 20 20 20 20 3c 6c 69 3e 52 65 77 6f 72 6b 65       <li>Reworke
2260: 64 20 74 68 65 20 77 68 6f 6c 65 20 69 6e 74 65  d the whole inte
2270: 72 6f 70 2e 63 20 74 68 69 6e 67 20 69 6e 74 6f  rop.c thing into
2280: 20 69 6e 74 65 72 6f 70 2e 68 20 61 6e 64 20 72   interop.h and r
2290: 65 64 75 63 65 64 20 74 68 65 20 63 6f 64 65 20  educed the code 
22a0: 72 65 71 75 69 72 65 64 0a 20 20 20 20 20 20 20  required.       
22b0: 20 74 6f 20 6d 65 72 67 65 20 74 68 65 20 6d 61   to merge the ma
22c0: 69 6e 20 73 71 6c 69 74 65 33 20 63 6f 64 65 62  in sqlite3 codeb
22d0: 61 73 65 2e 3c 2f 6c 69 3e 0a 20 20 20 20 20 20  ase.</li>.      
22e0: 3c 6c 69 3e 41 64 64 65 64 20 73 75 70 70 6f 72  <li>Added suppor
22f0: 74 20 66 6f 72 20 75 73 65 72 2d 64 65 66 69 6e  t for user-defin
2300: 65 64 20 63 6f 6c 6c 61 74 69 6f 6e 73 2e 3c 2f  ed collations.</
2310: 6c 69 3e 0a 20 20 20 20 3c 2f 75 6c 3e 0a 09 3c  li>.    </ul>..<
2320: 2f 62 6f 64 79 3e 0a 3c 2f 68 74 6d 6c 3e        /body>.</html>