System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 0cd344ea4924e4aabe9ee63cd85450c98c0f6ae7:


0000: ef bb bf 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .../************
0010: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0020: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 20 2a 20  ************. * 
0040: 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74 61  ADO.NET 2.0 Data
0050: 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53 51   Provider for SQ
0060: 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e 58  Lite Version 3.X
0070: 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79 20 52  . * Written by R
0080: 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20 28 72  obert Simpson (r
0090: 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73 74 6c  obert@blackcastl
00a0: 65 73 6f 66 74 2e 63 6f 6d 29 0a 20 2a 20 0a 20  esoft.com). * . 
00b0: 2a 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  * Released to th
00c0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00d0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00e0: 20 72 69 73 6b 21 0a 20 2a 2a 2a 2a 2a 2a 2a 2a   risk!. ********
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2f 0a 0a 6e 61 6d 65 73 70 61 63 65 20 53 79 73  /..namespace Sys
0130: 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 0a  tem.Data.SQLite.
0140: 7b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  {.  using System
0150: 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  ;.  using System
0160: 2e 44 61 74 61 3b 0a 20 20 75 73 69 6e 67 20 53  .Data;.  using S
0170: 79 73 74 65 6d 2e 44 61 74 61 2e 43 6f 6d 6d 6f  ystem.Data.Commo
0180: 6e 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65  n;.  using Syste
0190: 6d 2e 43 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47 65  m.Collections.Ge
01a0: 6e 65 72 69 63 3b 0a 0a 20 20 69 6e 74 65 72 6e  neric;..  intern
01b0: 61 6c 20 73 74 72 75 63 74 20 53 51 4c 69 74 65  al struct SQLite
01c0: 54 79 70 65 0a 20 20 7b 0a 20 20 20 20 69 6e 74  Type.  {.    int
01d0: 65 72 6e 61 6c 20 44 62 54 79 70 65 20 20 20 20  ernal DbType    
01e0: 20 20 20 20 20 54 79 70 65 3b 0a 20 20 20 20 69       Type;.    i
01f0: 6e 74 65 72 6e 61 6c 20 54 79 70 65 41 66 66 69  nternal TypeAffi
0200: 6e 69 74 79 20 41 66 66 69 6e 69 74 79 3b 0a 20  nity Affinity;. 
0210: 20 7d 0a 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61   }..  /// <summa
0220: 72 79 3e 0a 20 20 2f 2f 2f 20 53 51 4c 69 74 65  ry>.  /// SQLite
0230: 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20   implementation 
0240: 6f 66 20 44 62 44 61 74 61 52 65 61 64 65 72 2e  of DbDataReader.
0250: 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79  .  /// </summary
0260: 3e 0a 20 20 70 75 62 6c 69 63 20 73 65 61 6c 65  >.  public seale
0270: 64 20 63 6c 61 73 73 20 53 51 4c 69 74 65 44 61  d class SQLiteDa
0280: 74 61 52 65 61 64 65 72 20 3a 20 44 62 44 61 74  taReader : DbDat
0290: 61 52 65 61 64 65 72 0a 20 20 7b 0a 20 20 20 20  aReader.  {.    
02a0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20  /// <summary>.  
02b0: 20 20 2f 2f 2f 20 55 6e 64 65 72 6c 79 69 6e 67    /// Underlying
02c0: 20 63 6f 6d 6d 61 6e 64 20 74 68 69 73 20 72 65   command this re
02d0: 61 64 65 72 20 69 73 20 61 74 74 61 63 68 65 64  ader is attached
02e0: 20 74 6f 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75   to.    /// </su
02f0: 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61  mmary>.    priva
0300: 74 65 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64  te SQLiteCommand
0310: 20 20 20 5f 63 6f 6d 6d 61 6e 64 3b 0a 20 20 20     _command;.   
0320: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
0330: 20 20 20 2f 2f 2f 20 49 6e 64 65 78 20 6f 66 20     /// Index of 
0340: 74 68 65 20 63 75 72 72 65 6e 74 20 73 74 61 74  the current stat
0350: 65 6d 65 6e 74 20 69 6e 20 74 68 65 20 63 6f 6d  ement in the com
0360: 6d 61 6e 64 20 62 65 69 6e 67 20 70 72 6f 63 65  mand being proce
0370: 73 73 65 64 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ssed.    /// </s
0380: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76  ummary>.    priv
0390: 61 74 65 20 69 6e 74 20 20 20 20 20 20 20 20 20  ate int         
03a0: 20 20 20 20 5f 61 63 74 69 76 65 53 74 61 74 65      _activeState
03b0: 6d 65 6e 74 49 6e 64 65 78 3b 0a 20 20 20 20 2f  mentIndex;.    /
03c0: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20  // <summary>.   
03d0: 20 2f 2f 2f 20 43 75 72 72 65 6e 74 20 73 74 61   /// Current sta
03e0: 74 65 6d 65 6e 74 20 62 65 69 6e 67 20 52 65 61  tement being Rea
03f0: 64 28 29 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  d().    /// </su
0400: 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61  mmary>.    priva
0410: 74 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65  te SQLiteStateme
0420: 6e 74 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d  nt _activeStatem
0430: 65 6e 74 3b 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  ent;.    /// <su
0440: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 53  mmary>.    /// S
0450: 74 61 74 65 20 6f 66 20 74 68 65 20 63 75 72 72  tate of the curr
0460: 65 6e 74 20 73 74 61 74 65 6d 65 6e 74 20 62 65  ent statement be
0470: 69 6e 67 20 70 72 6f 63 65 73 73 65 64 2e 0a 20  ing processed.. 
0480: 20 20 20 2f 2f 2f 20 2d 31 20 3d 20 46 69 72 73     /// -1 = Firs
0490: 74 20 53 74 65 70 28 29 20 65 78 65 63 75 74 65  t Step() execute
04a0: 64 2c 20 73 6f 20 74 68 65 20 66 69 72 73 74 20  d, so the first 
04b0: 52 65 61 64 28 29 20 77 69 6c 6c 20 62 65 20 69  Read() will be i
04c0: 67 6e 6f 72 65 64 0a 20 20 20 20 2f 2f 2f 20 20  gnored.    ///  
04d0: 30 20 3d 20 41 63 74 69 76 65 6c 79 20 72 65 61  0 = Actively rea
04e0: 64 69 6e 67 0a 20 20 20 20 2f 2f 2f 20 20 31 20  ding.    ///  1 
04f0: 3d 20 46 69 6e 69 73 68 65 64 20 72 65 61 64 69  = Finished readi
0500: 6e 67 0a 20 20 20 20 2f 2f 2f 20 20 32 20 3d 20  ng.    ///  2 = 
0510: 4e 6f 6e 2d 72 6f 77 2d 72 65 74 75 72 6e 69 6e  Non-row-returnin
0520: 67 20 73 74 61 74 65 6d 65 6e 74 2c 20 6e 6f 20  g statement, no 
0530: 72 65 63 6f 72 64 73 0a 20 20 20 20 2f 2f 2f 20  records.    /// 
0540: 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70  </summary>.    p
0550: 72 69 76 61 74 65 20 69 6e 74 20 20 20 20 20 20  rivate int      
0560: 20 20 20 20 20 20 20 5f 72 65 61 64 69 6e 67 53         _readingS
0570: 74 61 74 65 3b 0a 20 20 20 20 2f 2f 2f 20 3c 73  tate;.    /// <s
0580: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
0590: 4e 75 6d 62 65 72 20 6f 66 20 72 65 63 6f 72 64  Number of record
05a0: 73 20 61 66 66 65 63 74 65 64 20 62 79 20 74 68  s affected by th
05b0: 65 20 69 6e 73 65 72 74 2f 75 70 64 61 74 65 20  e insert/update 
05c0: 73 74 61 74 65 6d 65 6e 74 73 20 65 78 65 63 75  statements execu
05d0: 74 65 64 20 6f 6e 20 74 68 65 20 63 6f 6d 6d 61  ted on the comma
05e0: 6e 64 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  nd.    /// </sum
05f0: 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74  mary>.    privat
0600: 65 20 69 6e 74 20 20 20 20 20 20 20 20 20 20 20  e int           
0610: 20 20 5f 72 6f 77 73 41 66 66 65 63 74 65 64 3b    _rowsAffected;
0620: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
0630: 79 3e 0a 20 20 20 20 2f 2f 2f 20 43 6f 75 6e 74  y>.    /// Count
0640: 20 6f 66 20 66 69 65 6c 64 73 20 28 63 6f 6c 75   of fields (colu
0650: 6d 6e 73 29 20 69 6e 20 74 68 65 20 72 6f 77 2d  mns) in the row-
0660: 72 65 74 75 72 6e 69 6e 67 20 73 74 61 74 65 6d  returning statem
0670: 65 6e 74 20 63 75 72 72 65 6e 74 6c 79 20 62 65  ent currently be
0680: 69 6e 67 20 70 72 6f 63 65 73 73 65 64 0a 20 20  ing processed.  
0690: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
06a0: 0a 20 20 20 20 70 72 69 76 61 74 65 20 69 6e 74  .    private int
06b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 5f 66 69               _fi
06c0: 65 6c 64 43 6f 75 6e 74 3b 0a 20 20 20 20 2f 2f  eldCount;.    //
06d0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
06e0: 2f 2f 2f 20 44 61 74 61 74 79 70 65 73 20 6f 66  /// Datatypes of
06f0: 20 61 63 74 69 76 65 20 66 69 65 6c 64 73 20 28   active fields (
0700: 63 6f 6c 75 6d 6e 73 29 20 69 6e 20 74 68 65 20  columns) in the 
0710: 63 75 72 72 65 6e 74 20 73 74 61 74 65 6d 65 6e  current statemen
0720: 74 2c 20 75 73 65 64 20 66 6f 72 20 74 79 70 65  t, used for type
0730: 2d 72 65 73 74 72 69 63 74 69 6e 67 20 64 61 74  -restricting dat
0740: 61 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  a.    /// </summ
0750: 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74 65  ary>.    private
0760: 20 53 51 4c 69 74 65 54 79 70 65 5b 5d 20 20 20   SQLiteType[]   
0770: 20 5f 66 69 65 6c 64 54 79 70 65 41 72 72 61 79   _fieldTypeArray
0780: 3b 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ;..    /// <summ
0790: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 54 68 65  ary>.    /// The
07a0: 20 62 65 68 61 76 69 6f 72 20 6f 66 20 74 68 65   behavior of the
07b0: 20 64 61 74 61 72 65 61 64 65 72 0a 20 20 20 20   datareader.    
07c0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
07d0: 20 20 20 70 72 69 76 61 74 65 20 43 6f 6d 6d 61     private Comma
07e0: 6e 64 42 65 68 61 76 69 6f 72 20 5f 63 6f 6d 6d  ndBehavior _comm
07f0: 61 6e 64 42 65 68 61 76 69 6f 72 3b 0a 0a 20 20  andBehavior;..  
0800: 20 20 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74    internal SQLit
0810: 65 44 61 74 61 52 65 61 64 65 72 28 53 51 4c 69  eDataReader(SQLi
0820: 74 65 43 6f 6d 6d 61 6e 64 20 63 6d 64 2c 20 43  teCommand cmd, C
0830: 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 20 62  ommandBehavior b
0840: 65 68 61 76 65 29 0a 20 20 20 20 7b 0a 20 20 20  ehave).    {.   
0850: 20 20 20 5f 63 6f 6d 6d 61 6e 64 20 3d 20 63 6d     _command = cm
0860: 64 3b 0a 20 20 20 20 20 20 5f 63 6f 6d 6d 61 6e  d;.      _comman
0870: 64 42 65 68 61 76 69 6f 72 20 3d 20 62 65 68 61  dBehavior = beha
0880: 76 65 3b 0a 20 20 20 20 20 20 49 6e 69 74 69 61  ve;.      Initia
0890: 6c 69 7a 65 28 29 3b 0a 20 20 20 20 7d 0a 0a 20  lize();.    }.. 
08a0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 76 6f 69 64     internal void
08b0: 20 49 6e 69 74 69 61 6c 69 7a 65 28 29 0a 20 20   Initialize().  
08c0: 20 20 7b 0a 20 20 20 20 20 20 5f 61 63 74 69 76    {.      _activ
08d0: 65 53 74 61 74 65 6d 65 6e 74 49 6e 64 65 78 20  eStatementIndex 
08e0: 3d 20 2d 31 3b 0a 20 20 20 20 20 20 5f 61 63 74  = -1;.      _act
08f0: 69 76 65 53 74 61 74 65 6d 65 6e 74 20 3d 20 6e  iveStatement = n
0900: 75 6c 6c 3b 0a 20 20 20 20 20 20 5f 72 6f 77 73  ull;.      _rows
0910: 41 66 66 65 63 74 65 64 20 3d 20 2d 31 3b 0a 20  Affected = -1;. 
0920: 20 20 20 20 20 5f 66 69 65 6c 64 43 6f 75 6e 74       _fieldCount
0930: 20 3d 20 2d 31 3b 0a 0a 20 20 20 20 20 20 4e 65   = -1;..      Ne
0940: 78 74 52 65 73 75 6c 74 28 29 3b 0a 20 20 20 20  xtResult();.    
0950: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
0960: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 43 6c 6f  ary>.    /// Clo
0970: 73 65 73 20 74 68 65 20 64 61 74 61 72 65 61 64  ses the dataread
0980: 65 72 2c 20 70 6f 74 65 6e 74 69 61 6c 6c 79 20  er, potentially 
0990: 63 6c 6f 73 69 6e 67 20 74 68 65 20 63 6f 6e 6e  closing the conn
09a0: 65 63 74 69 6f 6e 20 61 73 20 77 65 6c 6c 20 69  ection as well i
09b0: 66 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f  f CommandBehavio
09c0: 72 2e 43 6c 6f 73 65 43 6f 6e 6e 65 63 74 69 6f  r.CloseConnectio
09d0: 6e 20 77 61 73 20 73 70 65 63 69 66 69 65 64 2e  n was specified.
09e0: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
09f0: 72 79 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f  ry>.    public o
0a00: 76 65 72 72 69 64 65 20 76 6f 69 64 20 43 6c 6f  verride void Clo
0a10: 73 65 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  se().    {.     
0a20: 20 69 66 20 28 5f 63 6f 6d 6d 61 6e 64 20 21 3d   if (_command !=
0a30: 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20 7b 0a 20   null).      {. 
0a40: 20 20 20 20 20 20 20 77 68 69 6c 65 20 28 4e 65         while (Ne
0a50: 78 74 52 65 73 75 6c 74 28 29 29 20 3b 0a 20 20  xtResult()) ;.  
0a60: 20 20 20 20 20 20 5f 63 6f 6d 6d 61 6e 64 2e 43        _command.C
0a70: 6c 65 61 72 44 61 74 61 52 65 61 64 65 72 28 29  learDataReader()
0a80: 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20  ;.      }..     
0a90: 20 2f 2f 20 49 66 20 74 68 65 20 64 61 74 61 72   // If the datar
0aa0: 65 61 64 65 72 27 73 20 62 65 68 61 76 69 6f 72  eader's behavior
0ab0: 20 69 6e 63 6c 75 64 65 73 20 63 6c 6f 73 69 6e   includes closin
0ac0: 67 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  g the connection
0ad0: 2c 20 74 68 65 6e 20 64 6f 20 73 6f 20 68 65 72  , then do so her
0ae0: 65 2e 0a 20 20 20 20 20 20 69 66 20 28 28 5f 63  e..      if ((_c
0af0: 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 20 26  ommandBehavior &
0b00: 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72   CommandBehavior
0b10: 2e 43 6c 6f 73 65 43 6f 6e 6e 65 63 74 69 6f 6e  .CloseConnection
0b20: 29 20 21 3d 20 30 29 0a 20 20 20 20 20 20 20 20  ) != 0).        
0b30: 5f 63 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74  _command.Connect
0b40: 69 6f 6e 2e 43 6c 6f 73 65 28 29 3b 0a 0a 20 20  ion.Close();..  
0b50: 20 20 20 20 5f 63 6f 6d 6d 61 6e 64 20 3d 20 6e      _command = n
0b60: 75 6c 6c 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ull;.    }..    
0b70: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20  /// <summary>.  
0b80: 20 20 2f 2f 2f 20 44 69 73 70 6f 73 65 73 20 74    /// Disposes t
0b90: 68 65 20 64 61 74 61 72 65 61 64 65 72 2e 20 20  he datareader.  
0ba0: 43 61 6c 6c 73 20 43 6c 6f 73 65 28 29 20 74 6f  Calls Close() to
0bb0: 20 65 6e 73 75 72 65 20 65 76 65 72 79 74 68 69   ensure everythi
0bc0: 6e 67 20 69 73 20 63 6c 65 61 6e 65 64 20 75 70  ng is cleaned up
0bd0: 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
0be0: 61 72 79 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  ary>.    public 
0bf0: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 44 69  override void Di
0c00: 73 70 6f 73 65 28 29 0a 20 20 20 20 7b 0a 20 20  spose().    {.  
0c10: 20 20 20 20 43 6c 6f 73 65 28 29 3b 0a 20 20 20      Close();.   
0c20: 20 20 20 47 43 2e 53 75 70 70 72 65 73 73 46 69     GC.SuppressFi
0c30: 6e 61 6c 69 7a 65 28 74 68 69 73 29 3b 0a 20 20  nalize(this);.  
0c40: 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75    }..    /// <su
0c50: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 54  mmary>.    /// T
0c60: 68 72 6f 77 20 61 6e 20 65 72 72 6f 72 20 69 66  hrow an error if
0c70: 20 74 68 65 20 64 61 74 61 72 65 61 64 65 72 20   the datareader 
0c80: 69 73 20 63 6c 6f 73 65 64 0a 20 20 20 20 2f 2f  is closed.    //
0c90: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20  / </summary>.   
0ca0: 20 70 72 69 76 61 74 65 20 76 6f 69 64 20 43 68   private void Ch
0cb0: 65 63 6b 43 6c 6f 73 65 64 28 29 0a 20 20 20 20  eckClosed().    
0cc0: 7b 0a 20 20 20 20 20 20 69 66 20 28 5f 63 6f 6d  {.      if (_com
0cd0: 6d 61 6e 64 20 3d 3d 20 6e 75 6c 6c 29 0a 20 20  mand == null).  
0ce0: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
0cf0: 49 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e  InvalidOperation
0d00: 45 78 63 65 70 74 69 6f 6e 28 22 44 61 74 61 52  Exception("DataR
0d10: 65 61 64 65 72 20 68 61 73 20 62 65 65 6e 20 63  eader has been c
0d20: 6c 6f 73 65 64 22 29 3b 0a 20 20 20 20 7d 0a 0a  losed");.    }..
0d30: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
0d40: 3e 0a 20 20 20 20 2f 2f 2f 20 45 6e 75 6d 65 72  >.    /// Enumer
0d50: 61 74 6f 72 20 73 75 70 70 6f 72 74 0a 20 20 20  ator support.   
0d60: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
0d70: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
0d80: 3e 52 65 74 75 72 6e 73 20 61 20 44 62 45 6e 75  >Returns a DbEnu
0d90: 6d 65 72 61 74 6f 72 20 6f 62 6a 65 63 74 2e 3c  merator object.<
0da0: 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75  /returns>.    pu
0db0: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 43 6f  blic override Co
0dc0: 6c 6c 65 63 74 69 6f 6e 73 2e 49 45 6e 75 6d 65  llections.IEnume
0dd0: 72 61 74 6f 72 20 47 65 74 45 6e 75 6d 65 72 61  rator GetEnumera
0de0: 74 6f 72 28 29 0a 20 20 20 20 7b 0a 20 20 20 20  tor().    {.    
0df0: 20 20 72 65 74 75 72 6e 20 6e 65 77 20 44 62 45    return new DbE
0e00: 6e 75 6d 65 72 61 74 6f 72 28 74 68 69 73 29 3b  numerator(this);
0e10: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
0e20: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
0e30: 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  / .    /// </sum
0e40: 6d 61 72 79 3e 0a 20 20 20 20 70 75 62 6c 69 63  mary>.    public
0e50: 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 44 65   override int De
0e60: 70 74 68 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  pth.    {.      
0e70: 67 65 74 0a 20 20 20 20 20 20 7b 0a 20 20 20 20  get.      {.    
0e80: 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28      CheckClosed(
0e90: 29 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  );.        retur
0ea0: 6e 20 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n 0;.      }.   
0eb0: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
0ec0: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20  mary>.    /// . 
0ed0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
0ee0: 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65  >.    public ove
0ef0: 72 72 69 64 65 20 69 6e 74 20 46 69 65 6c 64 43  rride int FieldC
0f00: 6f 75 6e 74 0a 20 20 20 20 7b 0a 20 20 20 20 20  ount.    {.     
0f10: 20 67 65 74 0a 20 20 20 20 20 20 7b 0a 20 20 20   get.      {.   
0f20: 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64       CheckClosed
0f30: 28 29 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75  ();.        retu
0f40: 72 6e 20 5f 66 69 65 6c 64 43 6f 75 6e 74 3b 0a  rn _fieldCount;.
0f50: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20        }.    }.. 
0f60: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
0f70: 0a 20 20 20 20 2f 2f 2f 20 53 51 4c 69 74 65 20  .    /// SQLite 
0f80: 69 73 20 69 6e 68 65 72 65 6e 74 6c 79 20 75 6e  is inherently un
0f90: 2d 74 79 70 65 64 2e 20 20 41 6c 6c 20 64 61 74  -typed.  All dat
0fa0: 61 74 79 70 65 73 20 69 6e 20 53 51 4c 69 74 65  atypes in SQLite
0fb0: 20 61 72 65 20 6e 61 74 69 76 65 6c 79 20 73 74   are natively st
0fc0: 72 69 6e 67 73 2e 20 20 54 68 65 20 64 65 66 69  rings.  The defi
0fd0: 6e 69 74 69 6f 6e 20 6f 66 20 74 68 65 20 63 6f  nition of the co
0fe0: 6c 75 6d 6e 73 20 6f 66 20 61 20 74 61 62 6c 65  lumns of a table
0ff0: 0a 20 20 20 20 2f 2f 2f 20 61 6e 64 20 74 68 65  .    /// and the
1000: 20 61 66 66 69 6e 69 74 79 20 6f 66 20 72 65 74   affinity of ret
1010: 75 72 6e 65 64 20 74 79 70 65 73 20 61 72 65 20  urned types are 
1020: 61 6c 6c 20 77 65 20 68 61 76 65 20 74 6f 20 67  all we have to g
1030: 6f 20 6f 6e 20 74 6f 20 74 79 70 65 2d 72 65 73  o on to type-res
1040: 74 72 69 63 74 20 64 61 74 61 20 69 6e 20 74 68  trict data in th
1050: 65 20 72 65 61 64 65 72 2e 0a 20 20 20 20 2f 2f  e reader..    //
1060: 2f 20 0a 20 20 20 20 2f 2f 2f 20 54 68 69 73 20  / .    /// This 
1070: 66 75 6e 63 74 69 6f 6e 20 61 74 74 65 6d 70 74  function attempt
1080: 73 20 74 6f 20 76 65 72 69 66 79 20 74 68 61 74  s to verify that
1090: 20 74 68 65 20 74 79 70 65 20 6f 66 20 64 61 74   the type of dat
10a0: 61 20 62 65 69 6e 67 20 72 65 71 75 65 73 74 65  a being requeste
10b0: 64 20 6f 66 20 61 20 63 6f 6c 75 6d 6e 20 6d 61  d of a column ma
10c0: 74 63 68 65 73 20 74 68 65 20 64 61 74 61 74 79  tches the dataty
10d0: 70 65 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e  pe of the column
10e0: 2e 20 20 49 6e 0a 20 20 20 20 2f 2f 2f 20 74 68  .  In.    /// th
10f0: 65 20 63 61 73 65 20 6f 66 20 63 6f 6c 75 6d 6e  e case of column
1100: 73 20 74 68 61 74 20 61 72 65 20 6e 6f 74 20 62  s that are not b
1110: 61 63 6b 65 64 20 69 6e 74 6f 20 61 20 74 61 62  acked into a tab
1120: 6c 65 20 64 65 66 69 6e 69 74 69 6f 6e 2c 20 77  le definition, w
1130: 65 20 61 74 74 65 6d 70 74 20 74 6f 20 6d 61 74  e attempt to mat
1140: 63 68 20 75 70 20 74 68 65 20 61 66 66 69 6e 69  ch up the affini
1150: 74 79 20 6f 66 20 61 20 63 6f 6c 75 6d 6e 20 28  ty of a column (
1160: 69 6e 74 2c 20 64 6f 75 62 6c 65 2c 20 73 74 72  int, double, str
1170: 69 6e 67 20 6f 72 20 62 6c 6f 62 29 0a 20 20 20  ing or blob).   
1180: 20 2f 2f 2f 20 74 6f 20 61 20 73 65 74 20 6f 66   /// to a set of
1190: 20 6b 6e 6f 77 6e 20 74 79 70 65 73 20 74 68 61   known types tha
11a0: 74 20 63 6c 6f 73 65 6c 79 20 6d 61 74 63 68 20  t closely match 
11b0: 74 68 61 74 20 61 66 66 69 6e 69 74 79 2e 20 20  that affinity.  
11c0: 49 74 27 73 20 6e 6f 74 20 61 6e 20 65 78 61 63  It's not an exac
11d0: 74 20 73 63 69 65 6e 63 65 2c 20 62 75 74 20 69  t science, but i
11e0: 74 73 20 74 68 65 20 62 65 73 74 20 77 65 20 63  ts the best we c
11f0: 61 6e 20 64 6f 2e 0a 20 20 20 20 2f 2f 2f 20 3c  an do..    /// <
1200: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  /summary>.    //
1210: 2f 20 3c 72 65 74 75 72 6e 73 3e 0a 20 20 20 20  / <returns>.    
1220: 2f 2f 2f 20 54 68 69 73 20 66 75 6e 63 74 69 6f  /// This functio
1230: 6e 20 74 68 72 6f 77 73 20 61 6e 20 49 6e 76 61  n throws an Inva
1240: 6c 69 64 54 79 70 65 43 61 73 74 28 29 20 65 78  lidTypeCast() ex
1250: 63 65 70 74 69 6f 6e 20 69 66 20 74 68 65 20 72  ception if the r
1260: 65 71 75 65 73 74 65 64 20 74 79 70 65 20 64 6f  equested type do
1270: 65 73 6e 27 74 20 6d 61 74 63 68 20 74 68 65 20  esn't match the 
1280: 63 6f 6c 75 6d 6e 27 73 20 64 65 66 69 6e 69 74  column's definit
1290: 69 6f 6e 20 6f 72 20 61 66 66 69 6e 69 74 79 2e  ion or affinity.
12a0: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 74 75 72  .    /// </retur
12b0: 6e 73 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  ns>.    /// <par
12c0: 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c  am name="ordinal
12d0: 22 3e 54 68 65 20 69 6e 64 65 78 20 6f 66 20 74  ">The index of t
12e0: 68 65 20 63 6f 6c 75 6d 6e 20 74 6f 20 74 79 70  he column to typ
12f0: 65 2d 63 68 65 63 6b 3c 2f 70 61 72 61 6d 3e 0a  e-check</param>.
1300: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
1310: 61 6d 65 3d 22 74 79 70 22 3e 54 68 65 20 74 79  ame="typ">The ty
1320: 70 65 20 77 65 20 77 61 6e 74 20 74 6f 20 67 65  pe we want to ge
1330: 74 20 6f 75 74 20 6f 66 20 74 68 65 20 63 6f 6c  t out of the col
1340: 75 6d 6e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20  umn</param>.    
1350: 70 72 69 76 61 74 65 20 76 6f 69 64 20 56 65 72  private void Ver
1360: 69 66 79 54 79 70 65 28 69 6e 74 20 6f 72 64 69  ifyType(int ordi
1370: 6e 61 6c 2c 20 44 62 54 79 70 65 20 74 79 70 29  nal, DbType typ)
1380: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53 51 4c  .    {.      SQL
1390: 69 74 65 54 79 70 65 20 74 20 3d 20 47 65 74 53  iteType t = GetS
13a0: 51 4c 69 74 65 54 79 70 65 28 6f 72 64 69 6e 61  QLiteType(ordina
13b0: 6c 29 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 74  l);..      if (t
13c0: 2e 54 79 70 65 20 3d 3d 20 74 79 70 29 20 72 65  .Type == typ) re
13d0: 74 75 72 6e 3b 0a 0a 20 20 20 20 20 20 69 66 20  turn;..      if 
13e0: 28 74 2e 54 79 70 65 20 21 3d 20 44 62 54 79 70  (t.Type != DbTyp
13f0: 65 2e 4f 62 6a 65 63 74 29 0a 20 20 20 20 20 20  e.Object).      
1400: 7b 0a 20 20 20 20 20 20 20 20 2f 2f 20 43 6f 65  {.        // Coe
1410: 72 63 61 62 6c 65 20 74 79 70 65 2c 20 75 73 75  rcable type, usu
1420: 61 6c 6c 79 20 61 20 6c 69 74 65 72 61 6c 20 6f  ally a literal o
1430: 66 20 73 6f 6d 65 20 6b 69 6e 64 0a 20 20 20 20  f some kind.    
1440: 20 20 20 20 73 77 69 74 63 68 20 28 5f 66 69 65      switch (_fie
1450: 6c 64 54 79 70 65 41 72 72 61 79 5b 6f 72 64 69  ldTypeArray[ordi
1460: 6e 61 6c 5d 2e 41 66 66 69 6e 69 74 79 29 0a 20  nal].Affinity). 
1470: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
1480: 20 20 20 63 61 73 65 20 54 79 70 65 41 66 66 69     case TypeAffi
1490: 6e 69 74 79 2e 49 6e 74 36 34 3a 0a 20 20 20 20  nity.Int64:.    
14a0: 20 20 20 20 20 20 20 20 69 66 20 28 74 79 70 20          if (typ 
14b0: 3d 3d 20 44 62 54 79 70 65 2e 49 6e 74 31 36 29  == DbType.Int16)
14c0: 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 20 20 20   return;.       
14d0: 20 20 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20       if (typ == 
14e0: 44 62 54 79 70 65 2e 49 6e 74 33 32 29 20 72 65  DbType.Int32) re
14f0: 74 75 72 6e 3b 0a 20 20 20 20 20 20 20 20 20 20  turn;.          
1500: 20 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54    if (typ == DbT
1510: 79 70 65 2e 49 6e 74 36 34 29 20 72 65 74 75 72  ype.Int64) retur
1520: 6e 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  n;.            i
1530: 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65  f (typ == DbType
1540: 2e 42 6f 6f 6c 65 61 6e 29 20 72 65 74 75 72 6e  .Boolean) return
1550: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66  ;.            if
1560: 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e   (typ == DbType.
1570: 42 79 74 65 29 20 72 65 74 75 72 6e 3b 0a 20 20  Byte) return;.  
1580: 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b            break;
1590: 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20  .          case 
15a0: 54 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f 75  TypeAffinity.Dou
15b0: 62 6c 65 3a 0a 20 20 20 20 20 20 20 20 20 20 20  ble:.           
15c0: 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79   if (typ == DbTy
15d0: 70 65 2e 53 69 6e 67 6c 65 29 20 72 65 74 75 72  pe.Single) retur
15e0: 6e 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  n;.            i
15f0: 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65  f (typ == DbType
1600: 2e 44 6f 75 62 6c 65 29 20 72 65 74 75 72 6e 3b  .Double) return;
1610: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20  .            if 
1620: 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 44  (typ == DbType.D
1630: 65 63 69 6d 61 6c 29 20 72 65 74 75 72 6e 3b 0a  ecimal) return;.
1640: 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61              brea
1650: 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 63 61 73  k;.          cas
1660: 65 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 54  e TypeAffinity.T
1670: 65 78 74 3a 0a 20 20 20 20 20 20 20 20 20 20 20  ext:.           
1680: 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79   if (typ == DbTy
1690: 70 65 2e 53 42 79 74 65 29 20 72 65 74 75 72 6e  pe.SByte) return
16a0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66  ;.            if
16b0: 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e   (typ == DbType.
16c0: 53 74 72 69 6e 67 29 20 72 65 74 75 72 6e 3b 0a  String) return;.
16d0: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
16e0: 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 53 42  typ == DbType.SB
16f0: 79 74 65 29 20 72 65 74 75 72 6e 3b 0a 20 20 20  yte) return;.   
1700: 20 20 20 20 20 20 20 20 20 69 66 20 28 74 79 70           if (typ
1710: 20 3d 3d 20 44 62 54 79 70 65 2e 47 75 69 64 29   == DbType.Guid)
1720: 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 20 20 20   return;.       
1730: 20 20 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20       if (typ == 
1740: 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d 65 29  DbType.DateTime)
1750: 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 20 20 20   return;.       
1760: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
1770: 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65 41        case TypeA
1780: 66 66 69 6e 69 74 79 2e 42 6c 6f 62 3a 0a 20 20  ffinity.Blob:.  
1790: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74 79            if (ty
17a0: 70 20 3d 3d 20 44 62 54 79 70 65 2e 53 74 72 69  p == DbType.Stri
17b0: 6e 67 29 20 72 65 74 75 72 6e 3b 0a 20 20 20 20  ng) return;.    
17c0: 20 20 20 20 20 20 20 20 69 66 20 28 74 79 70 20          if (typ 
17d0: 3d 3d 20 44 62 54 79 70 65 2e 42 69 6e 61 72 79  == DbType.Binary
17e0: 29 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 20 20  ) return;.      
17f0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
1800: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 0a       }.      }..
1810: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
1820: 49 6e 76 61 6c 69 64 43 61 73 74 45 78 63 65 70  InvalidCastExcep
1830: 74 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a 0a 20  tion();.    }.. 
1840: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
1850: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
1860: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  ry>.    /// <par
1870: 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c  am name="ordinal
1880: 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  "></param>.    /
1890: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65  // <returns></re
18a0: 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69  turns>.    publi
18b0: 63 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20  c override bool 
18c0: 47 65 74 42 6f 6f 6c 65 61 6e 28 69 6e 74 20 6f  GetBoolean(int o
18d0: 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b 0a 20 20  rdinal).    {.  
18e0: 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28      CheckClosed(
18f0: 29 3b 0a 20 20 20 20 20 20 56 65 72 69 66 79 54  );.      VerifyT
1900: 79 70 65 28 6f 72 64 69 6e 61 6c 2c 20 44 62 54  ype(ordinal, DbT
1910: 79 70 65 2e 42 6f 6f 6c 65 61 6e 29 3b 0a 20 20  ype.Boolean);.  
1920: 20 20 20 20 72 65 74 75 72 6e 20 43 6f 6e 76 65      return Conve
1930: 72 74 2e 54 6f 42 6f 6f 6c 65 61 6e 28 47 65 74  rt.ToBoolean(Get
1940: 56 61 6c 75 65 28 6f 72 64 69 6e 61 6c 29 29 3b  Value(ordinal));
1950: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
1960: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
1970: 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  / .    /// </sum
1980: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  mary>.    /// <p
1990: 61 72 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69 6e  aram name="ordin
19a0: 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20  al"></param>.   
19b0: 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f   /// <returns></
19c0: 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62  returns>.    pub
19d0: 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62 79 74  lic override byt
19e0: 65 20 47 65 74 42 79 74 65 28 69 6e 74 20 6f 72  e GetByte(int or
19f0: 64 69 6e 61 6c 29 0a 20 20 20 20 7b 0a 20 20 20  dinal).    {.   
1a00: 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29     CheckClosed()
1a10: 3b 0a 20 20 20 20 20 20 56 65 72 69 66 79 54 79  ;.      VerifyTy
1a20: 70 65 28 6f 72 64 69 6e 61 6c 2c 20 44 62 54 79  pe(ordinal, DbTy
1a30: 70 65 2e 42 79 74 65 29 3b 0a 20 20 20 20 20 20  pe.Byte);.      
1a40: 72 65 74 75 72 6e 20 43 6f 6e 76 65 72 74 2e 54  return Convert.T
1a50: 6f 42 79 74 65 28 5f 61 63 74 69 76 65 53 74 61  oByte(_activeSta
1a60: 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 49  tement._sql.GetI
1a70: 6e 74 33 32 28 5f 61 63 74 69 76 65 53 74 61 74  nt32(_activeStat
1a80: 65 6d 65 6e 74 2c 20 6f 72 64 69 6e 61 6c 29 29  ement, ordinal))
1a90: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f  ;.    }..    ///
1aa0: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
1ab0: 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  // .    /// </su
1ac0: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c  mmary>.    /// <
1ad0: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69  param name="ordi
1ae0: 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20  nal"></param>.  
1af0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
1b00: 65 3d 22 64 61 74 61 4f 66 66 73 65 74 22 3e 3c  e="dataOffset"><
1b10: 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20  /param>.    /// 
1b20: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62 75 66  <param name="buf
1b30: 66 65 72 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20  fer"></param>.  
1b40: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
1b50: 65 3d 22 62 75 66 66 65 72 4f 66 66 73 65 74 22  e="bufferOffset"
1b60: 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f  ></param>.    //
1b70: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6c  / <param name="l
1b80: 65 6e 67 74 68 22 3e 3c 2f 70 61 72 61 6d 3e 0a  ength"></param>.
1b90: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
1ba0: 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20  ></returns>.    
1bb0: 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20  public override 
1bc0: 6c 6f 6e 67 20 47 65 74 42 79 74 65 73 28 69 6e  long GetBytes(in
1bd0: 74 20 6f 72 64 69 6e 61 6c 2c 20 6c 6f 6e 67 20  t ordinal, long 
1be0: 64 61 74 61 4f 66 66 73 65 74 2c 20 62 79 74 65  dataOffset, byte
1bf0: 5b 5d 20 62 75 66 66 65 72 2c 20 69 6e 74 20 62  [] buffer, int b
1c00: 75 66 66 65 72 4f 66 66 73 65 74 2c 20 69 6e 74  ufferOffset, int
1c10: 20 6c 65 6e 67 74 68 29 0a 20 20 20 20 7b 0a 20   length).    {. 
1c20: 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64       CheckClosed
1c30: 28 29 3b 0a 20 20 20 20 20 20 56 65 72 69 66 79  ();.      Verify
1c40: 54 79 70 65 28 6f 72 64 69 6e 61 6c 2c 20 44 62  Type(ordinal, Db
1c50: 54 79 70 65 2e 42 69 6e 61 72 79 29 3b 0a 20 20  Type.Binary);.  
1c60: 20 20 20 20 72 65 74 75 72 6e 20 5f 61 63 74 69      return _acti
1c70: 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c  veStatement._sql
1c80: 2e 47 65 74 42 79 74 65 73 28 5f 61 63 74 69 76  .GetBytes(_activ
1c90: 65 53 74 61 74 65 6d 65 6e 74 2c 20 6f 72 64 69  eStatement, ordi
1ca0: 6e 61 6c 2c 20 28 69 6e 74 29 64 61 74 61 4f 66  nal, (int)dataOf
1cb0: 66 73 65 74 2c 20 62 75 66 66 65 72 2c 20 62 75  fset, buffer, bu
1cc0: 66 66 65 72 4f 66 66 73 65 74 2c 20 6c 65 6e 67  fferOffset, leng
1cd0: 74 68 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  th);.    }..    
1ce0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20  /// <summary>.  
1cf0: 20 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c    /// .    /// <
1d00: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  /summary>.    //
1d10: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f  / <param name="o
1d20: 72 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e  rdinal"></param>
1d30: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
1d40: 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20  s></returns>.   
1d50: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
1d60: 20 63 68 61 72 20 47 65 74 43 68 61 72 28 69 6e   char GetChar(in
1d70: 74 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b  t ordinal).    {
1d80: 0a 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73  .      CheckClos
1d90: 65 64 28 29 3b 0a 20 20 20 20 20 20 56 65 72 69  ed();.      Veri
1da0: 66 79 54 79 70 65 28 6f 72 64 69 6e 61 6c 2c 20  fyType(ordinal, 
1db0: 44 62 54 79 70 65 2e 53 42 79 74 65 29 3b 0a 20  DbType.SByte);. 
1dc0: 20 20 20 20 20 72 65 74 75 72 6e 20 43 6f 6e 76       return Conv
1dd0: 65 72 74 2e 54 6f 43 68 61 72 28 5f 61 63 74 69  ert.ToChar(_acti
1de0: 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c  veStatement._sql
1df0: 2e 47 65 74 49 6e 74 33 32 28 5f 61 63 74 69 76  .GetInt32(_activ
1e00: 65 53 74 61 74 65 6d 65 6e 74 2c 20 6f 72 64 69  eStatement, ordi
1e10: 6e 61 6c 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  nal));.    }..  
1e20: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
1e30: 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f      /// .    ///
1e40: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20   </summary>.    
1e50: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
1e60: 22 6f 72 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61  "ordinal"></para
1e70: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  m>.    /// <para
1e80: 6d 20 6e 61 6d 65 3d 22 64 61 74 61 4f 66 66 73  m name="dataOffs
1e90: 65 74 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20  et"></param>.   
1ea0: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
1eb0: 3d 22 62 75 66 66 65 72 22 3e 3c 2f 70 61 72 61  ="buffer"></para
1ec0: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  m>.    /// <para
1ed0: 6d 20 6e 61 6d 65 3d 22 62 75 66 66 65 72 4f 66  m name="bufferOf
1ee0: 66 73 65 74 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20  fset"></param>. 
1ef0: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
1f00: 6d 65 3d 22 6c 65 6e 67 74 68 22 3e 3c 2f 70 61  me="length"></pa
1f10: 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ram>.    /// <re
1f20: 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e  turns></returns>
1f30: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
1f40: 72 69 64 65 20 6c 6f 6e 67 20 47 65 74 43 68 61  ride long GetCha
1f50: 72 73 28 69 6e 74 20 6f 72 64 69 6e 61 6c 2c 20  rs(int ordinal, 
1f60: 6c 6f 6e 67 20 64 61 74 61 4f 66 66 73 65 74 2c  long dataOffset,
1f70: 20 63 68 61 72 5b 5d 20 62 75 66 66 65 72 2c 20   char[] buffer, 
1f80: 69 6e 74 20 62 75 66 66 65 72 4f 66 66 73 65 74  int bufferOffset
1f90: 2c 20 69 6e 74 20 6c 65 6e 67 74 68 29 0a 20 20  , int length).  
1fa0: 20 20 7b 0a 20 20 20 20 20 20 43 68 65 63 6b 43    {.      CheckC
1fb0: 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20 20 20 56  losed();.      V
1fc0: 65 72 69 66 79 54 79 70 65 28 6f 72 64 69 6e 61  erifyType(ordina
1fd0: 6c 2c 20 44 62 54 79 70 65 2e 53 74 72 69 6e 67  l, DbType.String
1fe0: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
1ff0: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
2000: 2e 5f 73 71 6c 2e 47 65 74 43 68 61 72 73 28 5f  ._sql.GetChars(_
2010: 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2c  activeStatement,
2020: 20 6f 72 64 69 6e 61 6c 2c 20 28 69 6e 74 29 64   ordinal, (int)d
2030: 61 74 61 4f 66 66 73 65 74 2c 20 62 75 66 66 65  ataOffset, buffe
2040: 72 2c 20 62 75 66 66 65 72 4f 66 66 73 65 74 2c  r, bufferOffset,
2050: 20 6c 65 6e 67 74 68 29 3b 0a 20 20 20 20 7d 0a   length);.    }.
2060: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
2070: 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20  y>.    /// .    
2080: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
2090: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
20a0: 6d 65 3d 22 6f 72 64 69 6e 61 6c 22 3e 3c 2f 70  me="ordinal"></p
20b0: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72  aram>.    /// <r
20c0: 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73  eturns></returns
20d0: 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65  >.    public ove
20e0: 72 72 69 64 65 20 73 74 72 69 6e 67 20 47 65 74  rride string Get
20f0: 44 61 74 61 54 79 70 65 4e 61 6d 65 28 69 6e 74  DataTypeName(int
2100: 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b 0a   ordinal).    {.
2110: 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65        CheckClose
2120: 64 28 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72  d();.      retur
2130: 6e 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65  n _activeStateme
2140: 6e 74 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e 4e 61  nt._sql.ColumnNa
2150: 6d 65 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d  me(_activeStatem
2160: 65 6e 74 2c 20 6f 72 64 69 6e 61 6c 29 3b 0a 20  ent, ordinal);. 
2170: 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73     }..    /// <s
2180: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
2190: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
21a0: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  ry>.    /// <par
21b0: 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c  am name="ordinal
21c0: 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  "></param>.    /
21d0: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65  // <returns></re
21e0: 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69  turns>.    publi
21f0: 63 20 6f 76 65 72 72 69 64 65 20 44 61 74 65 54  c override DateT
2200: 69 6d 65 20 47 65 74 44 61 74 65 54 69 6d 65 28  ime GetDateTime(
2210: 69 6e 74 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20  int ordinal).   
2220: 20 7b 0a 20 20 20 20 20 20 43 68 65 63 6b 43 6c   {.      CheckCl
2230: 6f 73 65 64 28 29 3b 0a 20 20 20 20 20 20 56 65  osed();.      Ve
2240: 72 69 66 79 54 79 70 65 28 6f 72 64 69 6e 61 6c  rifyType(ordinal
2250: 2c 20 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d  , DbType.DateTim
2260: 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  e);.      return
2270: 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e   _activeStatemen
2280: 74 2e 5f 73 71 6c 2e 47 65 74 44 61 74 65 54 69  t._sql.GetDateTi
2290: 6d 65 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d  me(_activeStatem
22a0: 65 6e 74 2c 20 6f 72 64 69 6e 61 6c 29 3b 0a 20  ent, ordinal);. 
22b0: 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73     }..    /// <s
22c0: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
22d0: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
22e0: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  ry>.    /// <par
22f0: 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c  am name="ordinal
2300: 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  "></param>.    /
2310: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65  // <returns></re
2320: 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69  turns>.    publi
2330: 63 20 6f 76 65 72 72 69 64 65 20 64 65 63 69 6d  c override decim
2340: 61 6c 20 47 65 74 44 65 63 69 6d 61 6c 28 69 6e  al GetDecimal(in
2350: 74 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b  t ordinal).    {
2360: 0a 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73  .      CheckClos
2370: 65 64 28 29 3b 0a 20 20 20 20 20 20 56 65 72 69  ed();.      Veri
2380: 66 79 54 79 70 65 28 6f 72 64 69 6e 61 6c 2c 20  fyType(ordinal, 
2390: 44 62 54 79 70 65 2e 44 65 63 69 6d 61 6c 29 3b  DbType.Decimal);
23a0: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 43 6f  .      return Co
23b0: 6e 76 65 72 74 2e 54 6f 44 65 63 69 6d 61 6c 28  nvert.ToDecimal(
23c0: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
23d0: 2e 5f 73 71 6c 2e 47 65 74 44 6f 75 62 6c 65 28  ._sql.GetDouble(
23e0: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
23f0: 2c 20 6f 72 64 69 6e 61 6c 29 29 3b 0a 20 20 20  , ordinal));.   
2400: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
2410: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20  mary>.    /// . 
2420: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
2430: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
2440: 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c 22 3e   name="ordinal">
2450: 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f  </param>.    ///
2460: 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75   <returns></retu
2470: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
2480: 6f 76 65 72 72 69 64 65 20 64 6f 75 62 6c 65 20  override double 
2490: 47 65 74 44 6f 75 62 6c 65 28 69 6e 74 20 6f 72  GetDouble(int or
24a0: 64 69 6e 61 6c 29 0a 20 20 20 20 7b 0a 20 20 20  dinal).    {.   
24b0: 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29     CheckClosed()
24c0: 3b 0a 20 20 20 20 20 20 56 65 72 69 66 79 54 79  ;.      VerifyTy
24d0: 70 65 28 6f 72 64 69 6e 61 6c 2c 20 44 62 54 79  pe(ordinal, DbTy
24e0: 70 65 2e 44 6f 75 62 6c 65 29 3b 0a 20 20 20 20  pe.Double);.    
24f0: 20 20 72 65 74 75 72 6e 20 5f 61 63 74 69 76 65    return _active
2500: 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47  Statement._sql.G
2510: 65 74 44 6f 75 62 6c 65 28 5f 61 63 74 69 76 65  etDouble(_active
2520: 53 74 61 74 65 6d 65 6e 74 2c 20 6f 72 64 69 6e  Statement, ordin
2530: 61 6c 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  al);.    }..    
2540: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20  /// <summary>.  
2550: 20 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c    /// .    /// <
2560: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  /summary>.    //
2570: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f  / <param name="o
2580: 72 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e  rdinal"></param>
2590: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
25a0: 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20  s></returns>.   
25b0: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
25c0: 20 54 79 70 65 20 47 65 74 46 69 65 6c 64 54 79   Type GetFieldTy
25d0: 70 65 28 69 6e 74 20 6f 72 64 69 6e 61 6c 29 0a  pe(int ordinal).
25e0: 20 20 20 20 7b 0a 20 20 20 20 20 20 43 68 65 63      {.      Chec
25f0: 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20 20  kClosed();.     
2600: 20 53 51 4c 69 74 65 54 79 70 65 20 74 20 3d 20   SQLiteType t = 
2610: 47 65 74 53 51 4c 69 74 65 54 79 70 65 28 6f 72  GetSQLiteType(or
2620: 64 69 6e 61 6c 29 3b 0a 0a 20 20 20 20 20 20 69  dinal);..      i
2630: 66 20 28 74 2e 54 79 70 65 20 21 3d 20 44 62 54  f (t.Type != DbT
2640: 79 70 65 2e 4f 62 6a 65 63 74 29 0a 20 20 20 20  ype.Object).    
2650: 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 69 74      return SQLit
2660: 65 43 6f 6e 76 65 72 74 2e 44 62 54 79 70 65 54  eConvert.DbTypeT
2670: 6f 54 79 70 65 28 74 2e 54 79 70 65 29 3b 0a 0a  oType(t.Type);..
2680: 20 20 20 20 20 20 73 77 69 74 63 68 20 28 74 2e        switch (t.
2690: 41 66 66 69 6e 69 74 79 29 0a 20 20 20 20 20 20  Affinity).      
26a0: 7b 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 54  {.        case T
26b0: 79 70 65 41 66 66 69 6e 69 74 79 2e 4e 75 6c 6c  ypeAffinity.Null
26c0: 3a 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  :.          retu
26d0: 72 6e 20 74 79 70 65 6f 66 28 44 42 4e 75 6c 6c  rn typeof(DBNull
26e0: 29 3b 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  );.        case 
26f0: 54 79 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74  TypeAffinity.Int
2700: 36 34 3a 0a 20 20 20 20 20 20 20 20 20 20 72 65  64:.          re
2710: 74 75 72 6e 20 74 79 70 65 6f 66 28 49 6e 74 36  turn typeof(Int6
2720: 34 29 3b 0a 20 20 20 20 20 20 20 20 63 61 73 65  4);.        case
2730: 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f   TypeAffinity.Do
2740: 75 62 6c 65 3a 0a 20 20 20 20 20 20 20 20 20 20  uble:.          
2750: 72 65 74 75 72 6e 20 74 79 70 65 6f 66 28 44 6f  return typeof(Do
2760: 75 62 6c 65 29 3b 0a 20 20 20 20 20 20 20 20 63  uble);.        c
2770: 61 73 65 20 54 79 70 65 41 66 66 69 6e 69 74 79  ase TypeAffinity
2780: 2e 42 6c 6f 62 3a 0a 20 20 20 20 20 20 20 20 20  .Blob:.         
2790: 20 72 65 74 75 72 6e 20 74 79 70 65 6f 66 28 62   return typeof(b
27a0: 79 74 65 5b 5d 29 3b 0a 20 20 20 20 20 20 20 20  yte[]);.        
27b0: 64 65 66 61 75 6c 74 3a 0a 20 20 20 20 20 20 20  default:.       
27c0: 20 20 20 72 65 74 75 72 6e 20 74 79 70 65 6f 66     return typeof
27d0: 28 73 74 72 69 6e 67 29 3b 0a 20 20 20 20 20 20  (string);.      
27e0: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f  }.    }..    ///
27f0: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
2800: 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  // .    /// </su
2810: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c  mmary>.    /// <
2820: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69  param name="ordi
2830: 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20  nal"></param>.  
2840: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c    /// <returns><
2850: 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75  /returns>.    pu
2860: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 66 6c  blic override fl
2870: 6f 61 74 20 47 65 74 46 6c 6f 61 74 28 69 6e 74  oat GetFloat(int
2880: 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b 0a   ordinal).    {.
2890: 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65        CheckClose
28a0: 64 28 29 3b 0a 20 20 20 20 20 20 56 65 72 69 66  d();.      Verif
28b0: 79 54 79 70 65 28 6f 72 64 69 6e 61 6c 2c 20 44  yType(ordinal, D
28c0: 62 54 79 70 65 2e 53 69 6e 67 6c 65 29 3b 0a 20  bType.Single);. 
28d0: 20 20 20 20 20 72 65 74 75 72 6e 20 43 6f 6e 76       return Conv
28e0: 65 72 74 2e 54 6f 53 69 6e 67 6c 65 28 5f 61 63  ert.ToSingle(_ac
28f0: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73  tiveStatement._s
2900: 71 6c 2e 47 65 74 44 6f 75 62 6c 65 28 5f 61 63  ql.GetDouble(_ac
2910: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2c 20 6f  tiveStatement, o
2920: 72 64 69 6e 61 6c 29 29 3b 0a 20 20 20 20 7d 0a  rdinal));.    }.
2930: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
2940: 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20  y>.    /// .    
2950: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
2960: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
2970: 6d 65 3d 22 6f 72 64 69 6e 61 6c 22 3e 3c 2f 70  me="ordinal"></p
2980: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72  aram>.    /// <r
2990: 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73  eturns></returns
29a0: 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65  >.    public ove
29b0: 72 72 69 64 65 20 47 75 69 64 20 47 65 74 47 75  rride Guid GetGu
29c0: 69 64 28 69 6e 74 20 6f 72 64 69 6e 61 6c 29 0a  id(int ordinal).
29d0: 20 20 20 20 7b 0a 20 20 20 20 20 20 43 68 65 63      {.      Chec
29e0: 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20 20  kClosed();.     
29f0: 20 56 65 72 69 66 79 54 79 70 65 28 6f 72 64 69   VerifyType(ordi
2a00: 6e 61 6c 2c 20 44 62 54 79 70 65 2e 47 75 69 64  nal, DbType.Guid
2a10: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
2a20: 6e 65 77 20 47 75 69 64 28 5f 61 63 74 69 76 65  new Guid(_active
2a30: 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47  Statement._sql.G
2a40: 65 74 54 65 78 74 28 5f 61 63 74 69 76 65 53 74  etText(_activeSt
2a50: 61 74 65 6d 65 6e 74 2c 20 6f 72 64 69 6e 61 6c  atement, ordinal
2a60: 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  ));.    }..    /
2a70: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20  // <summary>.   
2a80: 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f   /// .    /// </
2a90: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
2aa0: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f 72   <param name="or
2ab0: 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a  dinal"></param>.
2ac0: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
2ad0: 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20  ></returns>.    
2ae0: 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20  public override 
2af0: 49 6e 74 31 36 20 47 65 74 49 6e 74 31 36 28 69  Int16 GetInt16(i
2b00: 6e 74 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20  nt ordinal).    
2b10: 7b 0a 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f  {.      CheckClo
2b20: 73 65 64 28 29 3b 0a 20 20 20 20 20 20 56 65 72  sed();.      Ver
2b30: 69 66 79 54 79 70 65 28 6f 72 64 69 6e 61 6c 2c  ifyType(ordinal,
2b40: 20 44 62 54 79 70 65 2e 49 6e 74 31 36 29 3b 0a   DbType.Int16);.
2b50: 20 20 20 20 20 20 72 65 74 75 72 6e 20 43 6f 6e        return Con
2b60: 76 65 72 74 2e 54 6f 49 6e 74 31 36 28 5f 61 63  vert.ToInt16(_ac
2b70: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73  tiveStatement._s
2b80: 71 6c 2e 47 65 74 49 6e 74 33 32 28 5f 61 63 74  ql.GetInt32(_act
2b90: 69 76 65 53 74 61 74 65 6d 65 6e 74 2c 20 6f 72  iveStatement, or
2ba0: 64 69 6e 61 6c 29 29 3b 0a 20 20 20 20 7d 0a 0a  dinal));.    }..
2bb0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
2bc0: 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20 2f  >.    /// .    /
2bd0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20  // </summary>.  
2be0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
2bf0: 65 3d 22 6f 72 64 69 6e 61 6c 22 3e 3c 2f 70 61  e="ordinal"></pa
2c00: 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ram>.    /// <re
2c10: 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e  turns></returns>
2c20: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
2c30: 72 69 64 65 20 49 6e 74 33 32 20 47 65 74 49 6e  ride Int32 GetIn
2c40: 74 33 32 28 69 6e 74 20 6f 72 64 69 6e 61 6c 29  t32(int ordinal)
2c50: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 43 68 65  .    {.      Che
2c60: 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20  ckClosed();.    
2c70: 20 20 56 65 72 69 66 79 54 79 70 65 28 6f 72 64    VerifyType(ord
2c80: 69 6e 61 6c 2c 20 44 62 54 79 70 65 2e 49 6e 74  inal, DbType.Int
2c90: 33 32 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72  32);.      retur
2ca0: 6e 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65  n _activeStateme
2cb0: 6e 74 2e 5f 73 71 6c 2e 47 65 74 49 6e 74 33 32  nt._sql.GetInt32
2cc0: 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  (_activeStatemen
2cd0: 74 2c 20 6f 72 64 69 6e 61 6c 29 3b 0a 20 20 20  t, ordinal);.   
2ce0: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
2cf0: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20  mary>.    /// . 
2d00: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
2d10: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
2d20: 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c 22 3e   name="ordinal">
2d30: 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f  </param>.    ///
2d40: 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75   <returns></retu
2d50: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
2d60: 6f 76 65 72 72 69 64 65 20 49 6e 74 36 34 20 47  override Int64 G
2d70: 65 74 49 6e 74 36 34 28 69 6e 74 20 6f 72 64 69  etInt64(int ordi
2d80: 6e 61 6c 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  nal).    {.     
2d90: 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a   CheckClosed();.
2da0: 20 20 20 20 20 20 56 65 72 69 66 79 54 79 70 65        VerifyType
2db0: 28 6f 72 64 69 6e 61 6c 2c 20 44 62 54 79 70 65  (ordinal, DbType
2dc0: 2e 49 6e 74 36 34 29 3b 0a 20 20 20 20 20 20 72  .Int64);.      r
2dd0: 65 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61  eturn _activeSta
2de0: 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 49  tement._sql.GetI
2df0: 6e 74 36 34 28 5f 61 63 74 69 76 65 53 74 61 74  nt64(_activeStat
2e00: 65 6d 65 6e 74 2c 20 6f 72 64 69 6e 61 6c 29 3b  ement, ordinal);
2e10: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
2e20: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
2e30: 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  / .    /// </sum
2e40: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  mary>.    /// <p
2e50: 61 72 61 6d 20 6e 61 6d 65 3d 22 6f 72 64 69 6e  aram name="ordin
2e60: 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20  al"></param>.   
2e70: 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f   /// <returns></
2e80: 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62  returns>.    pub
2e90: 6c 69 63 20 6f 76 65 72 72 69 64 65 20 73 74 72  lic override str
2ea0: 69 6e 67 20 47 65 74 4e 61 6d 65 28 69 6e 74 20  ing GetName(int 
2eb0: 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b 0a 20  ordinal).    {. 
2ec0: 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64       CheckClosed
2ed0: 28 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  ();.      return
2ee0: 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e   _activeStatemen
2ef0: 74 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e 4e 61 6d  t._sql.ColumnNam
2f00: 65 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65  e(_activeStateme
2f10: 6e 74 2c 20 6f 72 64 69 6e 61 6c 29 3b 0a 20 20  nt, ordinal);.  
2f20: 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75    }..    /// <su
2f30: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a  mmary>.    /// .
2f40: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
2f50: 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  y>.    /// <para
2f60: 6d 20 6e 61 6d 65 3d 22 6e 61 6d 65 22 3e 3c 2f  m name="name"></
2f70: 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c  param>.    /// <
2f80: 72 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e  returns></return
2f90: 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76  s>.    public ov
2fa0: 65 72 72 69 64 65 20 69 6e 74 20 47 65 74 4f 72  erride int GetOr
2fb0: 64 69 6e 61 6c 28 73 74 72 69 6e 67 20 6e 61 6d  dinal(string nam
2fc0: 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 43  e).    {.      C
2fd0: 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20  heckClosed();.  
2fe0: 20 20 20 20 72 65 74 75 72 6e 20 5f 61 63 74 69      return _acti
2ff0: 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c  veStatement._sql
3000: 2e 43 6f 6c 75 6d 6e 49 6e 64 65 78 28 5f 61 63  .ColumnIndex(_ac
3010: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2c 20 6e  tiveStatement, n
3020: 61 6d 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ame);.    }..   
3030: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
3040: 20 20 20 2f 2f 2f 20 53 63 68 65 6d 61 20 69 6e     /// Schema in
3050: 66 6f 72 6d 61 74 69 6f 6e 20 69 6e 20 53 51 4c  formation in SQL
3060: 69 74 65 20 69 73 20 61 6e 20 69 66 66 79 2d 62  ite is an iffy-b
3070: 75 73 69 6e 65 73 73 2e 20 20 57 65 27 76 65 20  usiness.  We've 
3080: 65 78 74 65 6e 64 65 64 20 74 68 65 20 6e 61 74  extended the nat
3090: 69 76 65 20 53 51 4c 69 74 65 33 2e 44 4c 4c 20  ive SQLite3.DLL 
30a0: 74 6f 20 69 6e 63 6c 75 64 65 20 61 20 73 70 65  to include a spe
30b0: 63 69 61 6c 20 70 72 61 67 6d 61 20 63 61 6c 6c  cial pragma call
30c0: 65 64 0a 20 20 20 20 2f 2f 2f 20 50 52 41 47 4d  ed.    /// PRAGM
30d0: 41 20 72 65 61 6c 5f 63 6f 6c 75 6d 6e 5f 6e 61  A real_column_na
30e0: 6d 65 73 0a 20 20 20 20 2f 2f 2f 20 57 68 65 6e  mes.    /// When
30f0: 20 65 6e 61 62 6c 65 64 2c 20 74 68 65 20 70 72   enabled, the pr
3100: 61 67 6d 61 20 63 61 75 73 65 73 20 61 6c 6c 20  agma causes all 
3110: 63 6f 6c 75 6d 6e 20 61 6c 69 61 73 65 73 20 74  column aliases t
3120: 6f 20 62 65 20 69 67 6e 6f 72 65 64 2c 20 61 6e  o be ignored, an
3130: 64 20 74 68 65 20 66 75 6c 6c 20 44 61 74 61 62  d the full Datab
3140: 61 73 65 2e 54 61 62 6c 65 2e 43 6f 6c 75 6d 6e  ase.Table.Column
3150: 4e 61 6d 65 20 74 6f 20 62 65 20 72 65 74 75 72  Name to be retur
3160: 6e 65 64 20 66 6f 72 0a 20 20 20 20 2f 2f 2f 20  ned for.    /// 
3170: 65 61 63 68 20 63 6f 6c 75 6d 6e 20 6f 66 20 61  each column of a
3180: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
3190: 74 2e 20 20 55 73 69 6e 67 20 74 68 69 73 20 69  t.  Using this i
31a0: 6e 66 6f 72 6d 61 74 69 6f 6e 20 69 74 20 69 73  nformation it is
31b0: 20 74 68 65 6e 20 70 6f 73 73 69 62 6c 65 20 74   then possible t
31c0: 6f 20 71 75 65 72 79 20 65 61 63 68 20 64 61 74  o query each dat
31d0: 61 62 61 73 65 20 61 6e 64 20 74 61 62 6c 65 20  abase and table 
31e0: 66 6f 72 20 74 68 65 0a 20 20 20 20 2f 2f 2f 20  for the.    /// 
31f0: 6d 61 74 63 68 69 6e 67 20 63 6f 6c 75 6d 6e 2c  matching column,
3200: 20 61 6e 64 20 61 73 73 6f 63 69 61 74 65 20 69   and associate i
3210: 74 20 77 69 74 68 20 74 68 65 20 61 63 74 69 76  t with the activ
3220: 65 20 73 74 61 74 65 6d 65 6e 74 2e 0a 20 20 20  e statement..   
3230: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
3240: 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61 72 6b 73      /// <remarks
3250: 3e 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 63 75  >.    /// The cu
3260: 72 72 65 6e 74 20 63 6f 6e 6e 65 63 74 69 6f 6e  rrent connection
3270: 20 69 73 20 63 6c 6f 6e 65 64 20 66 6f 72 20 74   is cloned for t
3280: 68 65 20 73 61 6b 65 20 6f 66 20 65 78 65 63 75  he sake of execu
3290: 74 69 6e 67 20 74 68 69 73 20 73 74 61 74 65 6d  ting this statem
32a0: 65 6e 74 2c 20 73 6f 20 61 73 20 74 6f 20 61 76  ent, so as to av
32b0: 6f 69 64 20 61 6e 79 20 70 6f 73 73 69 62 69 6c  oid any possibil
32c0: 69 74 79 20 6f 66 20 63 6f 72 72 75 70 74 69 6e  ity of corruptin
32d0: 67 20 74 68 65 0a 20 20 20 20 2f 2f 2f 20 6f 72  g the.    /// or
32e0: 69 67 69 6e 61 6c 20 63 6f 6e 6e 65 63 74 69 6f  iginal connectio
32f0: 6e 27 73 20 65 78 69 73 74 69 6e 67 20 73 74 61  n's existing sta
3300: 74 65 6d 65 6e 74 73 20 6f 72 20 73 74 61 74 65  tements or state
3310: 2e 20 20 41 6e 79 20 61 74 74 61 63 68 65 64 20  .  Any attached 
3320: 64 61 74 61 62 61 73 65 73 20 61 72 65 20 72 65  databases are re
3330: 2d 61 74 74 61 63 68 65 64 20 74 6f 20 74 68 65  -attached to the
3340: 20 6e 65 77 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e   new connection.
3350: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72  .    /// </remar
3360: 6b 73 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  ks>.    /// <ret
3370: 75 72 6e 73 3e 52 65 74 75 72 6e 73 20 61 20 44  urns>Returns a D
3380: 61 74 61 54 61 62 6c 65 20 63 6f 6e 74 61 69 6e  ataTable contain
3390: 69 6e 67 20 74 68 65 20 73 63 68 65 6d 61 20 69  ing the schema i
33a0: 6e 66 6f 72 6d 61 74 69 6f 6e 20 66 6f 72 20 74  nformation for t
33b0: 68 65 20 61 63 74 69 76 65 20 53 45 4c 45 43 54  he active SELECT
33c0: 20 73 74 61 74 65 6d 65 6e 74 20 62 65 69 6e 67   statement being
33d0: 20 70 72 6f 63 65 73 73 65 64 2e 3c 2f 72 65 74   processed.</ret
33e0: 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63  urns>.    public
33f0: 20 6f 76 65 72 72 69 64 65 20 44 61 74 61 54 61   override DataTa
3400: 62 6c 65 20 47 65 74 53 63 68 65 6d 61 54 61 62  ble GetSchemaTab
3410: 6c 65 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  le().    {.     
3420: 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a   CheckClosed();.
3430: 0a 20 20 20 20 20 20 44 61 74 61 54 61 62 6c 65  .      DataTable
3440: 20 74 62 6c 20 3d 20 6e 65 77 20 44 61 74 61 54   tbl = new DataT
3450: 61 62 6c 65 28 22 53 63 68 65 6d 61 22 29 3b 0a  able("Schema");.
3460: 20 20 20 20 20 20 73 74 72 69 6e 67 5b 5d 20 61        string[] a
3470: 72 4e 61 6d 65 3b 0a 20 20 20 20 20 20 73 74 72  rName;.      str
3480: 69 6e 67 20 73 74 72 54 61 62 6c 65 3b 0a 20 20  ing strTable;.  
3490: 20 20 20 20 73 74 72 69 6e 67 20 73 74 72 43 61      string strCa
34a0: 74 61 6c 6f 67 3b 0a 20 20 20 20 20 20 44 61 74  talog;.      Dat
34b0: 61 52 6f 77 20 72 6f 77 3b 0a 0a 20 20 20 20 20  aRow row;..     
34c0: 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64   tbl.Columns.Add
34d0: 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  (SchemaTableColu
34e0: 6d 6e 2e 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 74  mn.ColumnName, t
34f0: 79 70 65 6f 66 28 53 74 72 69 6e 67 29 29 3b 0a  ypeof(String));.
3500: 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e        tbl.Column
3510: 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62 6c  s.Add(SchemaTabl
3520: 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e 4f 72  eColumn.ColumnOr
3530: 64 69 6e 61 6c 2c 20 74 79 70 65 6f 66 28 49 6e  dinal, typeof(In
3540: 74 33 32 29 29 3b 0a 20 20 20 20 20 20 74 62 6c  t32));.      tbl
3550: 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68  .Columns.Add(Sch
3560: 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 43  emaTableColumn.C
3570: 6f 6c 75 6d 6e 53 69 7a 65 2c 20 74 79 70 65 6f  olumnSize, typeo
3580: 66 28 49 6e 74 33 32 29 29 3b 0a 20 20 20 20 20  f(Int32));.     
3590: 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64   tbl.Columns.Add
35a0: 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  (SchemaTableColu
35b0: 6d 6e 2e 4e 75 6d 65 72 69 63 50 72 65 63 69 73  mn.NumericPrecis
35c0: 69 6f 6e 2c 20 74 79 70 65 6f 66 28 49 6e 74 33  ion, typeof(Int3
35d0: 32 29 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43  2));.      tbl.C
35e0: 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d  olumns.Add(Schem
35f0: 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 4e 75 6d  aTableColumn.Num
3600: 65 72 69 63 53 63 61 6c 65 2c 20 74 79 70 65 6f  ericScale, typeo
3610: 66 28 49 6e 74 33 32 29 29 3b 0a 20 20 20 20 20  f(Int32));.     
3620: 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64   tbl.Columns.Add
3630: 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  (SchemaTableColu
3640: 6d 6e 2e 44 61 74 61 54 79 70 65 2c 20 74 79 70  mn.DataType, typ
3650: 65 6f 66 28 54 79 70 65 29 29 3b 0a 20 20 20 20  eof(Type));.    
3660: 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64    tbl.Columns.Ad
3670: 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  d(SchemaTableCol
3680: 75 6d 6e 2e 50 72 6f 76 69 64 65 72 54 79 70 65  umn.ProviderType
3690: 2c 20 74 79 70 65 6f 66 28 49 6e 74 33 32 29 29  , typeof(Int32))
36a0: 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75  ;.      tbl.Colu
36b0: 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61  mns.Add(SchemaTa
36c0: 62 6c 65 43 6f 6c 75 6d 6e 2e 49 73 4c 6f 6e 67  bleColumn.IsLong
36d0: 2c 20 74 79 70 65 6f 66 28 42 6f 6f 6c 65 61 6e  , typeof(Boolean
36e0: 29 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f  ));.      tbl.Co
36f0: 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61  lumns.Add(Schema
3700: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 41 6c 6c 6f  TableColumn.Allo
3710: 77 44 42 4e 75 6c 6c 2c 20 74 79 70 65 6f 66 28  wDBNull, typeof(
3720: 42 6f 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20  Boolean));.     
3730: 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64   tbl.Columns.Add
3740: 28 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69  (SchemaTableOpti
3750: 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 52 65 61  onalColumn.IsRea
3760: 64 4f 6e 6c 79 2c 20 74 79 70 65 6f 66 28 42 6f  dOnly, typeof(Bo
3770: 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20 74  olean));.      t
3780: 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53  bl.Columns.Add(S
3790: 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e  chemaTableOption
37a0: 61 6c 43 6f 6c 75 6d 6e 2e 49 73 52 6f 77 56 65  alColumn.IsRowVe
37b0: 72 73 69 6f 6e 2c 20 74 79 70 65 6f 66 28 42 6f  rsion, typeof(Bo
37c0: 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20 74  olean));.      t
37d0: 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53  bl.Columns.Add(S
37e0: 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e  chemaTableColumn
37f0: 2e 49 73 55 6e 69 71 75 65 2c 20 74 79 70 65 6f  .IsUnique, typeo
3800: 66 28 42 6f 6f 6c 65 61 6e 29 29 3b 0a 20 20 20  f(Boolean));.   
3810: 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41     tbl.Columns.A
3820: 64 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  dd(SchemaTableCo
3830: 6c 75 6d 6e 2e 49 73 4b 65 79 2c 20 74 79 70 65  lumn.IsKey, type
3840: 6f 66 28 42 6f 6f 6c 65 61 6e 29 29 3b 0a 20 20  of(Boolean));.  
3850: 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e      tbl.Columns.
3860: 41 64 64 28 53 63 68 65 6d 61 54 61 62 6c 65 4f  Add(SchemaTableO
3870: 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73  ptionalColumn.Is
3880: 41 75 74 6f 49 6e 63 72 65 6d 65 6e 74 2c 20 74  AutoIncrement, t
3890: 79 70 65 6f 66 28 42 6f 6f 6c 65 61 6e 29 29 3b  ypeof(Boolean));
38a0: 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d  .      tbl.Colum
38b0: 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62  ns.Add(SchemaTab
38c0: 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65 53 63 68  leColumn.BaseSch
38d0: 65 6d 61 4e 61 6d 65 2c 20 74 79 70 65 6f 66 28  emaName, typeof(
38e0: 53 74 72 69 6e 67 29 29 3b 0a 20 20 20 20 20 20  String));.      
38f0: 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28  tbl.Columns.Add(
3900: 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f  SchemaTableOptio
3910: 6e 61 6c 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 61  nalColumn.BaseCa
3920: 74 61 6c 6f 67 4e 61 6d 65 2c 20 74 79 70 65 6f  talogName, typeo
3930: 66 28 53 74 72 69 6e 67 29 29 3b 0a 20 20 20 20  f(String));.    
3940: 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64    tbl.Columns.Ad
3950: 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  d(SchemaTableCol
3960: 75 6d 6e 2e 42 61 73 65 54 61 62 6c 65 4e 61 6d  umn.BaseTableNam
3970: 65 2c 20 74 79 70 65 6f 66 28 53 74 72 69 6e 67  e, typeof(String
3980: 29 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f  ));.      tbl.Co
3990: 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61  lumns.Add(Schema
39a0: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65  TableColumn.Base
39b0: 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 74 79 70 65  ColumnName, type
39c0: 6f 66 28 53 74 72 69 6e 67 29 29 3b 0a 20 20 20  of(String));.   
39d0: 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41     tbl.Columns.A
39e0: 64 64 28 53 63 68 65 6d 61 54 61 62 6c 65 4f 70  dd(SchemaTableOp
39f0: 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 42 61 73  tionalColumn.Bas
3a00: 65 43 6f 6c 75 6d 6e 4e 61 6d 65 73 70 61 63 65  eColumnNamespace
3a10: 2c 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29  , typeof(string)
3a20: 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c  );.      tbl.Col
3a30: 75 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54  umns.Add(SchemaT
3a40: 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75  ableOptionalColu
3a50: 6d 6e 2e 44 65 66 61 75 6c 74 56 61 6c 75 65 2c  mn.DefaultValue,
3a60: 20 74 79 70 65 6f 66 28 6f 62 6a 65 63 74 29 29   typeof(object))
3a70: 3b 0a 0a 20 20 20 20 20 20 74 62 6c 2e 42 65 67  ;..      tbl.Beg
3a80: 69 6e 4c 6f 61 64 44 61 74 61 28 29 3b 0a 0a 20  inLoadData();.. 
3a90: 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65       SQLiteConne
3aa0: 63 74 69 6f 6e 20 63 6e 6e 20 3d 20 28 53 51 4c  ction cnn = (SQL
3ab0: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 29 5f 63  iteConnection)_c
3ac0: 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f  ommand.Connectio
3ad0: 6e 3b 0a 0a 20 20 20 20 20 20 74 72 79 0a 20 20  n;..      try.  
3ae0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 63 6e      {.        cn
3af0: 6e 2e 5f 73 71 6c 2e 53 65 74 52 65 61 6c 43 6f  n._sql.SetRealCo
3b00: 6c 4e 61 6d 65 73 28 74 72 75 65 29 3b 0a 0a 20  lNames(true);.. 
3b10: 20 20 20 20 20 20 20 2f 2f 20 43 72 65 61 74 65         // Create
3b20: 20 61 20 6e 65 77 20 63 6f 6d 6d 61 6e 64 20 62   a new command b
3b30: 61 73 65 64 20 6f 6e 20 74 68 65 20 6f 72 69 67  ased on the orig
3b40: 69 6e 61 6c 2e 20 20 54 68 65 20 6f 6e 6c 79 20  inal.  The only 
3b50: 64 69 66 66 65 72 65 6e 63 65 20 62 65 69 6e 67  difference being
3b60: 20 74 68 61 74 20 74 68 69 73 20 6e 65 77 20 63   that this new c
3b70: 6f 6d 6d 61 6e 64 20 72 65 74 75 72 6e 73 0a 20  ommand returns. 
3b80: 20 20 20 20 20 20 20 2f 2f 20 66 75 6c 6c 79 2d         // fully-
3b90: 71 75 61 6c 69 66 69 65 64 20 44 61 74 61 62 61  qualified Databa
3ba0: 73 65 2e 54 61 62 6c 65 2e 43 6f 6c 75 6d 6e 20  se.Table.Column 
3bb0: 63 6f 6c 75 6d 6e 20 6e 61 6d 65 73 20 62 65 63  column names bec
3bc0: 61 75 73 65 20 6f 66 20 74 68 65 20 61 62 6f 76  ause of the abov
3bd0: 65 20 70 72 61 67 6d 61 0a 20 20 20 20 20 20 20  e pragma.       
3be0: 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65 43 6f   using (SQLiteCo
3bf0: 6d 6d 61 6e 64 20 63 6d 64 20 3d 20 6e 65 77 20  mmand cmd = new 
3c00: 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 28 5f 61  SQLiteCommand(_a
3c10: 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f  ctiveStatement._
3c20: 73 71 6c 53 74 61 74 65 6d 65 6e 74 2c 20 63 6e  sqlStatement, cn
3c30: 6e 29 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20  n)).        {.  
3c40: 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 44          using (D
3c50: 62 44 61 74 61 52 65 61 64 65 72 20 72 64 20 3d  bDataReader rd =
3c60: 20 63 6d 64 2e 45 78 65 63 75 74 65 52 65 61 64   cmd.ExecuteRead
3c70: 65 72 28 29 29 0a 20 20 20 20 20 20 20 20 20 20  er()).          
3c80: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  {.            //
3c90: 20 4e 6f 20 6e 65 65 64 20 74 6f 20 52 65 61 64   No need to Read
3ca0: 28 29 20 66 72 6f 6d 20 74 68 69 73 20 72 65 61  () from this rea
3cb0: 64 65 72 2c 20 77 65 20 6a 75 73 74 20 77 61 6e  der, we just wan
3cc0: 74 20 74 68 65 20 63 6f 6c 75 6d 6e 20 6e 61 6d  t the column nam
3cd0: 65 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 66  es.            f
3ce0: 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20 6e  or (int n = 0; n
3cf0: 20 3c 20 46 69 65 6c 64 43 6f 75 6e 74 3b 20 6e   < FieldCount; n
3d00: 2b 2b 29 0a 20 20 20 20 20 20 20 20 20 20 20 20  ++).            
3d10: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
3d20: 73 74 72 54 61 62 6c 65 20 3d 20 22 22 3b 0a 20  strTable = "";. 
3d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74 72               str
3d40: 43 61 74 61 6c 6f 67 20 3d 20 22 6d 61 69 6e 22  Catalog = "main"
3d50: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3d60: 20 72 6f 77 20 3d 20 74 62 6c 2e 4e 65 77 52 6f   row = tbl.NewRo
3d70: 77 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20  w();..          
3d80: 20 20 20 20 2f 2f 20 44 65 66 61 75 6c 74 20 73      // Default s
3d90: 65 74 74 69 6e 67 73 20 66 6f 72 20 74 68 65 20  ettings for the 
3da0: 63 6f 6c 75 6d 6e 0a 20 20 20 20 20 20 20 20 20  column.         
3db0: 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54       row[SchemaT
3dc0: 61 62 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d  ableColumn.Colum
3dd0: 6e 4e 61 6d 65 5d 20 3d 20 47 65 74 4e 61 6d 65  nName] = GetName
3de0: 28 6e 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  (n);.           
3df0: 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62     row[SchemaTab
3e00: 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e 4f  leColumn.ColumnO
3e10: 72 64 69 6e 61 6c 5d 20 3d 20 6e 3b 0a 20 20 20  rdinal] = n;.   
3e20: 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53             row[S
3e30: 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e  chemaTableColumn
3e40: 2e 43 6f 6c 75 6d 6e 53 69 7a 65 5d 20 3d 20 30  .ColumnSize] = 0
3e50: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
3e60: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43  row[SchemaTableC
3e70: 6f 6c 75 6d 6e 2e 4e 75 6d 65 72 69 63 50 72 65  olumn.NumericPre
3e80: 63 69 73 69 6f 6e 5d 20 3d 20 30 3b 0a 20 20 20  cision] = 0;.   
3e90: 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53             row[S
3ea0: 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e  chemaTableColumn
3eb0: 2e 4e 75 6d 65 72 69 63 53 63 61 6c 65 5d 20 3d  .NumericScale] =
3ec0: 20 30 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20   0;.            
3ed0: 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c    row[SchemaTabl
3ee0: 65 43 6f 6c 75 6d 6e 2e 44 61 74 61 54 79 70 65  eColumn.DataType
3ef0: 5d 20 3d 20 47 65 74 46 69 65 6c 64 54 79 70 65  ] = GetFieldType
3f00: 28 6e 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  (n);.           
3f10: 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62     row[SchemaTab
3f20: 6c 65 43 6f 6c 75 6d 6e 2e 50 72 6f 76 69 64 65  leColumn.Provide
3f30: 72 54 79 70 65 5d 20 3d 20 47 65 74 53 51 4c 69  rType] = GetSQLi
3f40: 74 65 54 79 70 65 28 6e 29 2e 54 79 70 65 3b 0a  teType(n).Type;.
3f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 6f                ro
3f60: 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  w[SchemaTableCol
3f70: 75 6d 6e 2e 49 73 4c 6f 6e 67 5d 20 3d 20 66 61  umn.IsLong] = fa
3f80: 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20  lse;.           
3f90: 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62     row[SchemaTab
3fa0: 6c 65 43 6f 6c 75 6d 6e 2e 41 6c 6c 6f 77 44 42  leColumn.AllowDB
3fb0: 4e 75 6c 6c 5d 20 3d 20 74 72 75 65 3b 0a 20 20  Null] = true;.  
3fc0: 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b              row[
3fd0: 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f  SchemaTableOptio
3fe0: 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 52 65 61 64  nalColumn.IsRead
3ff0: 4f 6e 6c 79 5d 20 3d 20 74 72 75 65 3b 0a 20 20  Only] = true;.  
4000: 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b              row[
4010: 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f  SchemaTableOptio
4020: 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 52 6f 77 56  nalColumn.IsRowV
4030: 65 72 73 69 6f 6e 5d 20 3d 20 66 61 6c 73 65 3b  ersion] = false;
4040: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72  .              r
4050: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
4060: 6c 75 6d 6e 2e 49 73 55 6e 69 71 75 65 5d 20 3d  lumn.IsUnique] =
4070: 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 20 20   false;.        
4080: 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61        row[Schema
4090: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 49 73 4b 65  TableColumn.IsKe
40a0: 79 5d 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20  y] = false;.    
40b0: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
40c0: 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61  hemaTableOptiona
40d0: 6c 43 6f 6c 75 6d 6e 2e 49 73 41 75 74 6f 49 6e  lColumn.IsAutoIn
40e0: 63 72 65 6d 65 6e 74 5d 20 3d 20 66 61 6c 73 65  crement] = false
40f0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
4100: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 4f  row[SchemaTableO
4110: 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73  ptionalColumn.Is
4120: 52 65 61 64 4f 6e 6c 79 5d 20 3d 20 66 61 6c 73  ReadOnly] = fals
4130: 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  e;.             
4140: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
4150: 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 6f 6c 75 6d  Column.BaseColum
4160: 6e 4e 61 6d 65 5d 20 3d 20 47 65 74 4e 61 6d 65  nName] = GetName
4170: 28 6e 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20  (n);..          
4180: 20 20 20 20 2f 2f 20 54 72 79 20 61 6e 64 20 65      // Try and e
4190: 78 74 72 61 63 74 20 74 68 65 20 64 61 74 61 62  xtract the datab
41a0: 61 73 65 2c 20 74 61 62 6c 65 20 61 6e 64 20 63  ase, table and c
41b0: 6f 6c 75 6d 6e 20 66 72 6f 6d 20 74 68 65 20 64  olumn from the d
41c0: 61 74 61 72 65 61 64 65 72 0a 20 20 20 20 20 20  atareader.      
41d0: 20 20 20 20 20 20 20 20 61 72 4e 61 6d 65 20 3d          arName =
41e0: 20 72 64 2e 47 65 74 4e 61 6d 65 28 6e 29 2e 53   rd.GetName(n).S
41f0: 70 6c 69 74 28 27 2e 27 29 3b 0a 0a 20 20 20 20  plit('.');..    
4200: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 61 72            if (ar
4210: 4e 61 6d 65 2e 4c 65 6e 67 74 68 20 3e 20 31 29  Name.Length > 1)
4220: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4230: 20 73 74 72 54 61 62 6c 65 20 3d 20 61 72 4e 61   strTable = arNa
4240: 6d 65 5b 61 72 4e 61 6d 65 2e 4c 65 6e 67 74 68  me[arName.Length
4250: 20 2d 20 32 5d 3b 0a 0a 20 20 20 20 20 20 20 20   - 2];..        
4260: 20 20 20 20 20 20 69 66 20 28 61 72 4e 61 6d 65        if (arName
4270: 2e 4c 65 6e 67 74 68 20 3e 20 32 29 0a 20 20 20  .Length > 2).   
4280: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74 72               str
4290: 43 61 74 61 6c 6f 67 20 3d 20 61 72 4e 61 6d 65  Catalog = arName
42a0: 5b 61 72 4e 61 6d 65 2e 4c 65 6e 67 74 68 20 2d  [arName.Length -
42b0: 20 33 5d 3b 0a 0a 20 20 20 20 20 20 20 20 20 20   3];..          
42c0: 20 20 20 20 2f 2f 20 49 66 20 77 65 20 68 61 76      // If we hav
42d0: 65 20 61 20 74 61 62 6c 65 2d 62 6f 75 6e 64 20  e a table-bound 
42e0: 63 6f 6c 75 6d 6e 2c 20 65 78 74 72 61 63 74 20  column, extract 
42f0: 74 68 65 20 65 78 74 72 61 20 69 6e 66 6f 72 6d  the extra inform
4300: 61 74 69 6f 6e 20 66 72 6f 6d 20 69 74 0a 20 20  ation from it.  
4310: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
4320: 61 72 4e 61 6d 65 2e 4c 65 6e 67 74 68 20 3e 20  arName.Length > 
4330: 31 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  1).             
4340: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
4350: 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65     using (SQLite
4360: 43 6f 6d 6d 61 6e 64 20 63 6d 64 54 61 62 6c 65  Command cmdTable
4370: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6d   = new SQLiteCom
4380: 6d 61 6e 64 28 53 74 72 69 6e 67 2e 46 6f 72 6d  mand(String.Form
4390: 61 74 28 22 50 52 41 47 4d 41 20 5b 7b 31 7d 5d  at("PRAGMA [{1}]
43a0: 2e 54 41 42 4c 45 5f 49 4e 46 4f 28 5b 7b 30 7d  .TABLE_INFO([{0}
43b0: 5d 29 22 2c 20 73 74 72 54 61 62 6c 65 2c 20 73  ])", strTable, s
43c0: 74 72 43 61 74 61 6c 6f 67 29 2c 20 63 6e 6e 29  trCatalog), cnn)
43d0: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ).              
43e0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
43f0: 20 20 20 20 20 20 69 66 20 28 61 72 4e 61 6d 65        if (arName
4400: 2e 4c 65 6e 67 74 68 20 3c 20 33 29 20 73 74 72  .Length < 3) str
4410: 43 61 74 61 6c 6f 67 20 3d 20 22 22 3b 0a 0a 20  Catalog = "";.. 
4420: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4430: 20 75 73 69 6e 67 20 28 44 62 44 61 74 61 52 65   using (DbDataRe
4440: 61 64 65 72 20 72 64 54 61 62 6c 65 20 3d 20 63  ader rdTable = c
4450: 6d 64 54 61 62 6c 65 2e 45 78 65 63 75 74 65 52  mdTable.ExecuteR
4460: 65 61 64 65 72 28 29 29 0a 20 20 20 20 20 20 20  eader()).       
4470: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
4480: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4490: 20 77 68 69 6c 65 20 28 72 64 54 61 62 6c 65 2e   while (rdTable.
44a0: 52 65 61 64 28 29 29 0a 20 20 20 20 20 20 20 20  Read()).        
44b0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20              {.  
44c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
44d0: 20 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e 43      if (String.C
44e0: 6f 6d 70 61 72 65 28 61 72 4e 61 6d 65 5b 61 72  ompare(arName[ar
44f0: 4e 61 6d 65 2e 4c 65 6e 67 74 68 20 2d 20 31 5d  Name.Length - 1]
4500: 2c 20 72 64 54 61 62 6c 65 2e 47 65 74 53 74 72  , rdTable.GetStr
4510: 69 6e 67 28 31 29 2c 20 74 72 75 65 29 20 3d 3d  ing(1), true) ==
4520: 20 30 29 0a 20 20 20 20 20 20 20 20 20 20 20 20   0).            
4530: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
4540: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4550: 20 20 20 20 73 74 72 69 6e 67 20 73 74 72 54 79      string strTy
4560: 70 65 20 3d 20 72 64 54 61 62 6c 65 2e 47 65 74  pe = rdTable.Get
4570: 53 74 72 69 6e 67 28 32 29 3b 0a 20 20 20 20 20  String(2);.     
4580: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4590: 20 20 20 73 74 72 69 6e 67 5b 5d 20 61 72 53 69     string[] arSi
45a0: 7a 65 20 3d 20 73 74 72 54 79 70 65 2e 53 70 6c  ze = strType.Spl
45b0: 69 74 28 27 28 27 29 3b 0a 20 20 20 20 20 20 20  it('(');.       
45c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
45d0: 20 69 66 20 28 61 72 53 69 7a 65 2e 4c 65 6e 67   if (arSize.Leng
45e0: 74 68 20 3e 20 31 29 0a 20 20 20 20 20 20 20 20  th > 1).        
45f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4600: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
4610: 20 20 20 20 20 20 20 20 20 20 20 20 61 72 53 69              arSi
4620: 7a 65 20 3d 20 61 72 53 69 7a 65 5b 31 5d 2e 53  ze = arSize[1].S
4630: 70 6c 69 74 28 27 29 27 29 3b 0a 20 20 20 20 20  plit(')');.     
4640: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4650: 20 20 20 20 20 69 66 20 28 61 72 53 69 7a 65 2e       if (arSize.
4660: 4c 65 6e 67 74 68 20 3e 20 31 29 0a 20 20 20 20  Length > 1).    
4670: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4680: 20 20 20 20 20 20 20 20 72 6f 77 5b 22 43 6f 6c          row["Col
4690: 75 6d 6e 53 69 7a 65 22 5d 20 3d 20 43 6f 6e 76  umnSize"] = Conv
46a0: 65 72 74 2e 54 6f 49 6e 74 33 32 28 61 72 53 69  ert.ToInt32(arSi
46b0: 7a 65 5b 30 5d 29 3b 0a 20 20 20 20 20 20 20 20  ze[0]);.        
46c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
46d0: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }.              
46e0: 20 20 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 62            bool b
46f0: 4e 6f 74 4e 75 6c 6c 20 3d 20 72 64 54 61 62 6c  NotNull = rdTabl
4700: 65 2e 47 65 74 42 6f 6f 6c 65 61 6e 28 33 29 3b  e.GetBoolean(3);
4710: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4720: 20 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 62 50           bool bP
4730: 72 69 6d 61 72 79 4b 65 79 20 3d 20 72 64 54 61  rimaryKey = rdTa
4740: 62 6c 65 2e 47 65 74 42 6f 6f 6c 65 61 6e 28 35  ble.GetBoolean(5
4750: 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
4760: 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b              row[
4770: 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d  SchemaTableColum
4780: 6e 2e 42 61 73 65 54 61 62 6c 65 4e 61 6d 65 5d  n.BaseTableName]
4790: 20 3d 20 73 74 72 54 61 62 6c 65 3b 0a 20 20 20   = strTable;.   
47a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
47b0: 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54       row[SchemaT
47c0: 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65 43  ableColumn.BaseC
47d0: 6f 6c 75 6d 6e 4e 61 6d 65 5d 20 3d 20 72 64 54  olumnName] = rdT
47e0: 61 62 6c 65 2e 47 65 74 53 74 72 69 6e 67 28 31  able.GetString(1
47f0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
4800: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 73             if (s
4810: 74 72 43 61 74 61 6c 6f 67 2e 4c 65 6e 67 74 68  trCatalog.Length
4820: 20 3e 20 30 29 0a 20 20 20 20 20 20 20 20 20 20   > 0).          
4830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a                {.
4840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4850: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
4860: 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61  hemaTableOptiona
4870: 6c 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 6f 6c 75  lColumn.BaseColu
4880: 6d 6e 4e 61 6d 65 73 70 61 63 65 5d 20 3d 20 73  mnNamespace] = s
4890: 74 72 43 61 74 61 6c 6f 67 3b 0a 20 20 20 20 20  trCatalog;.     
48a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
48b0: 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54       row[SchemaT
48c0: 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65 53  ableColumn.BaseS
48d0: 63 68 65 6d 61 4e 61 6d 65 5d 20 3d 20 73 74 72  chemaName] = str
48e0: 43 61 74 61 6c 6f 67 3b 0a 20 20 20 20 20 20 20  Catalog;.       
48f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4900: 20 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
4910: 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b              row[
4920: 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d  SchemaTableColum
4930: 6e 2e 41 6c 6c 6f 77 44 42 4e 75 6c 6c 5d 20 3d  n.AllowDBNull] =
4940: 20 28 21 62 4e 6f 74 4e 75 6c 6c 20 26 26 20 21   (!bNotNull && !
4950: 62 50 72 69 6d 61 72 79 4b 65 79 29 3b 0a 20 20  bPrimaryKey);.  
4960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4970: 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61        row[Schema
4980: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 49 73 55 6e  TableColumn.IsUn
4990: 69 71 75 65 5d 20 3d 20 62 50 72 69 6d 61 72 79  ique] = bPrimary
49a0: 4b 65 79 3b 0a 20 20 20 20 20 20 20 20 20 20 20  Key;.           
49b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77               row
49c0: 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  [SchemaTableColu
49d0: 6d 6e 2e 49 73 4b 65 79 5d 20 3d 20 62 50 72 69  mn.IsKey] = bPri
49e0: 6d 61 72 79 4b 65 79 3b 0a 20 20 20 20 20 20 20  maryKey;.       
49f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4a00: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
4a10: 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49  OptionalColumn.I
4a20: 73 41 75 74 6f 49 6e 63 72 65 6d 65 6e 74 5d 20  sAutoIncrement] 
4a30: 3d 20 28 62 50 72 69 6d 61 72 79 4b 65 79 20 26  = (bPrimaryKey &
4a40: 26 20 53 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65  & String.Compare
4a50: 28 73 74 72 54 79 70 65 2c 20 22 49 6e 74 65 67  (strType, "Integ
4a60: 65 72 22 2c 20 74 72 75 65 29 20 3d 3d 20 30 29  er", true) == 0)
4a70: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
4a80: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
4a90: 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61  hemaTableOptiona
4aa0: 6c 43 6f 6c 75 6d 6e 2e 49 73 52 65 61 64 4f 6e  lColumn.IsReadOn
4ab0: 6c 79 5d 20 3d 20 21 28 62 6f 6f 6c 29 72 6f 77  ly] = !(bool)row
4ac0: 5b 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69  [SchemaTableOpti
4ad0: 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 41 75 74  onalColumn.IsAut
4ae0: 6f 49 6e 63 72 65 6d 65 6e 74 5d 3b 0a 20 20 20  oIncrement];.   
4af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4b00: 20 20 20 20 20 69 66 20 28 72 64 54 61 62 6c 65       if (rdTable
4b10: 2e 49 73 44 42 4e 75 6c 6c 28 34 29 20 3d 3d 20  .IsDBNull(4) == 
4b20: 66 61 6c 73 65 29 0a 20 20 20 20 20 20 20 20 20  false).         
4b30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4b40: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
4b50: 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 44  OptionalColumn.D
4b60: 65 66 61 75 6c 74 56 61 6c 75 65 5d 20 3d 20 72  efaultValue] = r
4b70: 64 54 61 62 6c 65 5b 34 5d 3b 0a 20 20 20 20 20  dTable[4];.     
4b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4b90: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
4ba0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4bb0: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }.              
4bc0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
4bd0: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
4be0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
4bf0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
4c00: 20 20 20 20 20 20 20 20 20 20 20 20 74 62 6c 2e              tbl.
4c10: 52 6f 77 73 2e 41 64 64 28 72 6f 77 29 3b 0a 20  Rows.Add(row);. 
4c20: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
4c30: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
4c40: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
4c50: 20 63 61 74 63 68 20 28 45 78 63 65 70 74 69 6f   catch (Exceptio
4c60: 6e 20 65 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  n e).      {.   
4c70: 20 20 20 20 20 74 68 72 6f 77 20 28 65 29 3b 0a       throw (e);.
4c80: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 66 69        }.      fi
4c90: 6e 61 6c 6c 79 0a 20 20 20 20 20 20 7b 0a 20 20  nally.      {.  
4ca0: 20 20 20 20 20 20 63 6e 6e 2e 5f 73 71 6c 2e 53        cnn._sql.S
4cb0: 65 74 52 65 61 6c 43 6f 6c 4e 61 6d 65 73 28 66  etRealColNames(f
4cc0: 61 6c 73 65 29 3b 0a 20 20 20 20 20 20 7d 0a 0a  alse);.      }..
4cd0: 20 20 20 20 20 20 74 62 6c 2e 41 63 63 65 70 74        tbl.Accept
4ce0: 43 68 61 6e 67 65 73 28 29 3b 0a 20 20 20 20 20  Changes();.     
4cf0: 20 74 62 6c 2e 45 6e 64 4c 6f 61 64 44 61 74 61   tbl.EndLoadData
4d00: 28 29 3b 0a 0a 20 20 20 20 20 20 72 65 74 75 72  ();..      retur
4d10: 6e 20 74 62 6c 3b 0a 20 20 20 20 7d 0a 0a 20 20  n tbl;.    }..  
4d20: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
4d30: 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f      /// .    ///
4d40: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20   </summary>.    
4d50: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
4d60: 22 6f 72 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61  "ordinal"></para
4d70: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75  m>.    /// <retu
4d80: 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20  rns></returns>. 
4d90: 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69     public overri
4da0: 64 65 20 73 74 72 69 6e 67 20 47 65 74 53 74 72  de string GetStr
4db0: 69 6e 67 28 69 6e 74 20 6f 72 64 69 6e 61 6c 29  ing(int ordinal)
4dc0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 43 68 65  .    {.      Che
4dd0: 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20  ckClosed();.    
4de0: 20 20 56 65 72 69 66 79 54 79 70 65 28 6f 72 64    VerifyType(ord
4df0: 69 6e 61 6c 2c 20 44 62 54 79 70 65 2e 53 74 72  inal, DbType.Str
4e00: 69 6e 67 29 3b 0a 20 20 20 20 20 20 72 65 74 75  ing);.      retu
4e10: 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d  rn _activeStatem
4e20: 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 54 65 78 74  ent._sql.GetText
4e30: 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  (_activeStatemen
4e40: 74 2c 20 6f 72 64 69 6e 61 6c 29 3b 0a 20 20 20  t, ordinal);.   
4e50: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
4e60: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20  mary>.    /// . 
4e70: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
4e80: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
4e90: 20 6e 61 6d 65 3d 22 6f 72 64 69 6e 61 6c 22 3e   name="ordinal">
4ea0: 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f  </param>.    ///
4eb0: 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75   <returns></retu
4ec0: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
4ed0: 6f 76 65 72 72 69 64 65 20 6f 62 6a 65 63 74 20  override object 
4ee0: 47 65 74 56 61 6c 75 65 28 69 6e 74 20 6f 72 64  GetValue(int ord
4ef0: 69 6e 61 6c 29 0a 20 20 20 20 7b 0a 20 20 20 20  inal).    {.    
4f00: 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b    CheckClosed();
4f10: 0a 20 20 20 20 20 20 69 66 20 28 49 73 44 42 4e  .      if (IsDBN
4f20: 75 6c 6c 28 6f 72 64 69 6e 61 6c 29 29 20 72 65  ull(ordinal)) re
4f30: 74 75 72 6e 20 44 42 4e 75 6c 6c 2e 56 61 6c 75  turn DBNull.Valu
4f40: 65 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 47 65  e;..      if (Ge
4f50: 74 46 69 65 6c 64 54 79 70 65 28 6f 72 64 69 6e  tFieldType(ordin
4f60: 61 6c 29 20 3d 3d 20 74 79 70 65 6f 66 28 62 79  al) == typeof(by
4f70: 74 65 5b 5d 29 29 0a 20 20 20 20 20 20 7b 0a 20  te[])).      {. 
4f80: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 28         int n = (
4f90: 69 6e 74 29 47 65 74 42 79 74 65 73 28 6f 72 64  int)GetBytes(ord
4fa0: 69 6e 61 6c 2c 20 30 2c 20 6e 75 6c 6c 2c 20 30  inal, 0, null, 0
4fb0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 62 79  , 0);.        by
4fc0: 74 65 5b 5d 20 62 20 3d 20 6e 65 77 20 62 79 74  te[] b = new byt
4fd0: 65 5b 6e 5d 3b 0a 20 20 20 20 20 20 20 20 47 65  e[n];.        Ge
4fe0: 74 42 79 74 65 73 28 6f 72 64 69 6e 61 6c 2c 20  tBytes(ordinal, 
4ff0: 30 2c 20 62 2c 20 30 2c 20 6e 29 3b 0a 0a 20 20  0, b, 0, n);..  
5000: 20 20 20 20 20 20 72 65 74 75 72 6e 20 62 3b 0a        return b;.
5010: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 72        }..      r
5020: 65 74 75 72 6e 20 43 6f 6e 76 65 72 74 2e 43 68  eturn Convert.Ch
5030: 61 6e 67 65 54 79 70 65 28 5f 61 63 74 69 76 65  angeType(_active
5040: 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47  Statement._sql.G
5050: 65 74 54 65 78 74 28 5f 61 63 74 69 76 65 53 74  etText(_activeSt
5060: 61 74 65 6d 65 6e 74 2c 20 6f 72 64 69 6e 61 6c  atement, ordinal
5070: 29 2c 20 47 65 74 46 69 65 6c 64 54 79 70 65 28  ), GetFieldType(
5080: 6f 72 64 69 6e 61 6c 29 2c 20 6e 75 6c 6c 29 3b  ordinal), null);
5090: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
50a0: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
50b0: 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  / .    /// </sum
50c0: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  mary>.    /// <p
50d0: 61 72 61 6d 20 6e 61 6d 65 3d 22 76 61 6c 75 65  aram name="value
50e0: 73 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20  s"></param>.    
50f0: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72  /// <returns></r
5100: 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c  eturns>.    publ
5110: 69 63 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  ic override int 
5120: 47 65 74 56 61 6c 75 65 73 28 6f 62 6a 65 63 74  GetValues(object
5130: 5b 5d 20 76 61 6c 75 65 73 29 0a 20 20 20 20 7b  [] values).    {
5140: 0a 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73  .      CheckClos
5150: 65 64 28 29 3b 0a 20 20 20 20 20 20 69 6e 74 20  ed();.      int 
5160: 6e 4d 61 78 20 3d 20 46 69 65 6c 64 43 6f 75 6e  nMax = FieldCoun
5170: 74 3b 0a 20 20 20 20 20 20 69 66 20 28 76 61 6c  t;.      if (val
5180: 75 65 73 2e 4c 65 6e 67 74 68 20 3c 20 6e 4d 61  ues.Length < nMa
5190: 78 29 20 6e 4d 61 78 20 3d 20 76 61 6c 75 65 73  x) nMax = values
51a0: 2e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20  .Length;..      
51b0: 66 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20  for (int n = 0; 
51c0: 6e 20 3c 20 6e 4d 61 78 3b 20 6e 2b 2b 29 0a 20  n < nMax; n++). 
51d0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 76       {.        v
51e0: 61 6c 75 65 73 2e 53 65 74 56 61 6c 75 65 28 47  alues.SetValue(G
51f0: 65 74 56 61 6c 75 65 28 6e 29 2c 20 6e 29 3b 0a  etValue(n), n);.
5200: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 72        }..      r
5210: 65 74 75 72 6e 20 6e 4d 61 78 3b 0a 20 20 20 20  eturn nMax;.    
5220: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
5230: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20  ary>.    /// .  
5240: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
5250: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
5260: 72 69 64 65 20 62 6f 6f 6c 20 48 61 73 52 6f 77  ride bool HasRow
5270: 73 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65  s.    {.      ge
5280: 74 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  t.      {.      
5290: 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b    CheckClosed();
52a0: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
52b0: 28 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 21  (_readingState !
52c0: 3d 20 32 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  = 2);.      }.  
52d0: 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75    }..    /// <su
52e0: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a  mmary>.    /// .
52f0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
5300: 79 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76  y>.    public ov
5310: 65 72 72 69 64 65 20 62 6f 6f 6c 20 49 73 43 6c  erride bool IsCl
5320: 6f 73 65 64 0a 20 20 20 20 7b 0a 20 20 20 20 20  osed.    {.     
5330: 20 67 65 74 20 7b 20 72 65 74 75 72 6e 20 28 5f   get { return (_
5340: 63 6f 6d 6d 61 6e 64 20 3d 3d 20 6e 75 6c 6c 29  command == null)
5350: 3b 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  ; }.    }..    /
5360: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20  // <summary>.   
5370: 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c 2f   /// .    /// </
5380: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
5390: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f 72   <param name="or
53a0: 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a  dinal"></param>.
53b0: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
53c0: 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20  ></returns>.    
53d0: 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20  public override 
53e0: 62 6f 6f 6c 20 49 73 44 42 4e 75 6c 6c 28 69 6e  bool IsDBNull(in
53f0: 74 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b  t ordinal).    {
5400: 0a 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73  .      CheckClos
5410: 65 64 28 29 3b 0a 20 20 20 20 20 20 72 65 74 75  ed();.      retu
5420: 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d  rn _activeStatem
5430: 65 6e 74 2e 5f 73 71 6c 2e 49 73 4e 75 6c 6c 28  ent._sql.IsNull(
5440: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
5450: 2c 20 6f 72 64 69 6e 61 6c 29 3b 0a 20 20 20 20  , ordinal);.    
5460: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
5470: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20  ary>.    /// .  
5480: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
5490: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
54a0: 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20  s></returns>.   
54b0: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
54c0: 20 62 6f 6f 6c 20 4e 65 78 74 52 65 73 75 6c 74   bool NextResult
54d0: 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 43  ().    {.      C
54e0: 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 0a 20  heckClosed();.. 
54f0: 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65       SQLiteState
5500: 6d 65 6e 74 20 73 74 6d 74 3b 0a 20 20 20 20 20  ment stmt;.     
5510: 20 69 6e 74 20 66 69 65 6c 64 43 6f 75 6e 74 3b   int fieldCount;
5520: 0a 0a 20 20 20 20 20 20 77 68 69 6c 65 20 28 74  ..      while (t
5530: 72 75 65 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  rue).      {.   
5540: 20 20 20 20 20 5f 72 65 61 64 69 6e 67 53 74 61       _readingSta
5550: 74 65 20 3d 20 32 3b 20 2f 2f 20 48 61 73 52 6f  te = 2; // HasRo
5560: 77 73 28 29 20 72 65 74 75 72 6e 73 20 66 61 6c  ws() returns fal
5570: 73 65 2c 20 52 65 61 64 28 29 20 72 65 74 75 72  se, Read() retur
5580: 6e 73 20 66 61 6c 73 65 0a 0a 20 20 20 20 20 20  ns false..      
5590: 20 20 69 66 20 28 5f 61 63 74 69 76 65 53 74 61    if (_activeSta
55a0: 74 65 6d 65 6e 74 20 21 3d 20 6e 75 6c 6c 29 0a  tement != null).
55b0: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
55c0: 20 20 20 20 2f 2f 20 52 65 73 65 74 20 74 68 65      // Reset the
55d0: 20 70 72 65 76 69 6f 75 73 6c 79 2d 65 78 65 63   previously-exec
55e0: 75 74 65 64 20 63 6f 6d 6d 61 6e 64 0a 20 20 20  uted command.   
55f0: 20 20 20 20 20 20 20 5f 61 63 74 69 76 65 53 74         _activeSt
5600: 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 52 65 73  atement._sql.Res
5610: 65 74 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d  et(_activeStatem
5620: 65 6e 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  ent);..         
5630: 20 2f 2f 20 49 66 20 77 65 27 72 65 20 6f 6e 6c   // If we're onl
5640: 79 20 73 75 70 70 6f 73 65 64 20 74 6f 20 72 65  y supposed to re
5650: 74 75 72 6e 20 61 20 73 69 6e 67 6c 65 20 72 6f  turn a single ro
5660: 77 73 65 74 2c 20 73 74 65 70 20 74 68 72 6f 75  wset, step throu
5670: 67 68 20 61 6c 6c 20 72 65 6d 61 69 6e 69 6e 67  gh all remaining
5680: 20 73 74 61 74 65 6d 65 6e 74 73 20 6f 6e 63 65   statements once
5690: 20 75 6e 74 69 6c 0a 20 20 20 20 20 20 20 20 20   until.         
56a0: 20 2f 2f 20 74 68 65 79 20 61 72 65 20 61 6c 6c   // they are all
56b0: 20 64 6f 6e 65 20 61 6e 64 20 72 65 74 75 72 6e   done and return
56c0: 20 66 61 6c 73 65 20 74 6f 20 69 6e 64 69 63 61   false to indica
56d0: 74 65 20 6e 6f 20 6d 6f 72 65 20 72 65 73 75 6c  te no more resul
56e0: 74 73 65 74 73 20 65 78 69 73 74 2e 0a 20 20 20  tsets exist..   
56f0: 20 20 20 20 20 20 20 69 66 20 28 28 5f 63 6f 6d         if ((_com
5700: 6d 61 6e 64 42 65 68 61 76 69 6f 72 20 26 20 43  mandBehavior & C
5710: 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 2e 53  ommandBehavior.S
5720: 69 6e 67 6c 65 52 65 73 75 6c 74 29 20 21 3d 20  ingleResult) != 
5730: 30 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20  0).          {. 
5740: 20 20 20 20 20 20 20 20 20 20 20 77 68 69 6c 65             while
5750: 20 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65   (_activeStateme
5760: 6e 74 49 6e 64 65 78 20 2b 20 31 20 21 3d 20 5f  ntIndex + 1 != _
5770: 63 6f 6d 6d 61 6e 64 2e 5f 73 74 61 74 65 6d 65  command._stateme
5780: 6e 74 4c 69 73 74 2e 4c 65 6e 67 74 68 29 0a 20  ntList.Length). 
5790: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
57a0: 20 20 20 20 20 20 20 20 20 20 20 5f 61 63 74 69             _acti
57b0: 76 65 53 74 61 74 65 6d 65 6e 74 49 6e 64 65 78  veStatementIndex
57c0: 2b 2b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ++;.            
57d0: 20 20 73 74 6d 74 20 3d 20 5f 63 6f 6d 6d 61 6e    stmt = _comman
57e0: 64 2e 5f 73 74 61 74 65 6d 65 6e 74 4c 69 73 74  d._statementList
57f0: 5b 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  [_activeStatemen
5800: 74 49 6e 64 65 78 5d 3b 0a 20 20 20 20 20 20 20  tIndex];.       
5810: 20 20 20 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c         stmt._sql
5820: 2e 53 74 65 70 28 73 74 6d 74 29 3b 0a 20 20 20  .Step(stmt);.   
5830: 20 20 20 20 20 20 20 20 20 20 20 73 74 6d 74 2e             stmt.
5840: 5f 73 71 6c 2e 52 65 73 65 74 28 73 74 6d 74 29  _sql.Reset(stmt)
5850: 3b 20 2f 2f 20 47 6f 74 74 61 20 72 65 73 65 74  ; // Gotta reset
5860: 20 61 66 74 65 72 20 65 76 65 72 79 20 73 74 65   after every ste
5870: 70 20 74 6f 20 72 65 6c 65 61 73 65 20 61 6e 79  p to release any
5880: 20 6c 6f 63 6b 73 20 61 6e 64 20 73 75 63 68 21   locks and such!
5890: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
58a0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
58b0: 6e 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 20  n false;.       
58c0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 0a     }.        }..
58d0: 20 20 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65          // If we
58e0: 27 76 65 20 72 65 61 63 68 65 64 20 74 68 65 20  've reached the 
58f0: 65 6e 64 20 6f 66 20 74 68 65 20 73 74 61 74 65  end of the state
5900: 6d 65 6e 74 73 2c 20 72 65 74 75 72 6e 20 66 61  ments, return fa
5910: 6c 73 65 2c 20 6e 6f 20 6d 6f 72 65 20 72 65 73  lse, no more res
5920: 75 6c 74 73 65 74 73 0a 20 20 20 20 20 20 20 20  ultsets.        
5930: 69 66 20 28 5f 61 63 74 69 76 65 53 74 61 74 65  if (_activeState
5940: 6d 65 6e 74 49 6e 64 65 78 20 2b 20 31 20 3d 3d  mentIndex + 1 ==
5950: 20 5f 63 6f 6d 6d 61 6e 64 2e 5f 73 74 61 74 65   _command._state
5960: 6d 65 6e 74 4c 69 73 74 2e 4c 65 6e 67 74 68 29  mentList.Length)
5970: 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72  .          retur
5980: 6e 20 66 61 6c 73 65 3b 0a 0a 20 20 20 20 20 20  n false;..      
5990: 20 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65    _activeStateme
59a0: 6e 74 49 6e 64 65 78 2b 2b 3b 0a 0a 20 20 20 20  ntIndex++;..    
59b0: 20 20 20 20 73 74 6d 74 20 3d 20 5f 63 6f 6d 6d      stmt = _comm
59c0: 61 6e 64 2e 5f 73 74 61 74 65 6d 65 6e 74 4c 69  and._statementLi
59d0: 73 74 5b 5f 61 63 74 69 76 65 53 74 61 74 65 6d  st[_activeStatem
59e0: 65 6e 74 49 6e 64 65 78 5d 3b 0a 20 20 20 20 20  entIndex];.     
59f0: 20 20 20 66 69 65 6c 64 43 6f 75 6e 74 20 3d 20     fieldCount = 
5a00: 73 74 6d 74 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e  stmt._sql.Column
5a10: 43 6f 75 6e 74 28 73 74 6d 74 29 3b 0a 0a 20 20  Count(stmt);..  
5a20: 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65 27 72        // If we'r
5a30: 65 20 74 6f 6c 64 20 74 6f 20 67 65 74 20 73 63  e told to get sc
5a40: 68 65 6d 61 20 69 6e 66 6f 72 6d 61 74 69 6f 6e  hema information
5a50: 20 6f 6e 6c 79 2c 20 74 68 65 6e 20 64 6f 6e 27   only, then don'
5a60: 74 20 70 65 72 66 6f 72 6d 20 61 6e 20 69 6e 69  t perform an ini
5a70: 74 69 61 6c 20 73 74 65 70 28 29 20 74 68 72 6f  tial step() thro
5a80: 75 67 68 20 74 68 65 20 72 65 73 75 6c 74 73 65  ugh the resultse
5a90: 74 0a 20 20 20 20 20 20 20 20 69 66 20 28 28 5f  t.        if ((_
5aa0: 63 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 20  commandBehavior 
5ab0: 26 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f  & CommandBehavio
5ac0: 72 2e 53 63 68 65 6d 61 4f 6e 6c 79 29 20 3d 3d  r.SchemaOnly) ==
5ad0: 20 30 20 7c 7c 20 66 69 65 6c 64 43 6f 75 6e 74   0 || fieldCount
5ae0: 20 3d 3d 20 30 29 0a 20 20 20 20 20 20 20 20 7b   == 0).        {
5af0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 73  .          if (s
5b00: 74 6d 74 2e 5f 73 71 6c 2e 53 74 65 70 28 73 74  tmt._sql.Step(st
5b10: 6d 74 29 29 0a 20 20 20 20 20 20 20 20 20 20 7b  mt)).          {
5b20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 5f 72 65  .            _re
5b30: 61 64 69 6e 67 53 74 61 74 65 20 3d 20 2d 31 3b  adingState = -1;
5b40: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
5b50: 20 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28         else if (
5b60: 66 69 65 6c 64 43 6f 75 6e 74 20 3d 3d 20 30 29  fieldCount == 0)
5b70: 20 2f 2f 20 4e 6f 20 72 6f 77 73 20 72 65 74 75   // No rows retu
5b80: 72 6e 65 64 2c 20 69 66 20 66 69 65 6c 64 43 6f  rned, if fieldCo
5b90: 75 6e 74 20 69 73 20 7a 65 72 6f 2c 20 73 6b 69  unt is zero, ski
5ba0: 70 20 74 6f 20 74 68 65 20 6e 65 78 74 20 73 74  p to the next st
5bb0: 61 74 65 6d 65 6e 74 0a 20 20 20 20 20 20 20 20  atement.        
5bc0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
5bd0: 73 74 6d 74 2e 5f 73 71 6c 2e 52 65 73 65 74 28  stmt._sql.Reset(
5be0: 73 74 6d 74 29 3b 0a 20 20 20 20 20 20 20 20 20  stmt);.         
5bf0: 20 20 20 63 6f 6e 74 69 6e 75 65 3b 20 2f 2f 20     continue; // 
5c00: 53 6b 69 70 20 74 68 69 73 20 63 6f 6d 6d 61 6e  Skip this comman
5c10: 64 20 61 6e 64 20 6d 6f 76 65 20 74 6f 20 74 68  d and move to th
5c20: 65 20 6e 65 78 74 2c 20 69 74 20 77 61 73 20 6e  e next, it was n
5c30: 6f 74 20 61 20 72 6f 77 2d 72 65 74 75 72 6e 69  ot a row-returni
5c40: 6e 67 20 72 65 73 75 6c 74 73 65 74 0a 20 20 20  ng resultset.   
5c50: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
5c60: 20 20 20 65 6c 73 65 20 2f 2f 20 4e 6f 20 72 6f     else // No ro
5c70: 77 73 2c 20 66 69 65 6c 64 43 6f 75 6e 74 20 69  ws, fieldCount i
5c80: 73 20 6e 6f 6e 2d 7a 65 72 6f 20 73 6f 20 73 74  s non-zero so st
5c90: 6f 70 20 68 65 72 65 0a 20 20 20 20 20 20 20 20  op here.        
5ca0: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
5cb0: 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 3d 20  _readingState = 
5cc0: 31 3b 20 2f 2f 20 54 68 69 73 20 63 6f 6d 6d 61  1; // This comma
5cd0: 6e 64 20 72 65 74 75 72 6e 65 64 20 63 6f 6c 75  nd returned colu
5ce0: 6d 6e 73 20 62 75 74 20 6e 6f 20 72 6f 77 73 2c  mns but no rows,
5cf0: 20 73 6f 20 72 65 74 75 72 6e 20 74 72 75 65 2c   so return true,
5d00: 20 62 75 74 20 48 61 73 52 6f 77 73 20 3d 20 66   but HasRows = f
5d10: 61 6c 73 65 20 61 6e 64 20 52 65 61 64 28 29 20  alse and Read() 
5d20: 72 65 74 75 72 6e 73 20 66 61 6c 73 65 0a 20 20  returns false.  
5d30: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
5d40: 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20    }..        // 
5d50: 41 68 68 2c 20 77 65 20 66 6f 75 6e 64 20 61 20  Ahh, we found a 
5d60: 72 6f 77 2d 72 65 74 75 72 6e 69 6e 67 20 72 65  row-returning re
5d70: 73 75 6c 74 73 65 74 20 65 6c 69 67 69 62 6c 65  sultset eligible
5d80: 20 74 6f 20 62 65 20 72 65 74 75 72 6e 65 64 21   to be returned!
5d90: 0a 20 20 20 20 20 20 20 20 5f 61 63 74 69 76 65  .        _active
5da0: 53 74 61 74 65 6d 65 6e 74 20 3d 20 73 74 6d 74  Statement = stmt
5db0: 3b 0a 20 20 20 20 20 20 20 20 5f 66 69 65 6c 64  ;.        _field
5dc0: 43 6f 75 6e 74 20 3d 20 66 69 65 6c 64 43 6f 75  Count = fieldCou
5dd0: 6e 74 3b 0a 20 20 20 20 20 20 20 20 5f 66 69 65  nt;.        _fie
5de0: 6c 64 54 79 70 65 41 72 72 61 79 20 3d 20 6e 75  ldTypeArray = nu
5df0: 6c 6c 3b 0a 0a 20 20 20 20 20 20 20 20 72 65 74  ll;..        ret
5e00: 75 72 6e 20 74 72 75 65 3b 0a 20 20 20 20 20 20  urn true;.      
5e10: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70 72 69  }.    }..    pri
5e20: 76 61 74 65 20 53 51 4c 69 74 65 54 79 70 65 20  vate SQLiteType 
5e30: 47 65 74 53 51 4c 69 74 65 54 79 70 65 28 69 6e  GetSQLiteType(in
5e40: 74 20 6f 72 64 69 6e 61 6c 29 0a 20 20 20 20 7b  t ordinal).    {
5e50: 0a 20 20 20 20 20 20 69 66 20 28 5f 66 69 65 6c  .      if (_fiel
5e60: 64 54 79 70 65 41 72 72 61 79 20 3d 3d 20 6e 75  dTypeArray == nu
5e70: 6c 6c 29 20 5f 66 69 65 6c 64 54 79 70 65 41 72  ll) _fieldTypeAr
5e80: 72 61 79 20 3d 20 6e 65 77 20 53 51 4c 69 74 65  ray = new SQLite
5e90: 54 79 70 65 5b 5f 66 69 65 6c 64 43 6f 75 6e 74  Type[_fieldCount
5ea0: 5d 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 5f 66  ];..      if (_f
5eb0: 69 65 6c 64 54 79 70 65 41 72 72 61 79 5b 6f 72  ieldTypeArray[or
5ec0: 64 69 6e 61 6c 5d 2e 41 66 66 69 6e 69 74 79 20  dinal].Affinity 
5ed0: 3d 3d 20 30 29 0a 20 20 20 20 20 20 20 20 5f 66  == 0).        _f
5ee0: 69 65 6c 64 54 79 70 65 41 72 72 61 79 5b 6f 72  ieldTypeArray[or
5ef0: 64 69 6e 61 6c 5d 2e 54 79 70 65 20 3d 20 53 51  dinal].Type = SQ
5f00: 4c 69 74 65 43 6f 6e 76 65 72 74 2e 54 79 70 65  LiteConvert.Type
5f10: 4e 61 6d 65 54 6f 44 62 54 79 70 65 28 5f 61 63  NameToDbType(_ac
5f20: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73  tiveStatement._s
5f30: 71 6c 2e 43 6f 6c 75 6d 6e 54 79 70 65 28 5f 61  ql.ColumnType(_a
5f40: 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2c 20  ctiveStatement, 
5f50: 6f 72 64 69 6e 61 6c 2c 20 6f 75 74 20 5f 66 69  ordinal, out _fi
5f60: 65 6c 64 54 79 70 65 41 72 72 61 79 5b 6f 72 64  eldTypeArray[ord
5f70: 69 6e 61 6c 5d 2e 41 66 66 69 6e 69 74 79 29 29  inal].Affinity))
5f80: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f  ;.      return _
5f90: 66 69 65 6c 64 54 79 70 65 41 72 72 61 79 5b 6f  fieldTypeArray[o
5fa0: 72 64 69 6e 61 6c 5d 3b 0a 20 20 20 20 7d 0a 0a  rdinal];.    }..
5fb0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
5fc0: 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20 2f  >.    /// .    /
5fd0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20  // </summary>.  
5fe0: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c    /// <returns><
5ff0: 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75  /returns>.    pu
6000: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62 6f  blic override bo
6010: 6f 6c 20 52 65 61 64 28 29 0a 20 20 20 20 7b 0a  ol Read().    {.
6020: 20 20 20 20 20 20 43 68 65 63 6b 43 6c 6f 73 65        CheckClose
6030: 64 28 29 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  d();..      if (
6040: 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 3d 3d  _readingState ==
6050: 20 2d 31 29 20 2f 2f 20 46 69 72 73 74 20 73 74   -1) // First st
6060: 65 70 20 77 61 73 20 61 6c 72 65 61 64 79 20 64  ep was already d
6070: 6f 6e 65 20 61 74 20 74 68 65 20 4e 65 78 74 52  one at the NextR
6080: 65 73 75 6c 74 28 29 20 6c 65 76 65 6c 2c 20 73  esult() level, s
6090: 6f 20 64 6f 6e 27 74 20 73 74 65 70 20 61 67 61  o don't step aga
60a0: 69 6e 2c 20 6a 75 73 74 20 72 65 74 75 72 6e 20  in, just return 
60b0: 74 72 75 65 2e 0a 20 20 20 20 20 20 7b 0a 20 20  true..      {.  
60c0: 20 20 20 20 20 20 5f 72 65 61 64 69 6e 67 53 74        _readingSt
60d0: 61 74 65 20 3d 20 30 3b 0a 20 20 20 20 20 20 20  ate = 0;.       
60e0: 20 72 65 74 75 72 6e 20 74 72 75 65 3b 0a 20 20   return true;.  
60f0: 20 20 20 20 7d 0a 20 20 20 20 20 20 65 6c 73 65      }.      else
6100: 20 69 66 20 28 5f 72 65 61 64 69 6e 67 53 74 61   if (_readingSta
6110: 74 65 20 3d 3d 20 30 29 20 2f 2f 20 41 63 74 69  te == 0) // Acti
6120: 76 65 6c 79 20 72 65 61 64 69 6e 67 20 72 6f 77  vely reading row
6130: 73 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  s.      {.      
6140: 20 20 69 66 20 28 5f 61 63 74 69 76 65 53 74 61    if (_activeSta
6150: 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 53 74 65 70  tement._sql.Step
6160: 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  (_activeStatemen
6170: 74 29 20 3d 3d 20 74 72 75 65 29 0a 20 20 20 20  t) == true).    
6180: 20 20 20 20 20 20 72 65 74 75 72 6e 20 74 72 75        return tru
6190: 65 3b 0a 0a 20 20 20 20 20 20 20 20 5f 72 65 61  e;..        _rea
61a0: 64 69 6e 67 53 74 61 74 65 20 3d 20 31 3b 20 2f  dingState = 1; /
61b0: 2f 20 46 69 6e 69 73 68 65 64 20 72 65 61 64 69  / Finished readi
61c0: 6e 67 20 72 6f 77 73 0a 20 20 20 20 20 20 7d 0a  ng rows.      }.
61d0: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 66 61  .      return fa
61e0: 6c 73 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  lse;.    }..    
61f0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20  /// <summary>.  
6200: 20 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c    /// .    /// <
6210: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 75  /summary>.    pu
6220: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 69 6e  blic override in
6230: 74 20 52 65 63 6f 72 64 73 41 66 66 65 63 74 65  t RecordsAffecte
6240: 64 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65  d.    {.      ge
6250: 74 20 7b 20 72 65 74 75 72 6e 20 5f 72 6f 77 73  t { return _rows
6260: 41 66 66 65 63 74 65 64 3b 20 7d 0a 20 20 20 20  Affected; }.    
6270: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
6280: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20  ary>.    /// .  
6290: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
62a0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
62b0: 6e 61 6d 65 3d 22 6e 61 6d 65 22 3e 3c 2f 70 61  name="name"></pa
62c0: 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ram>.    /// <re
62d0: 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e  turns></returns>
62e0: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
62f0: 72 69 64 65 20 6f 62 6a 65 63 74 20 74 68 69 73  ride object this
6300: 5b 73 74 72 69 6e 67 20 6e 61 6d 65 5d 0a 20 20  [string name].  
6310: 20 20 7b 0a 20 20 20 20 20 20 67 65 74 20 7b 20    {.      get { 
6320: 72 65 74 75 72 6e 20 47 65 74 56 61 6c 75 65 28  return GetValue(
6330: 47 65 74 4f 72 64 69 6e 61 6c 28 6e 61 6d 65 29  GetOrdinal(name)
6340: 29 3b 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ); }.    }..    
6350: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20  /// <summary>.  
6360: 20 20 2f 2f 2f 20 0a 20 20 20 20 2f 2f 2f 20 3c    /// .    /// <
6370: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  /summary>.    //
6380: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6f  / <param name="o
6390: 72 64 69 6e 61 6c 22 3e 3c 2f 70 61 72 61 6d 3e  rdinal"></param>
63a0: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
63b0: 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20  s></returns>.   
63c0: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
63d0: 20 6f 62 6a 65 63 74 20 74 68 69 73 5b 69 6e 74   object this[int
63e0: 20 6f 72 64 69 6e 61 6c 5d 0a 20 20 20 20 7b 0a   ordinal].    {.
63f0: 20 20 20 20 20 20 67 65 74 20 7b 20 72 65 74 75        get { retu
6400: 72 6e 20 47 65 74 56 61 6c 75 65 28 6f 72 64 69  rn GetValue(ordi
6410: 6e 61 6c 29 3b 20 7d 0a 20 20 20 20 7d 0a 20 20  nal); }.    }.  
6420: 7d 0a 7d 0a                                      }.}.