System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact db39b97a886fd5b40ce86963da1477c62688a1e8:


0000: 2f 2a 2a 2a 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 0a 20 2a 20 41 44 4f  *********. * ADO
0040: 2e 4e 45 54 20 32 2e 30 20 44 61 74 61 20 50 72  .NET 2.0 Data Pr
0050: 6f 76 69 64 65 72 20 66 6f 72 20 53 51 4c 69 74  ovider for SQLit
0060: 65 20 56 65 72 73 69 6f 6e 20 33 2e 58 0a 20 2a  e Version 3.X. *
0070: 20 57 72 69 74 74 65 6e 20 62 79 20 52 6f 62 65   Written by Robe
0080: 72 74 20 53 69 6d 70 73 6f 6e 20 28 72 6f 62 65  rt Simpson (robe
0090: 72 74 40 62 6c 61 63 6b 63 61 73 74 6c 65 73 6f  rt@blackcastleso
00a0: 66 74 2e 63 6f 6d 29 0a 20 2a 20 0a 20 2a 20 52  ft.com). * . * R
00b0: 65 6c 65 61 73 65 64 20 74 6f 20 74 68 65 20 70  eleased to the p
00c0: 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c 20 75 73  ublic domain, us
00d0: 65 20 61 74 20 79 6f 75 72 20 6f 77 6e 20 72 69  e at your own ri
00e0: 73 6b 21 0a 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  sk!. ***********
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 2f 0a 0a  *************/..
0120: 6e 61 6d 65 73 70 61 63 65 20 53 79 73 74 65 6d  namespace System
0130: 2e 44 61 74 61 2e 53 51 4c 69 74 65 0a 7b 0a 20  .Data.SQLite.{. 
0140: 20 75 73 69 6e 67 20 53 79 73 74 65 6d 3b 0a 20   using System;. 
0150: 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 61   using System.Da
0160: 74 61 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74  ta;.  using Syst
0170: 65 6d 2e 44 61 74 61 2e 43 6f 6d 6d 6f 6e 3b 0a  em.Data.Common;.
0180: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 43    using System.C
0190: 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47 65 6e 65 72  ollections.Gener
01a0: 69 63 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74  ic;.  using Syst
01b0: 65 6d 2e 47 6c 6f 62 61 6c 69 7a 61 74 69 6f 6e  em.Globalization
01c0: 3b 0a 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  ;..  /// <summar
01d0: 79 3e 0a 20 20 2f 2f 2f 20 54 68 69 73 20 63 6c  y>.  /// This cl
01e0: 61 73 73 20 70 72 6f 76 69 64 65 73 20 6b 65 79  ass provides key
01f0: 20 69 6e 66 6f 20 66 6f 72 20 61 20 67 69 76 65   info for a give
0200: 6e 20 53 51 4c 69 74 65 20 73 74 61 74 65 6d 65  n SQLite stateme
0210: 6e 74 2e 0a 20 20 2f 2f 2f 20 3c 72 65 6d 61 72  nt..  /// <remar
0220: 6b 73 3e 0a 20 20 2f 2f 2f 20 50 72 6f 76 69 64  ks>.  /// Provid
0230: 69 6e 67 20 6b 65 79 20 69 6e 66 6f 72 6d 61 74  ing key informat
0240: 69 6f 6e 20 66 6f 72 20 61 20 67 69 76 65 6e 20  ion for a given 
0250: 73 74 61 74 65 6d 65 6e 74 20 69 73 20 6e 6f 6e  statement is non
0260: 2d 74 72 69 76 69 61 6c 20 3a 28 0a 20 20 2f 2f  -trivial :(.  //
0270: 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e 0a 20 20 2f  / </remarks>.  /
0280: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20  // </summary>.  
0290: 69 6e 74 65 72 6e 61 6c 20 73 65 61 6c 65 64 20  internal sealed 
02a0: 63 6c 61 73 73 20 53 51 4c 69 74 65 4b 65 79 52  class SQLiteKeyR
02b0: 65 61 64 65 72 20 3a 20 49 44 69 73 70 6f 73 61  eader : IDisposa
02c0: 62 6c 65 0a 20 20 7b 0a 20 20 20 20 70 72 69 76  ble.  {.    priv
02d0: 61 74 65 20 4b 65 79 49 6e 66 6f 5b 5d 20 5f 6b  ate KeyInfo[] _k
02e0: 65 79 49 6e 66 6f 3b 0a 20 20 20 20 70 72 69 76  eyInfo;.    priv
02f0: 61 74 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d  ate SQLiteStatem
0300: 65 6e 74 20 5f 73 74 6d 74 3b 0a 20 20 20 20 70  ent _stmt;.    p
0310: 72 69 76 61 74 65 20 62 6f 6f 6c 20 5f 69 73 56  rivate bool _isV
0320: 61 6c 69 64 3b 0a 0a 20 20 20 20 2f 2f 2f 20 3c  alid;..    /// <
0330: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
0340: 20 55 73 65 64 20 74 6f 20 73 75 70 70 6f 72 74   Used to support
0350: 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72   CommandBehavior
0360: 2e 4b 65 79 49 6e 66 6f 0a 20 20 20 20 2f 2f 2f  .KeyInfo.    ///
0370: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20   </summary>.    
0380: 70 72 69 76 61 74 65 20 73 74 72 75 63 74 20 4b  private struct K
0390: 65 79 49 6e 66 6f 0a 20 20 20 20 7b 0a 20 20 20  eyInfo.    {.   
03a0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 72 69     internal stri
03b0: 6e 67 20 64 61 74 61 62 61 73 65 4e 61 6d 65 3b  ng databaseName;
03c0: 0a 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  .      internal 
03d0: 73 74 72 69 6e 67 20 74 61 62 6c 65 4e 61 6d 65  string tableName
03e0: 3b 0a 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c  ;.      internal
03f0: 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 4e 61   string columnNa
0400: 6d 65 3b 0a 20 20 20 20 20 20 69 6e 74 65 72 6e  me;.      intern
0410: 61 6c 20 69 6e 74 20 64 61 74 61 62 61 73 65 3b  al int database;
0420: 0a 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  .      internal 
0430: 69 6e 74 20 72 6f 6f 74 50 61 67 65 3b 0a 20 20  int rootPage;.  
0440: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 69 6e 74      internal int
0450: 20 63 75 72 73 6f 72 3b 0a 20 20 20 20 20 20 69   cursor;.      i
0460: 6e 74 65 72 6e 61 6c 20 4b 65 79 51 75 65 72 79  nternal KeyQuery
0470: 20 71 75 65 72 79 3b 0a 20 20 20 20 20 20 69 6e   query;.      in
0480: 74 65 72 6e 61 6c 20 69 6e 74 20 63 6f 6c 75 6d  ternal int colum
0490: 6e 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f  n;.    }..    //
04a0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
04b0: 2f 2f 2f 20 41 20 73 69 6e 67 6c 65 20 73 75 62  /// A single sub
04c0: 2d 71 75 65 72 79 20 66 6f 72 20 61 20 67 69 76  -query for a giv
04d0: 65 6e 20 74 61 62 6c 65 2f 64 61 74 61 62 61 73  en table/databas
04e0: 65 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  e..    /// </sum
04f0: 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74  mary>.    privat
0500: 65 20 73 65 61 6c 65 64 20 63 6c 61 73 73 20 4b  e sealed class K
0510: 65 79 51 75 65 72 79 20 3a 20 49 44 69 73 70 6f  eyQuery : IDispo
0520: 73 61 62 6c 65 0a 20 20 20 20 7b 0a 20 20 20 20  sable.    {.    
0530: 20 20 70 72 69 76 61 74 65 20 53 51 4c 69 74 65    private SQLite
0540: 43 6f 6d 6d 61 6e 64 20 5f 63 6f 6d 6d 61 6e 64  Command _command
0550: 3b 0a 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c  ;.      internal
0560: 20 53 51 4c 69 74 65 44 61 74 61 52 65 61 64 65   SQLiteDataReade
0570: 72 20 5f 72 65 61 64 65 72 3b 0a 0a 20 20 20 20  r _reader;..    
0580: 20 20 69 6e 74 65 72 6e 61 6c 20 4b 65 79 51 75    internal KeyQu
0590: 65 72 79 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63  ery(SQLiteConnec
05a0: 74 69 6f 6e 20 63 6e 6e 2c 20 73 74 72 69 6e 67  tion cnn, string
05b0: 20 64 61 74 61 62 61 73 65 2c 20 73 74 72 69 6e   database, strin
05c0: 67 20 74 61 62 6c 65 2c 20 70 61 72 61 6d 73 20  g table, params 
05d0: 73 74 72 69 6e 67 5b 5d 20 63 6f 6c 75 6d 6e 73  string[] columns
05e0: 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  ).      {.      
05f0: 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65 43    using (SQLiteC
0600: 6f 6d 6d 61 6e 64 42 75 69 6c 64 65 72 20 62 75  ommandBuilder bu
0610: 69 6c 64 65 72 20 3d 20 6e 65 77 20 53 51 4c 69  ilder = new SQLi
0620: 74 65 43 6f 6d 6d 61 6e 64 42 75 69 6c 64 65 72  teCommandBuilder
0630: 28 29 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20  ()).        {.  
0640: 20 20 20 20 20 20 20 20 5f 63 6f 6d 6d 61 6e 64          _command
0650: 20 3d 20 63 6e 6e 2e 43 72 65 61 74 65 43 6f 6d   = cnn.CreateCom
0660: 6d 61 6e 64 28 29 3b 0a 20 20 20 20 20 20 20 20  mand();.        
0670: 20 20 66 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30    for (int n = 0
0680: 3b 20 6e 20 3c 20 63 6f 6c 75 6d 6e 73 2e 4c 65  ; n < columns.Le
0690: 6e 67 74 68 3b 20 6e 2b 2b 29 0a 20 20 20 20 20  ngth; n++).     
06a0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
06b0: 20 20 20 63 6f 6c 75 6d 6e 73 5b 6e 5d 20 3d 20     columns[n] = 
06c0: 62 75 69 6c 64 65 72 2e 51 75 6f 74 65 49 64 65  builder.QuoteIde
06d0: 6e 74 69 66 69 65 72 28 63 6f 6c 75 6d 6e 73 5b  ntifier(columns[
06e0: 6e 5d 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  n]);.          }
06f0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
0700: 20 20 20 5f 63 6f 6d 6d 61 6e 64 2e 43 6f 6d 6d     _command.Comm
0710: 61 6e 64 54 65 78 74 20 3d 20 53 74 72 69 6e 67  andText = String
0720: 2e 46 6f 72 6d 61 74 28 43 75 6c 74 75 72 65 49  .Format(CultureI
0730: 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c  nfo.InvariantCul
0740: 74 75 72 65 2c 20 22 53 45 4c 45 43 54 20 7b 30  ture, "SELECT {0
0750: 7d 20 46 52 4f 4d 20 5b 7b 31 7d 5d 2e 5b 7b 32  } FROM [{1}].[{2
0760: 7d 5d 20 57 48 45 52 45 20 52 4f 57 49 44 20 3d  }] WHERE ROWID =
0770: 20 3f 22 2c 20 53 74 72 69 6e 67 2e 4a 6f 69 6e   ?", String.Join
0780: 28 22 2c 22 2c 20 63 6f 6c 75 6d 6e 73 29 2c 20  (",", columns), 
0790: 64 61 74 61 62 61 73 65 2c 20 74 61 62 6c 65 29  database, table)
07a0: 3b 0a 20 20 20 20 20 20 20 20 5f 63 6f 6d 6d 61  ;.        _comma
07b0: 6e 64 2e 50 61 72 61 6d 65 74 65 72 73 2e 41 64  nd.Parameters.Ad
07c0: 64 57 69 74 68 56 61 6c 75 65 28 6e 75 6c 6c 2c  dWithValue(null,
07d0: 20 28 6c 6f 6e 67 29 30 29 3b 0a 20 20 20 20 20   (long)0);.     
07e0: 20 7d 0a 0a 20 20 20 20 20 20 69 6e 74 65 72 6e   }..      intern
07f0: 61 6c 20 62 6f 6f 6c 20 49 73 56 61 6c 69 64 0a  al bool IsValid.
0800: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
0810: 73 65 74 0a 20 20 20 20 20 20 20 20 7b 0a 20 20  set.        {.  
0820: 20 20 20 20 20 20 20 20 69 66 20 28 76 61 6c 75          if (valu
0830: 65 20 21 3d 20 66 61 6c 73 65 29 20 74 68 72 6f  e != false) thro
0840: 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 45 78  w new ArgumentEx
0850: 63 65 70 74 69 6f 6e 28 29 3b 0a 20 20 20 20 20  ception();.     
0860: 20 20 20 20 20 69 66 20 28 5f 72 65 61 64 65 72       if (_reader
0870: 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20   != null).      
0880: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
0890: 20 20 5f 72 65 61 64 65 72 2e 44 69 73 70 6f 73    _reader.Dispos
08a0: 65 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  e();.           
08b0: 20 5f 72 65 61 64 65 72 20 3d 20 6e 75 6c 6c 3b   _reader = null;
08c0: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
08d0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 0a       }.      }..
08e0: 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 76        internal v
08f0: 6f 69 64 20 53 79 6e 63 28 6c 6f 6e 67 20 72 6f  oid Sync(long ro
0900: 77 69 64 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  wid).      {.   
0910: 20 20 20 20 20 49 73 56 61 6c 69 64 20 3d 20 66       IsValid = f
0920: 61 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 5f 63  alse;.        _c
0930: 6f 6d 6d 61 6e 64 2e 50 61 72 61 6d 65 74 65 72  ommand.Parameter
0940: 73 5b 30 5d 2e 56 61 6c 75 65 20 3d 20 72 6f 77  s[0].Value = row
0950: 69 64 3b 0a 20 20 20 20 20 20 20 20 5f 72 65 61  id;.        _rea
0960: 64 65 72 20 3d 20 5f 63 6f 6d 6d 61 6e 64 2e 45  der = _command.E
0970: 78 65 63 75 74 65 52 65 61 64 65 72 28 29 3b 0a  xecuteReader();.
0980: 20 20 20 20 20 20 20 20 5f 72 65 61 64 65 72 2e          _reader.
0990: 52 65 61 64 28 29 3b 0a 20 20 20 20 20 20 7d 0a  Read();.      }.
09a0: 0a 20 20 20 20 20 20 70 75 62 6c 69 63 20 76 6f  .      public vo
09b0: 69 64 20 44 69 73 70 6f 73 65 28 29 0a 20 20 20  id Dispose().   
09c0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 49 73 56     {.        IsV
09d0: 61 6c 69 64 20 3d 20 66 61 6c 73 65 3b 0a 0a 20  alid = false;.. 
09e0: 20 20 20 20 20 20 20 69 66 20 28 5f 63 6f 6d 6d         if (_comm
09f0: 61 6e 64 20 21 3d 20 6e 75 6c 6c 29 20 5f 63 6f  and != null) _co
0a00: 6d 6d 61 6e 64 2e 44 69 73 70 6f 73 65 28 29 3b  mmand.Dispose();
0a10: 0a 20 20 20 20 20 20 20 20 5f 63 6f 6d 6d 61 6e  .        _comman
0a20: 64 20 3d 20 6e 75 6c 6c 3b 0a 20 20 20 20 20 20  d = null;.      
0a30: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f  }.    }..    ///
0a40: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
0a50: 2f 2f 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e  // This function
0a60: 20 64 6f 65 73 20 61 6c 6c 20 74 68 65 20 6e 61   does all the na
0a70: 73 74 79 20 77 6f 72 6b 20 61 74 20 64 65 74 65  sty work at dete
0a80: 72 6d 69 6e 69 6e 67 20 77 68 61 74 20 6b 65 79  rmining what key
0a90: 73 20 6e 65 65 64 20 74 6f 20 62 65 20 72 65 74  s need to be ret
0aa0: 75 72 6e 65 64 20 66 6f 72 0a 20 20 20 20 2f 2f  urned for.    //
0ab0: 2f 20 61 20 67 69 76 65 6e 20 73 74 61 74 65 6d  / a given statem
0ac0: 65 6e 74 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ent..    /// </s
0ad0: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
0ae0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 63 6e 6e  <param name="cnn
0af0: 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  "></param>.    /
0b00: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
0b10: 72 65 61 64 65 72 22 3e 3c 2f 70 61 72 61 6d 3e  reader"></param>
0b20: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
0b30: 6e 61 6d 65 3d 22 73 74 6d 74 22 3e 3c 2f 70 61  name="stmt"></pa
0b40: 72 61 6d 3e 0a 20 20 20 20 69 6e 74 65 72 6e 61  ram>.    interna
0b50: 6c 20 53 51 4c 69 74 65 4b 65 79 52 65 61 64 65  l SQLiteKeyReade
0b60: 72 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  r(SQLiteConnecti
0b70: 6f 6e 20 63 6e 6e 2c 20 53 51 4c 69 74 65 44 61  on cnn, SQLiteDa
0b80: 74 61 52 65 61 64 65 72 20 72 65 61 64 65 72 2c  taReader reader,
0b90: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
0ba0: 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20   stmt).    {.   
0bb0: 20 20 20 44 69 63 74 69 6f 6e 61 72 79 3c 73 74     Dictionary<st
0bc0: 72 69 6e 67 2c 20 69 6e 74 3e 20 63 61 74 61 6c  ring, int> catal
0bd0: 6f 67 73 20 3d 20 6e 65 77 20 44 69 63 74 69 6f  ogs = new Dictio
0be0: 6e 61 72 79 3c 73 74 72 69 6e 67 2c 20 69 6e 74  nary<string, int
0bf0: 3e 28 29 3b 0a 20 20 20 20 20 20 44 69 63 74 69  >();.      Dicti
0c00: 6f 6e 61 72 79 3c 73 74 72 69 6e 67 2c 20 4c 69  onary<string, Li
0c10: 73 74 3c 73 74 72 69 6e 67 3e 3e 20 74 61 62 6c  st<string>> tabl
0c20: 65 73 20 3d 20 6e 65 77 20 44 69 63 74 69 6f 6e  es = new Diction
0c30: 61 72 79 3c 73 74 72 69 6e 67 2c 20 4c 69 73 74  ary<string, List
0c40: 3c 73 74 72 69 6e 67 3e 3e 28 29 3b 0a 20 20 20  <string>>();.   
0c50: 20 20 20 4c 69 73 74 3c 73 74 72 69 6e 67 3e 20     List<string> 
0c60: 6c 69 73 74 3b 0a 20 20 20 20 20 20 4c 69 73 74  list;.      List
0c70: 3c 4b 65 79 49 6e 66 6f 3e 20 6b 65 79 73 20 3d  <KeyInfo> keys =
0c80: 20 6e 65 77 20 4c 69 73 74 3c 4b 65 79 49 6e 66   new List<KeyInf
0c90: 6f 3e 28 29 3b 0a 0a 20 20 20 20 20 20 2f 2f 20  o>();..      // 
0ca0: 52 65 63 6f 72 64 20 74 68 65 20 73 74 61 74 65  Record the state
0cb0: 6d 65 6e 74 20 73 6f 20 77 65 20 63 61 6e 20 75  ment so we can u
0cc0: 73 65 20 69 74 20 6c 61 74 65 72 20 66 6f 72 20  se it later for 
0cd0: 73 79 6e 63 27 69 6e 67 0a 20 20 20 20 20 20 5f  sync'ing.      _
0ce0: 73 74 6d 74 20 3d 20 73 74 6d 74 3b 0a 0a 20 20  stmt = stmt;..  
0cf0: 20 20 20 20 2f 2f 20 46 65 74 63 68 20 61 6c 6c      // Fetch all
0d00: 20 74 68 65 20 61 74 74 61 63 68 65 64 20 64 61   the attached da
0d10: 74 61 62 61 73 65 73 20 6f 6e 20 74 68 69 73 20  tabases on this 
0d20: 63 6f 6e 6e 65 63 74 69 6f 6e 0a 20 20 20 20 20  connection.     
0d30: 20 75 73 69 6e 67 20 28 44 61 74 61 54 61 62 6c   using (DataTabl
0d40: 65 20 74 62 6c 20 3d 20 63 6e 6e 2e 47 65 74 53  e tbl = cnn.GetS
0d50: 63 68 65 6d 61 28 22 43 61 74 61 6c 6f 67 73 22  chema("Catalogs"
0d60: 29 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  )).      {.     
0d70: 20 20 20 66 6f 72 65 61 63 68 20 28 44 61 74 61     foreach (Data
0d80: 52 6f 77 20 72 6f 77 20 69 6e 20 74 62 6c 2e 52  Row row in tbl.R
0d90: 6f 77 73 29 0a 20 20 20 20 20 20 20 20 7b 0a 20  ows).        {. 
0da0: 20 20 20 20 20 20 20 20 20 63 61 74 61 6c 6f 67           catalog
0db0: 73 2e 41 64 64 28 28 73 74 72 69 6e 67 29 72 6f  s.Add((string)ro
0dc0: 77 5b 22 43 41 54 41 4c 4f 47 5f 4e 41 4d 45 22  w["CATALOG_NAME"
0dd0: 5d 2c 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e 74  ], Convert.ToInt
0de0: 33 32 28 72 6f 77 5b 22 49 44 22 5d 2c 20 43 75  32(row["ID"], Cu
0df0: 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72 69  ltureInfo.Invari
0e00: 61 6e 74 43 75 6c 74 75 72 65 29 29 3b 0a 20 20  antCulture));.  
0e10: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
0e20: 0a 20 20 20 20 20 20 2f 2f 20 46 65 74 63 68 20  .      // Fetch 
0e30: 61 6c 6c 20 74 68 65 20 75 6e 69 71 75 65 20 74  all the unique t
0e40: 61 62 6c 65 73 20 61 6e 64 20 63 61 74 61 6c 6f  ables and catalo
0e50: 67 73 20 75 73 65 64 20 62 79 20 74 68 65 20 63  gs used by the c
0e60: 75 72 72 65 6e 74 20 73 74 61 74 65 6d 65 6e 74  urrent statement
0e70: 0a 20 20 20 20 20 20 75 73 69 6e 67 20 28 44 61  .      using (Da
0e80: 74 61 54 61 62 6c 65 20 73 63 68 65 6d 61 20 3d  taTable schema =
0e90: 20 72 65 61 64 65 72 2e 47 65 74 53 63 68 65 6d   reader.GetSchem
0ea0: 61 54 61 62 6c 65 28 66 61 6c 73 65 2c 20 66 61  aTable(false, fa
0eb0: 6c 73 65 29 29 0a 20 20 20 20 20 20 7b 0a 20 20  lse)).      {.  
0ec0: 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 44        foreach (D
0ed0: 61 74 61 52 6f 77 20 72 6f 77 20 69 6e 20 73 63  ataRow row in sc
0ee0: 68 65 6d 61 2e 52 6f 77 73 29 0a 20 20 20 20 20  hema.Rows).     
0ef0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 2f     {.          /
0f00: 2f 20 43 68 65 63 6b 20 69 66 20 63 6f 6c 75 6d  / Check if colum
0f10: 6e 20 69 73 20 62 61 63 6b 65 64 20 74 6f 20 61  n is backed to a
0f20: 20 74 61 62 6c 65 0a 20 20 20 20 20 20 20 20 20   table.         
0f30: 20 69 66 20 28 72 6f 77 5b 53 63 68 65 6d 61 54   if (row[SchemaT
0f40: 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75  ableOptionalColu
0f50: 6d 6e 2e 42 61 73 65 43 61 74 61 6c 6f 67 4e 61  mn.BaseCatalogNa
0f60: 6d 65 5d 20 3d 3d 20 44 42 4e 75 6c 6c 2e 56 61  me] == DBNull.Va
0f70: 6c 75 65 29 0a 20 20 20 20 20 20 20 20 20 20 20  lue).           
0f80: 20 63 6f 6e 74 69 6e 75 65 3b 0a 0a 20 20 20 20   continue;..    
0f90: 20 20 20 20 20 20 2f 2f 20 52 65 63 6f 72 64 20        // Record 
0fa0: 74 68 65 20 75 6e 69 71 75 65 20 74 61 62 6c 65  the unique table
0fb0: 20 73 6f 20 77 65 20 63 61 6e 20 6c 6f 6f 6b 20   so we can look 
0fc0: 75 70 20 69 74 73 20 6b 65 79 73 0a 20 20 20 20  up its keys.    
0fd0: 20 20 20 20 20 20 73 74 72 69 6e 67 20 63 61 74        string cat
0fe0: 61 6c 6f 67 20 3d 20 28 73 74 72 69 6e 67 29 72  alog = (string)r
0ff0: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 4f 70  ow[SchemaTableOp
1000: 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 42 61 73  tionalColumn.Bas
1010: 65 43 61 74 61 6c 6f 67 4e 61 6d 65 5d 3b 0a 20  eCatalogName];. 
1020: 20 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20           string 
1030: 74 61 62 6c 65 20 3d 20 28 73 74 72 69 6e 67 29  table = (string)
1040: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43  row[SchemaTableC
1050: 6f 6c 75 6d 6e 2e 42 61 73 65 54 61 62 6c 65 4e  olumn.BaseTableN
1060: 61 6d 65 5d 3b 0a 0a 20 20 20 20 20 20 20 20 20  ame];..         
1070: 20 69 66 20 28 74 61 62 6c 65 73 2e 43 6f 6e 74   if (tables.Cont
1080: 61 69 6e 73 4b 65 79 28 63 61 74 61 6c 6f 67 29  ainsKey(catalog)
1090: 20 3d 3d 20 66 61 6c 73 65 29 0a 20 20 20 20 20   == false).     
10a0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
10b0: 20 20 20 6c 69 73 74 20 3d 20 6e 65 77 20 4c 69     list = new Li
10c0: 73 74 3c 73 74 72 69 6e 67 3e 28 29 3b 0a 20 20  st<string>();.  
10d0: 20 20 20 20 20 20 20 20 20 20 74 61 62 6c 65 73            tables
10e0: 2e 41 64 64 28 63 61 74 61 6c 6f 67 2c 20 6c 69  .Add(catalog, li
10f0: 73 74 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  st);.          }
1100: 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 0a  .          else.
1110: 20 20 20 20 20 20 20 20 20 20 20 20 6c 69 73 74              list
1120: 20 3d 20 74 61 62 6c 65 73 5b 63 61 74 61 6c 6f   = tables[catalo
1130: 67 5d 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 69  g];..          i
1140: 66 20 28 6c 69 73 74 2e 43 6f 6e 74 61 69 6e 73  f (list.Contains
1150: 28 74 61 62 6c 65 29 20 3d 3d 20 66 61 6c 73 65  (table) == false
1160: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 6c 69  ).            li
1170: 73 74 2e 41 64 64 28 74 61 62 6c 65 29 3b 0a 20  st.Add(table);. 
1180: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20         }..      
1190: 20 20 2f 2f 20 46 6f 72 20 65 61 63 68 20 63 61    // For each ca
11a0: 74 61 6c 6f 67 20 61 6e 64 20 65 61 63 68 20 74  talog and each t
11b0: 61 62 6c 65 2c 20 71 75 65 72 79 20 74 68 65 20  able, query the 
11c0: 69 6e 64 65 78 65 73 20 66 6f 72 20 74 68 65 20  indexes for the 
11d0: 74 61 62 6c 65 2e 0a 20 20 20 20 20 20 20 20 2f  table..        /
11e0: 2f 20 46 69 6e 64 20 61 20 70 72 69 6d 61 72 79  / Find a primary
11f0: 20 6b 65 79 20 69 6e 64 65 78 20 69 66 20 74 68   key index if th
1200: 65 72 65 20 69 73 20 6f 6e 65 2e 20 20 49 66 20  ere is one.  If 
1210: 6e 6f 74 2c 20 66 69 6e 64 20 61 20 75 6e 69 71  not, find a uniq
1220: 75 65 20 69 6e 64 65 78 20 69 6e 73 74 65 61 64  ue index instead
1230: 0a 20 20 20 20 20 20 20 20 66 6f 72 65 61 63 68  .        foreach
1240: 20 28 4b 65 79 56 61 6c 75 65 50 61 69 72 3c 73   (KeyValuePair<s
1250: 74 72 69 6e 67 2c 20 4c 69 73 74 3c 73 74 72 69  tring, List<stri
1260: 6e 67 3e 3e 20 70 61 69 72 20 69 6e 20 74 61 62  ng>> pair in tab
1270: 6c 65 73 29 0a 20 20 20 20 20 20 20 20 7b 0a 20  les).        {. 
1280: 20 20 20 20 20 20 20 20 20 66 6f 72 20 28 69 6e           for (in
1290: 74 20 69 20 3d 20 30 3b 20 69 20 3c 20 70 61 69  t i = 0; i < pai
12a0: 72 2e 56 61 6c 75 65 2e 43 6f 75 6e 74 3b 20 69  r.Value.Count; i
12b0: 2b 2b 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a  ++).          {.
12c0: 20 20 20 20 20 20 20 20 20 20 20 20 73 74 72 69              stri
12d0: 6e 67 20 74 61 62 6c 65 20 3d 20 70 61 69 72 2e  ng table = pair.
12e0: 56 61 6c 75 65 5b 69 5d 3b 0a 20 20 20 20 20 20  Value[i];.      
12f0: 20 20 20 20 20 20 44 61 74 61 52 6f 77 20 70 72        DataRow pr
1300: 65 66 65 72 72 65 64 52 6f 77 20 3d 20 6e 75 6c  eferredRow = nul
1310: 6c 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 75  l;.            u
1320: 73 69 6e 67 20 28 44 61 74 61 54 61 62 6c 65 20  sing (DataTable 
1330: 74 62 6c 20 3d 20 63 6e 6e 2e 47 65 74 53 63 68  tbl = cnn.GetSch
1340: 65 6d 61 28 22 49 6e 64 65 78 65 73 22 2c 20 6e  ema("Indexes", n
1350: 65 77 20 73 74 72 69 6e 67 5b 5d 20 7b 20 70 61  ew string[] { pa
1360: 69 72 2e 4b 65 79 2c 20 6e 75 6c 6c 2c 20 74 61  ir.Key, null, ta
1370: 62 6c 65 20 7d 29 29 0a 20 20 20 20 20 20 20 20  ble })).        
1380: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
1390: 20 20 20 20 2f 2f 20 4c 6f 6f 70 20 74 77 69 63      // Loop twic
13a0: 65 2e 20 20 54 68 65 20 66 69 72 73 74 20 74 69  e.  The first ti
13b0: 6d 65 20 6c 6f 6f 6b 69 6e 67 20 66 6f 72 20 61  me looking for a
13c0: 20 70 72 69 6d 61 72 79 20 6b 65 79 20 69 6e 64   primary key ind
13d0: 65 78 2c 20 0a 20 20 20 20 20 20 20 20 20 20 20  ex, .           
13e0: 20 20 20 2f 2f 20 74 68 65 20 73 65 63 6f 6e 64     // the second
13f0: 20 74 69 6d 65 20 6c 6f 6f 6b 69 6e 67 20 66 6f   time looking fo
1400: 72 20 61 20 75 6e 69 71 75 65 20 69 6e 64 65 78  r a unique index
1410: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
1420: 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20 6e  or (int n = 0; n
1430: 20 3c 20 32 20 26 26 20 70 72 65 66 65 72 72 65   < 2 && preferre
1440: 64 52 6f 77 20 3d 3d 20 6e 75 6c 6c 3b 20 6e 2b  dRow == null; n+
1450: 2b 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  +).             
1460: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
1470: 20 20 20 66 6f 72 65 61 63 68 20 28 44 61 74 61     foreach (Data
1480: 52 6f 77 20 72 6f 77 20 69 6e 20 74 62 6c 2e 52  Row row in tbl.R
1490: 6f 77 73 29 0a 20 20 20 20 20 20 20 20 20 20 20  ows).           
14a0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
14b0: 20 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3d           if (n =
14c0: 3d 20 30 20 26 26 20 28 62 6f 6f 6c 29 72 6f 77  = 0 && (bool)row
14d0: 5b 22 50 52 49 4d 41 52 59 5f 4b 45 59 22 5d 20  ["PRIMARY_KEY"] 
14e0: 3d 3d 20 74 72 75 65 29 0a 20 20 20 20 20 20 20  == true).       
14f0: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
1500: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1510: 20 70 72 65 66 65 72 72 65 64 52 6f 77 20 3d 20   preferredRow = 
1520: 72 6f 77 3b 0a 20 20 20 20 20 20 20 20 20 20 20  row;.           
1530: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
1540: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1550: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
1560: 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28 6e        else if (n
1570: 20 3d 3d 20 31 20 26 26 20 28 62 6f 6f 6c 29 72   == 1 && (bool)r
1580: 6f 77 5b 22 55 4e 49 51 55 45 22 5d 20 3d 3d 20  ow["UNIQUE"] == 
1590: 74 72 75 65 29 0a 20 20 20 20 20 20 20 20 20 20  true).          
15a0: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
15b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70 72                pr
15c0: 65 66 65 72 72 65 64 52 6f 77 20 3d 20 72 6f 77  eferredRow = row
15d0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
15e0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
15f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
1600: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1610: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   }.             
1620: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   }.             
1630: 20 69 66 20 28 70 72 65 66 65 72 72 65 64 52 6f   if (preferredRo
1640: 77 20 3d 3d 20 6e 75 6c 6c 29 20 2f 2f 20 55 6e  w == null) // Un
1650: 61 62 6c 65 20 74 6f 20 66 69 6e 64 20 61 6e 79  able to find any
1660: 20 73 75 69 74 61 62 6c 65 20 69 6e 64 65 78 20   suitable index 
1670: 66 6f 72 20 74 68 69 73 20 74 61 62 6c 65 20 73  for this table s
1680: 6f 20 72 65 6d 6f 76 65 20 69 74 0a 20 20 20 20  o remove it.    
1690: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
16a0: 20 20 20 20 20 20 20 20 20 20 20 20 70 61 69 72              pair
16b0: 2e 56 61 6c 75 65 2e 52 65 6d 6f 76 65 41 74 28  .Value.RemoveAt(
16c0: 69 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  i);.            
16d0: 20 20 20 20 69 2d 2d 3b 0a 20 20 20 20 20 20 20      i--;.       
16e0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
16f0: 20 20 20 20 20 20 20 65 6c 73 65 20 2f 2f 20 57         else // W
1700: 65 20 66 6f 75 6e 64 20 61 20 75 73 61 62 6c 65  e found a usable
1710: 20 69 6e 64 65 78 2c 20 73 6f 20 66 65 74 63 68   index, so fetch
1720: 20 74 68 65 20 6e 65 63 65 73 73 61 72 79 20 74   the necessary t
1730: 61 62 6c 65 20 64 65 74 61 69 6c 73 0a 20 20 20  able details.   
1740: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
1750: 20 20 20 20 20 20 20 20 20 20 20 20 20 75 73 69               usi
1760: 6e 67 20 28 44 61 74 61 54 61 62 6c 65 20 74 62  ng (DataTable tb
1770: 6c 54 61 62 6c 65 73 20 3d 20 63 6e 6e 2e 47 65  lTables = cnn.Ge
1780: 74 53 63 68 65 6d 61 28 22 54 61 62 6c 65 73 22  tSchema("Tables"
1790: 2c 20 6e 65 77 20 73 74 72 69 6e 67 5b 5d 20 7b  , new string[] {
17a0: 20 70 61 69 72 2e 4b 65 79 2c 20 6e 75 6c 6c 2c   pair.Key, null,
17b0: 20 74 61 62 6c 65 20 7d 29 29 0a 20 20 20 20 20   table })).     
17c0: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
17d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
17e0: 2f 20 46 69 6e 64 20 74 68 65 20 72 6f 6f 74 20  / Find the root 
17f0: 70 61 67 65 20 6f 66 20 74 68 65 20 74 61 62 6c  page of the tabl
1800: 65 20 69 6e 20 74 68 65 20 63 75 72 72 65 6e 74  e in the current
1810: 20 73 74 61 74 65 6d 65 6e 74 20 61 6e 64 20 67   statement and g
1820: 65 74 20 74 68 65 20 63 75 72 73 6f 72 20 74 68  et the cursor th
1830: 61 74 27 73 20 69 74 65 72 61 74 69 6e 67 20 69  at's iterating i
1840: 74 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t.              
1850: 20 20 20 20 69 6e 74 20 64 61 74 61 62 61 73 65      int database
1860: 20 3d 20 63 61 74 61 6c 6f 67 73 5b 70 61 69 72   = catalogs[pair
1870: 2e 4b 65 79 5d 3b 0a 20 20 20 20 20 20 20 20 20  .Key];.         
1880: 20 20 20 20 20 20 20 20 20 69 6e 74 20 72 6f 6f           int roo
1890: 74 50 61 67 65 20 3d 20 43 6f 6e 76 65 72 74 2e  tPage = Convert.
18a0: 54 6f 49 6e 74 33 32 28 74 62 6c 54 61 62 6c 65  ToInt32(tblTable
18b0: 73 2e 52 6f 77 73 5b 30 5d 5b 22 54 41 42 4c 45  s.Rows[0]["TABLE
18c0: 5f 52 4f 4f 54 50 41 47 45 22 5d 2c 20 43 75 6c  _ROOTPAGE"], Cul
18d0: 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72 69 61  tureInfo.Invaria
18e0: 6e 74 43 75 6c 74 75 72 65 29 3b 0a 20 20 20 20  ntCulture);.    
18f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e                in
1900: 74 20 63 75 72 73 6f 72 20 3d 20 73 74 6d 74 2e  t cursor = stmt.
1910: 5f 73 71 6c 2e 47 65 74 43 75 72 73 6f 72 46 6f  _sql.GetCursorFo
1920: 72 54 61 62 6c 65 28 73 74 6d 74 2c 20 64 61 74  rTable(stmt, dat
1930: 61 62 61 73 65 2c 20 72 6f 6f 74 50 61 67 65 29  abase, rootPage)
1940: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
1950: 20 20 20 20 20 2f 2f 20 4e 6f 77 20 65 6e 75 6d       // Now enum
1960: 65 72 61 74 65 20 74 68 65 20 6d 65 6d 62 65 72  erate the member
1970: 73 20 6f 66 20 74 68 65 20 69 6e 64 65 78 20 77  s of the index w
1980: 65 27 72 65 20 67 6f 69 6e 67 20 74 6f 20 75 73  e're going to us
1990: 65 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e.              
19a0: 20 20 20 20 75 73 69 6e 67 20 28 44 61 74 61 54      using (DataT
19b0: 61 62 6c 65 20 69 6e 64 65 78 43 6f 6c 75 6d 6e  able indexColumn
19c0: 73 20 3d 20 63 6e 6e 2e 47 65 74 53 63 68 65 6d  s = cnn.GetSchem
19d0: 61 28 22 49 6e 64 65 78 43 6f 6c 75 6d 6e 73 22  a("IndexColumns"
19e0: 2c 20 6e 65 77 20 73 74 72 69 6e 67 5b 5d 20 7b  , new string[] {
19f0: 20 70 61 69 72 2e 4b 65 79 2c 20 6e 75 6c 6c 2c   pair.Key, null,
1a00: 20 74 61 62 6c 65 2c 20 28 73 74 72 69 6e 67 29   table, (string)
1a10: 70 72 65 66 65 72 72 65 64 52 6f 77 5b 22 49 4e  preferredRow["IN
1a20: 44 45 58 5f 4e 41 4d 45 22 5d 20 7d 29 29 0a 20  DEX_NAME"] })). 
1a30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a40: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
1a50: 20 20 20 20 20 20 20 4b 65 79 51 75 65 72 79 20         KeyQuery 
1a60: 71 75 65 72 79 20 3d 20 6e 75 6c 6c 3b 0a 0a 20  query = null;.. 
1a70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a80: 20 20 20 4c 69 73 74 3c 73 74 72 69 6e 67 3e 20     List<string> 
1a90: 63 6f 6c 73 20 3d 20 6e 65 77 20 4c 69 73 74 3c  cols = new List<
1aa0: 73 74 72 69 6e 67 3e 28 29 3b 0a 20 20 20 20 20  string>();.     
1ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66                 f
1ac0: 6f 72 20 28 69 6e 74 20 78 20 3d 20 30 3b 20 78  or (int x = 0; x
1ad0: 20 3c 20 69 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e   < indexColumns.
1ae0: 52 6f 77 73 2e 43 6f 75 6e 74 3b 20 78 2b 2b 29  Rows.Count; x++)
1af0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1b00: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
1b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 62 6f 6f               boo
1b20: 6c 20 61 64 64 4b 65 79 20 3d 20 74 72 75 65 3b  l addKey = true;
1b30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1b40: 20 20 20 20 20 20 20 2f 2f 20 49 66 20 74 68 65         // If the
1b50: 20 63 6f 6c 75 6d 6e 20 69 6e 20 74 68 65 20 69   column in the i
1b60: 6e 64 65 78 20 61 6c 72 65 61 64 79 20 61 70 70  ndex already app
1b70: 65 61 72 73 20 69 6e 20 74 68 65 20 71 75 65 72  ears in the quer
1b80: 79 2c 20 73 6b 69 70 20 69 74 0a 20 20 20 20 20  y, skip it.     
1b90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1ba0: 20 66 6f 72 65 61 63 68 20 28 44 61 74 61 52 6f   foreach (DataRo
1bb0: 77 20 72 6f 77 20 69 6e 20 73 63 68 65 6d 61 2e  w row in schema.
1bc0: 52 6f 77 73 29 0a 20 20 20 20 20 20 20 20 20 20  Rows).          
1bd0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20              {.  
1be0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1bf0: 20 20 20 20 20 20 69 66 20 28 72 6f 77 2e 49 73        if (row.Is
1c00: 4e 75 6c 6c 28 53 63 68 65 6d 61 54 61 62 6c 65  Null(SchemaTable
1c10: 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 6f 6c 75 6d  Column.BaseColum
1c20: 6e 4e 61 6d 65 29 29 0a 20 20 20 20 20 20 20 20  nName)).        
1c30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1c40: 20 20 63 6f 6e 74 69 6e 75 65 3b 0a 0a 20 20 20    continue;..   
1c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1c60: 20 20 20 20 20 69 66 20 28 28 73 74 72 69 6e 67       if ((string
1c70: 29 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65  )row[SchemaTable
1c80: 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 6f 6c 75 6d  Column.BaseColum
1c90: 6e 4e 61 6d 65 5d 20 3d 3d 20 28 73 74 72 69 6e  nName] == (strin
1ca0: 67 29 69 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e 52  g)indexColumns.R
1cb0: 6f 77 73 5b 78 5d 5b 22 43 4f 4c 55 4d 4e 5f 4e  ows[x]["COLUMN_N
1cc0: 41 4d 45 22 5d 20 26 26 0a 20 20 20 20 20 20 20  AME"] &&.       
1cd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1ce0: 20 20 20 20 20 28 73 74 72 69 6e 67 29 72 6f 77       (string)row
1cf0: 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  [SchemaTableColu
1d00: 6d 6e 2e 42 61 73 65 54 61 62 6c 65 4e 61 6d 65  mn.BaseTableName
1d10: 5d 20 3d 3d 20 74 61 62 6c 65 20 26 26 0a 20 20  ] == table &&.  
1d20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1d30: 20 20 20 20 20 20 20 20 20 20 28 73 74 72 69 6e            (strin
1d40: 67 29 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c  g)row[SchemaTabl
1d50: 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e  eOptionalColumn.
1d60: 42 61 73 65 43 61 74 61 6c 6f 67 4e 61 6d 65 5d  BaseCatalogName]
1d70: 20 3d 3d 20 70 61 69 72 2e 4b 65 79 29 0a 20 20   == pair.Key).  
1d80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1d90: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
1da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1db0: 20 20 69 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e 52    indexColumns.R
1dc0: 6f 77 73 2e 52 65 6d 6f 76 65 41 74 28 78 29 3b  ows.RemoveAt(x);
1dd0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1de0: 20 20 20 20 20 20 20 20 20 20 20 78 2d 2d 3b 0a             x--;.
1df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1e00: 20 20 20 20 20 20 20 20 20 20 61 64 64 4b 65 79            addKey
1e10: 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20   = false;.      
1e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1e30: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20      break;.     
1e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1e50: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
1e60: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
1e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1e80: 20 20 20 69 66 20 28 61 64 64 4b 65 79 20 3d 3d     if (addKey ==
1e90: 20 74 72 75 65 29 0a 20 20 20 20 20 20 20 20 20   true).         
1ea0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63                 c
1eb0: 6f 6c 73 2e 41 64 64 28 28 73 74 72 69 6e 67 29  ols.Add((string)
1ec0: 69 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e 52 6f 77  indexColumns.Row
1ed0: 73 5b 78 5d 5b 22 43 4f 4c 55 4d 4e 5f 4e 41 4d  s[x]["COLUMN_NAM
1ee0: 45 22 5d 29 3b 0a 20 20 20 20 20 20 20 20 20 20  E"]);.          
1ef0: 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20            }..   
1f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1f10: 20 2f 2f 20 49 66 20 74 68 65 20 69 6e 64 65 78   // If the index
1f20: 20 69 73 20 6e 6f 74 20 61 20 72 6f 77 69 64 20   is not a rowid 
1f30: 61 6c 69 61 73 2c 20 72 65 63 6f 72 64 20 61 6c  alias, record al
1f40: 6c 20 74 68 65 20 63 6f 6c 75 6d 6e 73 0a 20 20  l the columns.  
1f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1f60: 20 20 2f 2f 20 6e 65 65 64 65 64 20 74 6f 20 6d    // needed to m
1f70: 61 6b 65 20 75 70 20 74 68 65 20 75 6e 69 71 75  ake up the uniqu
1f80: 65 20 69 6e 64 65 78 20 61 6e 64 20 63 6f 6e 73  e index and cons
1f90: 74 72 75 63 74 20 61 20 53 51 4c 20 71 75 65 72  truct a SQL quer
1fa0: 79 20 66 6f 72 20 69 74 0a 20 20 20 20 20 20 20  y for it.       
1fb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20               if 
1fc0: 28 28 73 74 72 69 6e 67 29 70 72 65 66 65 72 72  ((string)preferr
1fd0: 65 64 52 6f 77 5b 22 49 4e 44 45 58 5f 4e 41 4d  edRow["INDEX_NAM
1fe0: 45 22 5d 20 21 3d 20 22 73 71 6c 69 74 65 5f 6d  E"] != "sqlite_m
1ff0: 61 73 74 65 72 5f 50 4b 5f 22 20 2b 20 74 61 62  aster_PK_" + tab
2000: 6c 65 29 0a 20 20 20 20 20 20 20 20 20 20 20 20  le).            
2010: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
2020: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2030: 2f 2f 20 57 68 61 74 65 76 65 72 20 72 65 6d 61  // Whatever rema
2040: 69 6e 73 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  ins of the colum
2050: 6e 73 20 77 65 20 6e 65 65 64 20 74 68 61 74 20  ns we need that 
2060: 6d 61 6b 65 20 75 70 20 74 68 65 20 69 6e 64 65  make up the inde
2070: 78 20 74 68 61 74 20 61 72 65 20 6e 6f 74 0a 20  x that are not. 
2080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2090: 20 20 20 20 20 2f 2f 20 61 6c 72 65 61 64 79 20       // already 
20a0: 69 6e 20 74 68 65 20 71 75 65 72 79 20 6e 65 65  in the query nee
20b0: 64 20 74 6f 20 62 65 20 71 75 65 72 69 65 64 20  d to be queried 
20c0: 73 65 70 61 72 61 74 65 6c 79 2c 20 73 6f 20 63  separately, so c
20d0: 6f 6e 73 74 72 75 63 74 20 61 20 73 75 62 71 75  onstruct a subqu
20e0: 65 72 79 0a 20 20 20 20 20 20 20 20 20 20 20 20  ery.            
20f0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 63 6f            if (co
2100: 6c 73 2e 43 6f 75 6e 74 20 3e 20 30 29 0a 20 20  ls.Count > 0).  
2110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2120: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
2130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74                st
2140: 72 69 6e 67 5b 5d 20 71 75 65 72 79 63 6f 6c 73  ring[] querycols
2150: 20 3d 20 6e 65 77 20 73 74 72 69 6e 67 5b 63 6f   = new string[co
2160: 6c 73 2e 43 6f 75 6e 74 5d 3b 0a 20 20 20 20 20  ls.Count];.     
2170: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2180: 20 20 20 63 6f 6c 73 2e 43 6f 70 79 54 6f 28 71     cols.CopyTo(q
2190: 75 65 72 79 63 6f 6c 73 29 3b 0a 20 20 20 20 20  uerycols);.     
21a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
21b0: 20 20 20 71 75 65 72 79 20 3d 20 6e 65 77 20 4b     query = new K
21c0: 65 79 51 75 65 72 79 28 63 6e 6e 2c 20 70 61 69  eyQuery(cnn, pai
21d0: 72 2e 4b 65 79 2c 20 74 61 62 6c 65 2c 20 71 75  r.Key, table, qu
21e0: 65 72 79 63 6f 6c 73 29 3b 0a 20 20 20 20 20 20  erycols);.      
21f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2200: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }.              
2210: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20        }..       
2220: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20               // 
2230: 43 72 65 61 74 65 20 61 20 4b 65 79 49 6e 66 6f  Create a KeyInfo
2240: 20 73 74 72 75 63 74 20 66 6f 72 20 65 61 63 68   struct for each
2250: 20 63 6f 6c 75 6d 6e 20 6f 66 20 74 68 65 20 69   column of the i
2260: 6e 64 65 78 0a 20 20 20 20 20 20 20 20 20 20 20  ndex.           
2270: 20 20 20 20 20 20 20 20 20 66 6f 72 20 28 69 6e           for (in
2280: 74 20 78 20 3d 20 30 3b 20 78 20 3c 20 69 6e 64  t x = 0; x < ind
2290: 65 78 43 6f 6c 75 6d 6e 73 2e 52 6f 77 73 2e 43  exColumns.Rows.C
22a0: 6f 75 6e 74 3b 20 78 2b 2b 29 0a 20 20 20 20 20  ount; x++).     
22b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
22c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
22d0: 20 20 20 20 20 20 20 73 74 72 69 6e 67 20 63 6f         string co
22e0: 6c 75 6d 6e 4e 61 6d 65 20 3d 20 28 73 74 72 69  lumnName = (stri
22f0: 6e 67 29 69 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e  ng)indexColumns.
2300: 52 6f 77 73 5b 78 5d 5b 22 43 4f 4c 55 4d 4e 5f  Rows[x]["COLUMN_
2310: 4e 41 4d 45 22 5d 3b 0a 20 20 20 20 20 20 20 20  NAME"];.        
2320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 4b 65                Ke
2330: 79 49 6e 66 6f 20 6b 65 79 20 3d 20 6e 65 77 20  yInfo key = new 
2340: 4b 65 79 49 6e 66 6f 28 29 3b 0a 0a 20 20 20 20  KeyInfo();..    
2350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2360: 20 20 6b 65 79 2e 72 6f 6f 74 50 61 67 65 20 3d    key.rootPage =
2370: 20 72 6f 6f 74 50 61 67 65 3b 0a 20 20 20 20 20   rootPage;.     
2380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2390: 20 6b 65 79 2e 63 75 72 73 6f 72 20 3d 20 63 75   key.cursor = cu
23a0: 72 73 6f 72 3b 0a 20 20 20 20 20 20 20 20 20 20  rsor;.          
23b0: 20 20 20 20 20 20 20 20 20 20 20 20 6b 65 79 2e              key.
23c0: 64 61 74 61 62 61 73 65 20 3d 20 64 61 74 61 62  database = datab
23d0: 61 73 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20  ase;.           
23e0: 20 20 20 20 20 20 20 20 20 20 20 6b 65 79 2e 64             key.d
23f0: 61 74 61 62 61 73 65 4e 61 6d 65 20 3d 20 70 61  atabaseName = pa
2400: 69 72 2e 4b 65 79 3b 0a 20 20 20 20 20 20 20 20  ir.Key;.        
2410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6b 65                ke
2420: 79 2e 74 61 62 6c 65 4e 61 6d 65 20 3d 20 74 61  y.tableName = ta
2430: 62 6c 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20  ble;.           
2440: 20 20 20 20 20 20 20 20 20 20 20 6b 65 79 2e 63             key.c
2450: 6f 6c 75 6d 6e 4e 61 6d 65 20 3d 20 63 6f 6c 75  olumnName = colu
2460: 6d 6e 4e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20  mnName;.        
2470: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6b 65                ke
2480: 79 2e 71 75 65 72 79 20 3d 20 71 75 65 72 79 3b  y.query = query;
2490: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
24a0: 20 20 20 20 20 20 20 6b 65 79 2e 63 6f 6c 75 6d         key.colum
24b0: 6e 20 3d 20 78 3b 0a 0a 20 20 20 20 20 20 20 20  n = x;..        
24c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6b 65                ke
24d0: 79 73 2e 41 64 64 28 6b 65 79 29 3b 0a 20 20 20  ys.Add(key);.   
24e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
24f0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   }.             
2500: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
2510: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
2520: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
2530: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
2540: 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20   }.        }.   
2550: 20 20 20 7d 0a 0a 20 20 20 20 20 20 2f 2f 20 4e     }..      // N
2560: 6f 77 20 77 65 20 68 61 76 65 20 61 6c 6c 20 74  ow we have all t
2570: 68 65 20 61 64 64 69 74 69 6f 6e 61 6c 20 63 6f  he additional co
2580: 6c 75 6d 6e 73 20 77 65 20 68 61 76 65 20 74 6f  lumns we have to
2590: 20 72 65 74 75 72 6e 20 69 6e 20 6f 72 64 65 72   return in order
25a0: 20 74 6f 20 73 75 70 70 6f 72 74 0a 20 20 20 20   to support.    
25b0: 20 20 2f 2f 20 43 6f 6d 6d 61 6e 64 42 65 68 61    // CommandBeha
25c0: 76 69 6f 72 2e 4b 65 79 49 6e 66 6f 0a 20 20 20  vior.KeyInfo.   
25d0: 20 20 20 5f 6b 65 79 49 6e 66 6f 20 3d 20 6e 65     _keyInfo = ne
25e0: 77 20 4b 65 79 49 6e 66 6f 5b 6b 65 79 73 2e 43  w KeyInfo[keys.C
25f0: 6f 75 6e 74 5d 3b 0a 20 20 20 20 20 20 6b 65 79  ount];.      key
2600: 73 2e 43 6f 70 79 54 6f 28 5f 6b 65 79 49 6e 66  s.CopyTo(_keyInf
2610: 6f 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  o);.    }..    /
2620: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20  // <summary>.   
2630: 20 2f 2f 2f 20 48 6f 77 20 6d 61 6e 79 20 61 64   /// How many ad
2640: 64 69 74 69 6f 6e 61 6c 20 63 6f 6c 75 6d 6e 73  ditional columns
2650: 20 6f 66 20 6b 65 79 69 6e 66 6f 20 77 65 27 72   of keyinfo we'r
2660: 65 20 68 6f 6c 64 69 6e 67 0a 20 20 20 20 2f 2f  e holding.    //
2670: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20  / </summary>.   
2680: 20 69 6e 74 65 72 6e 61 6c 20 69 6e 74 20 43 6f   internal int Co
2690: 75 6e 74 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  unt.    {.      
26a0: 67 65 74 20 7b 20 72 65 74 75 72 6e 20 28 5f 6b  get { return (_k
26b0: 65 79 49 6e 66 6f 20 3d 3d 20 6e 75 6c 6c 29 20  eyInfo == null) 
26c0: 3f 20 30 20 3a 20 5f 6b 65 79 49 6e 66 6f 2e 4c  ? 0 : _keyInfo.L
26d0: 65 6e 67 74 68 3b 20 7d 0a 20 20 20 20 7d 0a 0a  ength; }.    }..
26e0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 76 6f 69      internal voi
26f0: 64 20 53 79 6e 63 28 69 6e 74 20 69 29 0a 20 20  d Sync(int i).  
2700: 20 20 7b 0a 20 20 20 20 20 20 53 79 6e 63 28 29    {.      Sync()
2710: 3b 0a 20 20 20 20 20 20 69 66 20 28 5f 6b 65 79  ;.      if (_key
2720: 49 6e 66 6f 5b 69 5d 2e 63 75 72 73 6f 72 20 3d  Info[i].cursor =
2730: 3d 20 2d 31 29 0a 20 20 20 20 20 20 20 20 74 68  = -1).        th
2740: 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64 43  row new InvalidC
2750: 61 73 74 45 78 63 65 70 74 69 6f 6e 28 29 3b 0a  astException();.
2760: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
2770: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
2780: 20 4d 61 6b 65 20 73 75 72 65 20 61 6c 6c 20 74   Make sure all t
2790: 68 65 20 73 75 62 71 75 65 72 69 65 73 20 61 72  he subqueries ar
27a0: 65 20 6f 70 65 6e 20 61 6e 64 20 72 65 61 64 79  e open and ready
27b0: 20 61 6e 64 20 73 79 6e 63 27 64 20 77 69 74 68   and sync'd with
27c0: 20 74 68 65 20 63 75 72 72 65 6e 74 20 72 6f 77   the current row
27d0: 69 64 0a 20 20 20 20 2f 2f 2f 20 6f 66 20 74 68  id.    /// of th
27e0: 65 20 74 61 62 6c 65 20 74 68 65 79 27 72 65 20  e table they're 
27f0: 73 75 70 70 6f 72 74 69 6e 67 0a 20 20 20 20 2f  supporting.    /
2800: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20  // </summary>.  
2810: 20 20 69 6e 74 65 72 6e 61 6c 20 76 6f 69 64 20    internal void 
2820: 53 79 6e 63 28 29 0a 20 20 20 20 7b 0a 20 20 20  Sync().    {.   
2830: 20 20 20 69 66 20 28 5f 69 73 56 61 6c 69 64 20     if (_isValid 
2840: 3d 3d 20 74 72 75 65 29 20 72 65 74 75 72 6e 3b  == true) return;
2850: 0a 0a 20 20 20 20 20 20 4b 65 79 51 75 65 72 79  ..      KeyQuery
2860: 20 6c 61 73 74 20 3d 20 6e 75 6c 6c 3b 0a 0a 20   last = null;.. 
2870: 20 20 20 20 20 66 6f 72 20 28 69 6e 74 20 6e 20       for (int n 
2880: 3d 20 30 3b 20 6e 20 3c 20 5f 6b 65 79 49 6e 66  = 0; n < _keyInf
2890: 6f 2e 4c 65 6e 67 74 68 3b 20 6e 2b 2b 29 0a 20  o.Length; n++). 
28a0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69       {.        i
28b0: 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e 71  f (_keyInfo[n].q
28c0: 75 65 72 79 20 3d 3d 20 6e 75 6c 6c 20 7c 7c 20  uery == null || 
28d0: 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e 71 75 65 72  _keyInfo[n].quer
28e0: 79 20 21 3d 20 6c 61 73 74 29 0a 20 20 20 20 20  y != last).     
28f0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 6c     {.          l
2900: 61 73 74 20 3d 20 5f 6b 65 79 49 6e 66 6f 5b 6e  ast = _keyInfo[n
2910: 5d 2e 71 75 65 72 79 3b 0a 0a 20 20 20 20 20 20  ].query;..      
2920: 20 20 20 20 69 66 20 28 6c 61 73 74 20 21 3d 20      if (last != 
2930: 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20 20 20 20  null).          
2940: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 6c 61  {.            la
2950: 73 74 2e 53 79 6e 63 28 5f 73 74 6d 74 2e 5f 73  st.Sync(_stmt._s
2960: 71 6c 2e 47 65 74 52 6f 77 49 64 46 6f 72 43 75  ql.GetRowIdForCu
2970: 72 73 6f 72 28 5f 73 74 6d 74 2c 20 5f 6b 65 79  rsor(_stmt, _key
2980: 49 6e 66 6f 5b 6e 5d 2e 63 75 72 73 6f 72 29 29  Info[n].cursor))
2990: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  ;.          }.  
29a0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
29b0: 20 20 20 20 20 20 5f 69 73 56 61 6c 69 64 20 3d        _isValid =
29c0: 20 74 72 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20   true;.    }..  
29d0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
29e0: 20 20 20 20 2f 2f 2f 20 52 65 6c 65 61 73 65 20      /// Release 
29f0: 61 6e 79 20 72 65 61 64 65 72 73 20 6f 6e 20 61  any readers on a
2a00: 6e 79 20 73 75 62 71 75 65 72 69 65 73 0a 20 20  ny subqueries.  
2a10: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
2a20: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 76 6f  .    internal vo
2a30: 69 64 20 52 65 73 65 74 28 29 0a 20 20 20 20 7b  id Reset().    {
2a40: 0a 20 20 20 20 20 20 5f 69 73 56 61 6c 69 64 20  .      _isValid 
2a50: 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 69  = false;.      i
2a60: 66 20 28 5f 6b 65 79 49 6e 66 6f 20 3d 3d 20 6e  f (_keyInfo == n
2a70: 75 6c 6c 29 20 72 65 74 75 72 6e 3b 0a 0a 20 20  ull) return;..  
2a80: 20 20 20 20 66 6f 72 20 28 69 6e 74 20 6e 20 3d      for (int n =
2a90: 20 30 3b 20 6e 20 3c 20 5f 6b 65 79 49 6e 66 6f   0; n < _keyInfo
2aa0: 2e 4c 65 6e 67 74 68 3b 20 6e 2b 2b 29 0a 20 20  .Length; n++).  
2ab0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69 66      {.        if
2ac0: 20 28 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e 71 75   (_keyInfo[n].qu
2ad0: 65 72 79 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20  ery != null).   
2ae0: 20 20 20 20 20 20 20 5f 6b 65 79 49 6e 66 6f 5b         _keyInfo[
2af0: 6e 5d 2e 71 75 65 72 79 2e 49 73 56 61 6c 69 64  n].query.IsValid
2b00: 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20   = false;.      
2b10: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70 75 62  }.    }..    pub
2b20: 6c 69 63 20 76 6f 69 64 20 44 69 73 70 6f 73 65  lic void Dispose
2b30: 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 5f  ().    {.      _
2b40: 73 74 6d 74 20 3d 20 6e 75 6c 6c 3b 0a 0a 20 20  stmt = null;..  
2b50: 20 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f      if (_keyInfo
2b60: 20 3d 3d 20 6e 75 6c 6c 29 20 72 65 74 75 72 6e   == null) return
2b70: 3b 0a 0a 20 20 20 20 20 20 66 6f 72 20 28 69 6e  ;..      for (in
2b80: 74 20 6e 20 3d 20 30 3b 20 6e 20 3c 20 5f 6b 65  t n = 0; n < _ke
2b90: 79 49 6e 66 6f 2e 4c 65 6e 67 74 68 3b 20 6e 2b  yInfo.Length; n+
2ba0: 2b 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  +).      {.     
2bb0: 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b     if (_keyInfo[
2bc0: 6e 5d 2e 71 75 65 72 79 20 21 3d 20 6e 75 6c 6c  n].query != null
2bd0: 29 0a 20 20 20 20 20 20 20 20 20 20 5f 6b 65 79  ).          _key
2be0: 49 6e 66 6f 5b 6e 5d 2e 71 75 65 72 79 2e 44 69  Info[n].query.Di
2bf0: 73 70 6f 73 65 28 29 3b 0a 20 20 20 20 20 20 7d  spose();.      }
2c00: 0a 20 20 20 20 20 20 5f 6b 65 79 49 6e 66 6f 20  .      _keyInfo 
2c10: 3d 20 6e 75 6c 6c 3b 0a 20 20 20 20 7d 0a 0a 20  = null;.    }.. 
2c20: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 72 69     internal stri
2c30: 6e 67 20 47 65 74 44 61 74 61 54 79 70 65 4e 61  ng GetDataTypeNa
2c40: 6d 65 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a  me(int i).    {.
2c50: 20 20 20 20 20 20 53 79 6e 63 28 29 3b 0a 20 20        Sync();.  
2c60: 20 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f      if (_keyInfo
2c70: 5b 69 5d 2e 71 75 65 72 79 20 21 3d 20 6e 75 6c  [i].query != nul
2c80: 6c 29 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e  l) return _keyIn
2c90: 66 6f 5b 69 5d 2e 71 75 65 72 79 2e 5f 72 65 61  fo[i].query._rea
2ca0: 64 65 72 2e 47 65 74 44 61 74 61 54 79 70 65 4e  der.GetDataTypeN
2cb0: 61 6d 65 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e  ame(_keyInfo[i].
2cc0: 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20 20 20 65  column);.      e
2cd0: 6c 73 65 20 72 65 74 75 72 6e 20 22 69 6e 74 65  lse return "inte
2ce0: 67 65 72 22 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ger";.    }..   
2cf0: 20 69 6e 74 65 72 6e 61 6c 20 54 79 70 65 20 47   internal Type G
2d00: 65 74 46 69 65 6c 64 54 79 70 65 28 69 6e 74 20  etFieldType(int 
2d10: 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53  i).    {.      S
2d20: 79 6e 63 28 29 3b 0a 20 20 20 20 20 20 69 66 20  ync();.      if 
2d30: 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65  (_keyInfo[i].que
2d40: 72 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65 74 75  ry != null) retu
2d50: 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71  rn _keyInfo[i].q
2d60: 75 65 72 79 2e 5f 72 65 61 64 65 72 2e 47 65 74  uery._reader.Get
2d70: 46 69 65 6c 64 54 79 70 65 28 5f 6b 65 79 49 6e  FieldType(_keyIn
2d80: 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 20  fo[i].column);. 
2d90: 20 20 20 20 20 65 6c 73 65 20 72 65 74 75 72 6e       else return
2da0: 20 74 79 70 65 6f 66 28 49 6e 74 36 34 29 3b 0a   typeof(Int64);.
2db0: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
2dc0: 6e 61 6c 20 73 74 72 69 6e 67 20 47 65 74 4e 61  nal string GetNa
2dd0: 6d 65 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a  me(int i).    {.
2de0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b 65        return _ke
2df0: 79 49 6e 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 4e  yInfo[i].columnN
2e00: 61 6d 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ame;.    }..    
2e10: 69 6e 74 65 72 6e 61 6c 20 69 6e 74 20 47 65 74  internal int Get
2e20: 4f 72 64 69 6e 61 6c 28 73 74 72 69 6e 67 20 6e  Ordinal(string n
2e30: 61 6d 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ame).    {.     
2e40: 20 66 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b   for (int n = 0;
2e50: 20 6e 20 3c 20 5f 6b 65 79 49 6e 66 6f 2e 4c 65   n < _keyInfo.Le
2e60: 6e 67 74 68 3b 20 6e 2b 2b 29 0a 20 20 20 20 20  ngth; n++).     
2e70: 20 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28 53   {.        if (S
2e80: 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28 6e 61  tring.Compare(na
2e90: 6d 65 2c 20 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e  me, _keyInfo[n].
2ea0: 63 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 53 74 72 69  columnName, Stri
2eb0: 6e 67 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64  ngComparison.Ord
2ec0: 69 6e 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20  inalIgnoreCase) 
2ed0: 3d 3d 20 30 29 20 72 65 74 75 72 6e 20 6e 3b 0a  == 0) return n;.
2ee0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65        }.      re
2ef0: 74 75 72 6e 20 2d 31 3b 0a 20 20 20 20 7d 0a 0a  turn -1;.    }..
2f00: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 62 6f 6f      internal boo
2f10: 6c 20 47 65 74 42 6f 6f 6c 65 61 6e 28 69 6e 74  l GetBoolean(int
2f20: 20 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   i).    {.      
2f30: 53 79 6e 63 28 69 29 3b 0a 20 20 20 20 20 20 69  Sync(i);.      i
2f40: 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71  f (_keyInfo[i].q
2f50: 75 65 72 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65  uery != null) re
2f60: 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d  turn _keyInfo[i]
2f70: 2e 71 75 65 72 79 2e 5f 72 65 61 64 65 72 2e 47  .query._reader.G
2f80: 65 74 42 6f 6f 6c 65 61 6e 28 5f 6b 65 79 49 6e  etBoolean(_keyIn
2f90: 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 20  fo[i].column);. 
2fa0: 20 20 20 20 20 65 6c 73 65 20 74 68 72 6f 77 20       else throw 
2fb0: 6e 65 77 20 49 6e 76 61 6c 69 64 43 61 73 74 45  new InvalidCastE
2fc0: 78 63 65 70 74 69 6f 6e 28 29 3b 0a 20 20 20 20  xception();.    
2fd0: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
2fe0: 62 79 74 65 20 47 65 74 42 79 74 65 28 69 6e 74  byte GetByte(int
2ff0: 20 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   i).    {.      
3000: 53 79 6e 63 28 69 29 3b 0a 20 20 20 20 20 20 69  Sync(i);.      i
3010: 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71  f (_keyInfo[i].q
3020: 75 65 72 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65  uery != null) re
3030: 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d  turn _keyInfo[i]
3040: 2e 71 75 65 72 79 2e 5f 72 65 61 64 65 72 2e 47  .query._reader.G
3050: 65 74 42 79 74 65 28 5f 6b 65 79 49 6e 66 6f 5b  etByte(_keyInfo[
3060: 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20  i].column);.    
3070: 20 20 65 6c 73 65 20 74 68 72 6f 77 20 6e 65 77    else throw new
3080: 20 49 6e 76 61 6c 69 64 43 61 73 74 45 78 63 65   InvalidCastExce
3090: 70 74 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a 0a  ption();.    }..
30a0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6c 6f 6e      internal lon
30b0: 67 20 47 65 74 42 79 74 65 73 28 69 6e 74 20 69  g GetBytes(int i
30c0: 2c 20 6c 6f 6e 67 20 66 69 65 6c 64 4f 66 66 73  , long fieldOffs
30d0: 65 74 2c 20 62 79 74 65 5b 5d 20 62 75 66 66 65  et, byte[] buffe
30e0: 72 2c 20 69 6e 74 20 62 75 66 66 65 72 6f 66 66  r, int bufferoff
30f0: 73 65 74 2c 20 69 6e 74 20 6c 65 6e 67 74 68 29  set, int length)
3100: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53 79 6e  .    {.      Syn
3110: 63 28 69 29 3b 0a 20 20 20 20 20 20 69 66 20 28  c(i);.      if (
3120: 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65 72  _keyInfo[i].quer
3130: 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65 74 75 72  y != null) retur
3140: 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75  n _keyInfo[i].qu
3150: 65 72 79 2e 5f 72 65 61 64 65 72 2e 47 65 74 42  ery._reader.GetB
3160: 79 74 65 73 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d  ytes(_keyInfo[i]
3170: 2e 63 6f 6c 75 6d 6e 2c 20 66 69 65 6c 64 4f 66  .column, fieldOf
3180: 66 73 65 74 2c 20 62 75 66 66 65 72 2c 20 62 75  fset, buffer, bu
3190: 66 66 65 72 6f 66 66 73 65 74 2c 20 6c 65 6e 67  fferoffset, leng
31a0: 74 68 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 20  th);.      else 
31b0: 74 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69  throw new Invali
31c0: 64 43 61 73 74 45 78 63 65 70 74 69 6f 6e 28 29  dCastException()
31d0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
31e0: 65 72 6e 61 6c 20 63 68 61 72 20 47 65 74 43 68  ernal char GetCh
31f0: 61 72 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a  ar(int i).    {.
3200: 20 20 20 20 20 20 53 79 6e 63 28 69 29 3b 0a 20        Sync(i);. 
3210: 20 20 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66       if (_keyInf
3220: 6f 5b 69 5d 2e 71 75 65 72 79 20 21 3d 20 6e 75  o[i].query != nu
3230: 6c 6c 29 20 72 65 74 75 72 6e 20 5f 6b 65 79 49  ll) return _keyI
3240: 6e 66 6f 5b 69 5d 2e 71 75 65 72 79 2e 5f 72 65  nfo[i].query._re
3250: 61 64 65 72 2e 47 65 74 43 68 61 72 28 5f 6b 65  ader.GetChar(_ke
3260: 79 49 6e 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 29  yInfo[i].column)
3270: 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 74 68 72  ;.      else thr
3280: 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64 43 61  ow new InvalidCa
3290: 73 74 45 78 63 65 70 74 69 6f 6e 28 29 3b 0a 20  stException();. 
32a0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
32b0: 61 6c 20 6c 6f 6e 67 20 47 65 74 43 68 61 72 73  al long GetChars
32c0: 28 69 6e 74 20 69 2c 20 6c 6f 6e 67 20 66 69 65  (int i, long fie
32d0: 6c 64 4f 66 66 73 65 74 2c 20 63 68 61 72 5b 5d  ldOffset, char[]
32e0: 20 62 75 66 66 65 72 2c 20 69 6e 74 20 62 75 66   buffer, int buf
32f0: 66 65 72 6f 66 66 73 65 74 2c 20 69 6e 74 20 6c  feroffset, int l
3300: 65 6e 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20  ength).    {.   
3310: 20 20 20 53 79 6e 63 28 69 29 3b 0a 20 20 20 20     Sync(i);.    
3320: 20 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69    if (_keyInfo[i
3330: 5d 2e 71 75 65 72 79 20 21 3d 20 6e 75 6c 6c 29  ].query != null)
3340: 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f   return _keyInfo
3350: 5b 69 5d 2e 71 75 65 72 79 2e 5f 72 65 61 64 65  [i].query._reade
3360: 72 2e 47 65 74 43 68 61 72 73 28 5f 6b 65 79 49  r.GetChars(_keyI
3370: 6e 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 2c 20 66  nfo[i].column, f
3380: 69 65 6c 64 4f 66 66 73 65 74 2c 20 62 75 66 66  ieldOffset, buff
3390: 65 72 2c 20 62 75 66 66 65 72 6f 66 66 73 65 74  er, bufferoffset
33a0: 2c 20 6c 65 6e 67 74 68 29 3b 0a 20 20 20 20 20  , length);.     
33b0: 20 65 6c 73 65 20 74 68 72 6f 77 20 6e 65 77 20   else throw new 
33c0: 49 6e 76 61 6c 69 64 43 61 73 74 45 78 63 65 70  InvalidCastExcep
33d0: 74 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a 0a 20  tion();.    }.. 
33e0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 44 61 74 65     internal Date
33f0: 54 69 6d 65 20 47 65 74 44 61 74 65 54 69 6d 65  Time GetDateTime
3400: 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a 20 20  (int i).    {.  
3410: 20 20 20 20 53 79 6e 63 28 69 29 3b 0a 20 20 20      Sync(i);.   
3420: 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b     if (_keyInfo[
3430: 69 5d 2e 71 75 65 72 79 20 21 3d 20 6e 75 6c 6c  i].query != null
3440: 29 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66  ) return _keyInf
3450: 6f 5b 69 5d 2e 71 75 65 72 79 2e 5f 72 65 61 64  o[i].query._read
3460: 65 72 2e 47 65 74 44 61 74 65 54 69 6d 65 28 5f  er.GetDateTime(_
3470: 6b 65 79 49 6e 66 6f 5b 69 5d 2e 63 6f 6c 75 6d  keyInfo[i].colum
3480: 6e 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 74  n);.      else t
3490: 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64  hrow new Invalid
34a0: 43 61 73 74 45 78 63 65 70 74 69 6f 6e 28 29 3b  CastException();
34b0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
34c0: 72 6e 61 6c 20 64 65 63 69 6d 61 6c 20 47 65 74  rnal decimal Get
34d0: 44 65 63 69 6d 61 6c 28 69 6e 74 20 69 29 0a 20  Decimal(int i). 
34e0: 20 20 20 7b 0a 20 20 20 20 20 20 53 79 6e 63 28     {.      Sync(
34f0: 69 29 3b 0a 20 20 20 20 20 20 69 66 20 28 5f 6b  i);.      if (_k
3500: 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65 72 79 20  eyInfo[i].query 
3510: 21 3d 20 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20  != null) return 
3520: 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65 72  _keyInfo[i].quer
3530: 79 2e 5f 72 65 61 64 65 72 2e 47 65 74 44 65 63  y._reader.GetDec
3540: 69 6d 61 6c 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d  imal(_keyInfo[i]
3550: 2e 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20 20 20  .column);.      
3560: 65 6c 73 65 20 74 68 72 6f 77 20 6e 65 77 20 49  else throw new I
3570: 6e 76 61 6c 69 64 43 61 73 74 45 78 63 65 70 74  nvalidCastExcept
3580: 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  ion();.    }..  
3590: 20 20 69 6e 74 65 72 6e 61 6c 20 64 6f 75 62 6c    internal doubl
35a0: 65 20 47 65 74 44 6f 75 62 6c 65 28 69 6e 74 20  e GetDouble(int 
35b0: 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53  i).    {.      S
35c0: 79 6e 63 28 69 29 3b 0a 20 20 20 20 20 20 69 66  ync(i);.      if
35d0: 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75   (_keyInfo[i].qu
35e0: 65 72 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65 74  ery != null) ret
35f0: 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e  urn _keyInfo[i].
3600: 71 75 65 72 79 2e 5f 72 65 61 64 65 72 2e 47 65  query._reader.Ge
3610: 74 44 6f 75 62 6c 65 28 5f 6b 65 79 49 6e 66 6f  tDouble(_keyInfo
3620: 5b 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20  [i].column);.   
3630: 20 20 20 65 6c 73 65 20 74 68 72 6f 77 20 6e 65     else throw ne
3640: 77 20 49 6e 76 61 6c 69 64 43 61 73 74 45 78 63  w InvalidCastExc
3650: 65 70 74 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a  eption();.    }.
3660: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 66 6c  .    internal fl
3670: 6f 61 74 20 47 65 74 46 6c 6f 61 74 28 69 6e 74  oat GetFloat(int
3680: 20 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   i).    {.      
3690: 53 79 6e 63 28 69 29 3b 0a 20 20 20 20 20 20 69  Sync(i);.      i
36a0: 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71  f (_keyInfo[i].q
36b0: 75 65 72 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65  uery != null) re
36c0: 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d  turn _keyInfo[i]
36d0: 2e 71 75 65 72 79 2e 5f 72 65 61 64 65 72 2e 47  .query._reader.G
36e0: 65 74 46 6c 6f 61 74 28 5f 6b 65 79 49 6e 66 6f  etFloat(_keyInfo
36f0: 5b 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20  [i].column);.   
3700: 20 20 20 65 6c 73 65 20 74 68 72 6f 77 20 6e 65     else throw ne
3710: 77 20 49 6e 76 61 6c 69 64 43 61 73 74 45 78 63  w InvalidCastExc
3720: 65 70 74 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a  eption();.    }.
3730: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 47 75  .    internal Gu
3740: 69 64 20 47 65 74 47 75 69 64 28 69 6e 74 20 69  id GetGuid(int i
3750: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53 79  ).    {.      Sy
3760: 6e 63 28 69 29 3b 0a 20 20 20 20 20 20 69 66 20  nc(i);.      if 
3770: 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65  (_keyInfo[i].que
3780: 72 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65 74 75  ry != null) retu
3790: 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71  rn _keyInfo[i].q
37a0: 75 65 72 79 2e 5f 72 65 61 64 65 72 2e 47 65 74  uery._reader.Get
37b0: 47 75 69 64 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d  Guid(_keyInfo[i]
37c0: 2e 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20 20 20  .column);.      
37d0: 65 6c 73 65 20 74 68 72 6f 77 20 6e 65 77 20 49  else throw new I
37e0: 6e 76 61 6c 69 64 43 61 73 74 45 78 63 65 70 74  nvalidCastExcept
37f0: 69 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  ion();.    }..  
3800: 20 20 69 6e 74 65 72 6e 61 6c 20 49 6e 74 31 36    internal Int16
3810: 20 47 65 74 49 6e 74 31 36 28 69 6e 74 20 69 29   GetInt16(int i)
3820: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53 79 6e  .    {.      Syn
3830: 63 28 69 29 3b 0a 20 20 20 20 20 20 69 66 20 28  c(i);.      if (
3840: 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65 72  _keyInfo[i].quer
3850: 79 20 21 3d 20 6e 75 6c 6c 29 20 72 65 74 75 72  y != null) retur
3860: 6e 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75  n _keyInfo[i].qu
3870: 65 72 79 2e 5f 72 65 61 64 65 72 2e 47 65 74 49  ery._reader.GetI
3880: 6e 74 31 36 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d  nt16(_keyInfo[i]
3890: 2e 63 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20 20 20  .column);.      
38a0: 65 6c 73 65 0a 20 20 20 20 20 20 7b 0a 20 20 20  else.      {.   
38b0: 20 20 20 20 20 6c 6f 6e 67 20 72 6f 77 69 64 20       long rowid 
38c0: 3d 20 5f 73 74 6d 74 2e 5f 73 71 6c 2e 47 65 74  = _stmt._sql.Get
38d0: 52 6f 77 49 64 46 6f 72 43 75 72 73 6f 72 28 5f  RowIdForCursor(_
38e0: 73 74 6d 74 2c 20 5f 6b 65 79 49 6e 66 6f 5b 69  stmt, _keyInfo[i
38f0: 5d 2e 63 75 72 73 6f 72 29 3b 0a 20 20 20 20 20  ].cursor);.     
3900: 20 20 20 69 66 20 28 72 6f 77 69 64 20 3d 3d 20     if (rowid == 
3910: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76  0) throw new Inv
3920: 61 6c 69 64 43 61 73 74 45 78 63 65 70 74 69 6f  alidCastExceptio
3930: 6e 28 29 3b 0a 20 20 20 20 20 20 20 20 72 65 74  n();.        ret
3940: 75 72 6e 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e  urn Convert.ToIn
3950: 74 31 36 28 72 6f 77 69 64 29 3b 0a 20 20 20 20  t16(rowid);.    
3960: 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69    }.    }..    i
3970: 6e 74 65 72 6e 61 6c 20 49 6e 74 33 32 20 47 65  nternal Int32 Ge
3980: 74 49 6e 74 33 32 28 69 6e 74 20 69 29 0a 20 20  tInt32(int i).  
3990: 20 20 7b 0a 20 20 20 20 20 20 53 79 6e 63 28 69    {.      Sync(i
39a0: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 5f 6b 65  );.      if (_ke
39b0: 79 49 6e 66 6f 5b 69 5d 2e 71 75 65 72 79 20 21  yInfo[i].query !
39c0: 3d 20 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 5f  = null) return _
39d0: 6b 65 79 49 6e 66 6f 5b 69 5d 2e 71 75 65 72 79  keyInfo[i].query
39e0: 2e 5f 72 65 61 64 65 72 2e 47 65 74 49 6e 74 33  ._reader.GetInt3
39f0: 32 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 63 6f  2(_keyInfo[i].co
3a00: 6c 75 6d 6e 29 3b 0a 20 20 20 20 20 20 65 6c 73  lumn);.      els
3a10: 65 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  e.      {.      
3a20: 20 20 6c 6f 6e 67 20 72 6f 77 69 64 20 3d 20 5f    long rowid = _
3a30: 73 74 6d 74 2e 5f 73 71 6c 2e 47 65 74 52 6f 77  stmt._sql.GetRow
3a40: 49 64 46 6f 72 43 75 72 73 6f 72 28 5f 73 74 6d  IdForCursor(_stm
3a50: 74 2c 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 63  t, _keyInfo[i].c
3a60: 75 72 73 6f 72 29 3b 0a 20 20 20 20 20 20 20 20  ursor);.        
3a70: 69 66 20 28 72 6f 77 69 64 20 3d 3d 20 30 29 20  if (rowid == 0) 
3a80: 74 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69  throw new Invali
3a90: 64 43 61 73 74 45 78 63 65 70 74 69 6f 6e 28 29  dCastException()
3aa0: 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ;.        return
3ab0: 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e 74 33 32   Convert.ToInt32
3ac0: 28 72 6f 77 69 64 29 3b 0a 20 20 20 20 20 20 7d  (rowid);.      }
3ad0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
3ae0: 72 6e 61 6c 20 49 6e 74 36 34 20 47 65 74 49 6e  rnal Int64 GetIn
3af0: 74 36 34 28 69 6e 74 20 69 29 0a 20 20 20 20 7b  t64(int i).    {
3b00: 0a 20 20 20 20 20 20 53 79 6e 63 28 69 29 3b 0a  .      Sync(i);.
3b10: 20 20 20 20 20 20 69 66 20 28 5f 6b 65 79 49 6e        if (_keyIn
3b20: 66 6f 5b 69 5d 2e 71 75 65 72 79 20 21 3d 20 6e  fo[i].query != n
3b30: 75 6c 6c 29 20 72 65 74 75 72 6e 20 5f 6b 65 79  ull) return _key
3b40: 49 6e 66 6f 5b 69 5d 2e 71 75 65 72 79 2e 5f 72  Info[i].query._r
3b50: 65 61 64 65 72 2e 47 65 74 49 6e 74 36 34 28 5f  eader.GetInt64(_
3b60: 6b 65 79 49 6e 66 6f 5b 69 5d 2e 63 6f 6c 75 6d  keyInfo[i].colum
3b70: 6e 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 0a 20  n);.      else. 
3b80: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 6c       {.        l
3b90: 6f 6e 67 20 72 6f 77 69 64 20 3d 20 5f 73 74 6d  ong rowid = _stm
3ba0: 74 2e 5f 73 71 6c 2e 47 65 74 52 6f 77 49 64 46  t._sql.GetRowIdF
3bb0: 6f 72 43 75 72 73 6f 72 28 5f 73 74 6d 74 2c 20  orCursor(_stmt, 
3bc0: 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e 63 75 72 73  _keyInfo[i].curs
3bd0: 6f 72 29 3b 0a 20 20 20 20 20 20 20 20 69 66 20  or);.        if 
3be0: 28 72 6f 77 69 64 20 3d 3d 20 30 29 20 74 68 72  (rowid == 0) thr
3bf0: 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64 43 61  ow new InvalidCa
3c00: 73 74 45 78 63 65 70 74 69 6f 6e 28 29 3b 0a 20  stException();. 
3c10: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 43 6f         return Co
3c20: 6e 76 65 72 74 2e 54 6f 49 6e 74 36 34 28 72 6f  nvert.ToInt64(ro
3c30: 77 69 64 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  wid);.      }.  
3c40: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
3c50: 6c 20 73 74 72 69 6e 67 20 47 65 74 53 74 72 69  l string GetStri
3c60: 6e 67 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a  ng(int i).    {.
3c70: 20 20 20 20 20 20 53 79 6e 63 28 69 29 3b 0a 20        Sync(i);. 
3c80: 20 20 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66       if (_keyInf
3c90: 6f 5b 69 5d 2e 71 75 65 72 79 20 21 3d 20 6e 75  o[i].query != nu
3ca0: 6c 6c 29 20 72 65 74 75 72 6e 20 5f 6b 65 79 49  ll) return _keyI
3cb0: 6e 66 6f 5b 69 5d 2e 71 75 65 72 79 2e 5f 72 65  nfo[i].query._re
3cc0: 61 64 65 72 2e 47 65 74 53 74 72 69 6e 67 28 5f  ader.GetString(_
3cd0: 6b 65 79 49 6e 66 6f 5b 69 5d 2e 63 6f 6c 75 6d  keyInfo[i].colum
3ce0: 6e 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 74  n);.      else t
3cf0: 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64  hrow new Invalid
3d00: 43 61 73 74 45 78 63 65 70 74 69 6f 6e 28 29 3b  CastException();
3d10: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
3d20: 72 6e 61 6c 20 6f 62 6a 65 63 74 20 47 65 74 56  rnal object GetV
3d30: 61 6c 75 65 28 69 6e 74 20 69 29 0a 20 20 20 20  alue(int i).    
3d40: 7b 0a 20 20 20 20 20 20 69 66 20 28 5f 6b 65 79  {.      if (_key
3d50: 49 6e 66 6f 5b 69 5d 2e 63 75 72 73 6f 72 20 3d  Info[i].cursor =
3d60: 3d 20 2d 31 29 20 72 65 74 75 72 6e 20 44 42 4e  = -1) return DBN
3d70: 75 6c 6c 2e 56 61 6c 75 65 3b 0a 0a 20 20 20 20  ull.Value;..    
3d80: 20 20 53 79 6e 63 28 69 29 3b 0a 20 20 20 20 20    Sync(i);.     
3d90: 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d   if (_keyInfo[i]
3da0: 2e 71 75 65 72 79 20 21 3d 20 6e 75 6c 6c 29 20  .query != null) 
3db0: 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b  return _keyInfo[
3dc0: 69 5d 2e 71 75 65 72 79 2e 5f 72 65 61 64 65 72  i].query._reader
3dd0: 2e 47 65 74 56 61 6c 75 65 28 5f 6b 65 79 49 6e  .GetValue(_keyIn
3de0: 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 0a  fo[i].column);..
3df0: 20 20 20 20 20 20 69 66 20 28 49 73 44 42 4e 75        if (IsDBNu
3e00: 6c 6c 28 69 29 20 3d 3d 20 74 72 75 65 29 0a 20  ll(i) == true). 
3e10: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 44 42         return DB
3e20: 4e 75 6c 6c 2e 56 61 6c 75 65 3b 0a 20 20 20 20  Null.Value;.    
3e30: 20 20 65 6c 73 65 20 72 65 74 75 72 6e 20 47 65    else return Ge
3e40: 74 49 6e 74 36 34 28 69 29 3b 0a 20 20 20 20 7d  tInt64(i);.    }
3e50: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 62  ..    internal b
3e60: 6f 6f 6c 20 49 73 44 42 4e 75 6c 6c 28 69 6e 74  ool IsDBNull(int
3e70: 20 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   i).    {.      
3e80: 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d 2e  if (_keyInfo[i].
3e90: 63 75 72 73 6f 72 20 3d 3d 20 2d 31 29 20 72 65  cursor == -1) re
3ea0: 74 75 72 6e 20 74 72 75 65 3b 0a 0a 20 20 20 20  turn true;..    
3eb0: 20 20 53 79 6e 63 28 69 29 3b 0a 20 20 20 20 20    Sync(i);.     
3ec0: 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b 69 5d   if (_keyInfo[i]
3ed0: 2e 71 75 65 72 79 20 21 3d 20 6e 75 6c 6c 29 20  .query != null) 
3ee0: 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 5b  return _keyInfo[
3ef0: 69 5d 2e 71 75 65 72 79 2e 5f 72 65 61 64 65 72  i].query._reader
3f00: 2e 49 73 44 42 4e 75 6c 6c 28 5f 6b 65 79 49 6e  .IsDBNull(_keyIn
3f10: 66 6f 5b 69 5d 2e 63 6f 6c 75 6d 6e 29 3b 0a 20  fo[i].column);. 
3f20: 20 20 20 20 20 65 6c 73 65 20 72 65 74 75 72 6e       else return
3f30: 20 5f 73 74 6d 74 2e 5f 73 71 6c 2e 47 65 74 52   _stmt._sql.GetR
3f40: 6f 77 49 64 46 6f 72 43 75 72 73 6f 72 28 5f 73  owIdForCursor(_s
3f50: 74 6d 74 2c 20 5f 6b 65 79 49 6e 66 6f 5b 69 5d  tmt, _keyInfo[i]
3f60: 2e 63 75 72 73 6f 72 29 20 3d 3d 20 30 3b 0a 20  .cursor) == 0;. 
3f70: 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73     }..    /// <s
3f80: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
3f90: 41 70 70 65 6e 64 20 61 6c 6c 20 74 68 65 20 63  Append all the c
3fa0: 6f 6c 75 6d 6e 73 20 77 65 27 76 65 20 61 64 64  olumns we've add
3fb0: 65 64 20 74 6f 20 74 68 65 20 6f 72 69 67 69 6e  ed to the origin
3fc0: 61 6c 20 71 75 65 72 79 20 74 6f 20 74 68 65 20  al query to the 
3fd0: 73 63 68 65 6d 61 0a 20 20 20 20 2f 2f 2f 20 3c  schema.    /// <
3fe0: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  /summary>.    //
3ff0: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 74  / <param name="t
4000: 62 6c 22 3e 3c 2f 70 61 72 61 6d 3e 0a 20 20 20  bl"></param>.   
4010: 20 69 6e 74 65 72 6e 61 6c 20 76 6f 69 64 20 41   internal void A
4020: 70 70 65 6e 64 53 63 68 65 6d 61 54 61 62 6c 65  ppendSchemaTable
4030: 28 44 61 74 61 54 61 62 6c 65 20 74 62 6c 29 0a  (DataTable tbl).
4040: 20 20 20 20 7b 0a 20 20 20 20 20 20 4b 65 79 51      {.      KeyQ
4050: 75 65 72 79 20 6c 61 73 74 20 3d 20 6e 75 6c 6c  uery last = null
4060: 3b 0a 0a 20 20 20 20 20 20 66 6f 72 20 28 69 6e  ;..      for (in
4070: 74 20 6e 20 3d 20 30 3b 20 6e 20 3c 20 5f 6b 65  t n = 0; n < _ke
4080: 79 49 6e 66 6f 2e 4c 65 6e 67 74 68 3b 20 6e 2b  yInfo.Length; n+
4090: 2b 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  +).      {.     
40a0: 20 20 20 69 66 20 28 5f 6b 65 79 49 6e 66 6f 5b     if (_keyInfo[
40b0: 6e 5d 2e 71 75 65 72 79 20 3d 3d 20 6e 75 6c 6c  n].query == null
40c0: 20 7c 7c 20 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e   || _keyInfo[n].
40d0: 71 75 65 72 79 20 21 3d 20 6c 61 73 74 29 0a 20  query != last). 
40e0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
40f0: 20 20 20 6c 61 73 74 20 3d 20 5f 6b 65 79 49 6e     last = _keyIn
4100: 66 6f 5b 6e 5d 2e 71 75 65 72 79 3b 0a 0a 20 20  fo[n].query;..  
4110: 20 20 20 20 20 20 20 20 69 66 20 28 6c 61 73 74          if (last
4120: 20 3d 3d 20 6e 75 6c 6c 29 20 2f 2f 20 52 4f 57   == null) // ROW
4130: 49 44 20 61 6c 69 61 73 65 73 20 61 72 65 20 74  ID aliases are t
4140: 72 65 61 74 65 64 20 73 70 65 63 69 61 6c 0a 20  reated special. 
4150: 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20           {.     
4160: 20 20 20 20 20 20 20 44 61 74 61 52 6f 77 20 72         DataRow r
4170: 6f 77 20 3d 20 74 62 6c 2e 4e 65 77 52 6f 77 28  ow = tbl.NewRow(
4180: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  );.            r
4190: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
41a0: 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e 4e 61 6d 65 5d  lumn.ColumnName]
41b0: 20 3d 20 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e 63   = _keyInfo[n].c
41c0: 6f 6c 75 6d 6e 4e 61 6d 65 3b 0a 20 20 20 20 20  olumnName;.     
41d0: 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d         row[Schem
41e0: 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c  aTableColumn.Col
41f0: 75 6d 6e 4f 72 64 69 6e 61 6c 5d 20 3d 20 74 62  umnOrdinal] = tb
4200: 6c 2e 52 6f 77 73 2e 43 6f 75 6e 74 3b 0a 20 20  l.Rows.Count;.  
4210: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
4220: 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e  hemaTableColumn.
4230: 43 6f 6c 75 6d 6e 53 69 7a 65 5d 20 3d 20 38 3b  ColumnSize] = 8;
4240: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77  .            row
4250: 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  [SchemaTableColu
4260: 6d 6e 2e 4e 75 6d 65 72 69 63 50 72 65 63 69 73  mn.NumericPrecis
4270: 69 6f 6e 5d 20 3d 20 32 35 35 3b 0a 20 20 20 20  ion] = 255;.    
4280: 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65          row[Sche
4290: 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 4e 75  maTableColumn.Nu
42a0: 6d 65 72 69 63 53 63 61 6c 65 5d 20 3d 20 32 35  mericScale] = 25
42b0: 35 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  5;.            r
42c0: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
42d0: 6c 75 6d 6e 2e 50 72 6f 76 69 64 65 72 54 79 70  lumn.ProviderTyp
42e0: 65 5d 20 3d 20 44 62 54 79 70 65 2e 49 6e 74 36  e] = DbType.Int6
42f0: 34 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  4;.            r
4300: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
4310: 6c 75 6d 6e 2e 49 73 4c 6f 6e 67 5d 20 3d 20 66  lumn.IsLong] = f
4320: 61 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 20 20  alse;.          
4330: 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c    row[SchemaTabl
4340: 65 43 6f 6c 75 6d 6e 2e 41 6c 6c 6f 77 44 42 4e  eColumn.AllowDBN
4350: 75 6c 6c 5d 20 3d 20 66 61 6c 73 65 3b 0a 20 20  ull] = false;.  
4360: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
4370: 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61  hemaTableOptiona
4380: 6c 43 6f 6c 75 6d 6e 2e 49 73 52 65 61 64 4f 6e  lColumn.IsReadOn
4390: 6c 79 5d 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20  ly] = false;.   
43a0: 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68           row[Sch
43b0: 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c  emaTableOptional
43c0: 43 6f 6c 75 6d 6e 2e 49 73 52 6f 77 56 65 72 73  Column.IsRowVers
43d0: 69 6f 6e 5d 20 3d 20 66 61 6c 73 65 3b 0a 20 20  ion] = false;.  
43e0: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
43f0: 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e  hemaTableColumn.
4400: 49 73 55 6e 69 71 75 65 5d 20 3d 20 66 61 6c 73  IsUnique] = fals
4410: 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  e;.            r
4420: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
4430: 6c 75 6d 6e 2e 49 73 4b 65 79 5d 20 3d 20 74 72  lumn.IsKey] = tr
4440: 75 65 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ue;.            
4450: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43  row[SchemaTableC
4460: 6f 6c 75 6d 6e 2e 44 61 74 61 54 79 70 65 5d 20  olumn.DataType] 
4470: 3d 20 74 79 70 65 6f 66 28 49 6e 74 36 34 29 3b  = typeof(Int64);
4480: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77  .            row
4490: 5b 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69  [SchemaTableOpti
44a0: 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 48 69 64  onalColumn.IsHid
44b0: 64 65 6e 5d 20 3d 20 74 72 75 65 3b 0a 20 20 20  den] = true;.   
44c0: 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68           row[Sch
44d0: 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42  emaTableColumn.B
44e0: 61 73 65 43 6f 6c 75 6d 6e 4e 61 6d 65 5d 20 3d  aseColumnName] =
44f0: 20 5f 6b 65 79 49 6e 66 6f 5b 6e 5d 2e 63 6f 6c   _keyInfo[n].col
4500: 75 6d 6e 4e 61 6d 65 3b 0a 20 20 20 20 20 20 20  umnName;.       
4510: 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54       row[SchemaT
4520: 61 62 6c 65 43 6f 6c 75 6d 6e 2e 49 73 45 78 70  ableColumn.IsExp
4530: 72 65 73 73 69 6f 6e 5d 20 3d 20 66 61 6c 73 65  ression] = false
4540: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 6f  ;.            ro
4550: 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  w[SchemaTableCol
4560: 75 6d 6e 2e 49 73 41 6c 69 61 73 65 64 5d 20 3d  umn.IsAliased] =
4570: 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 20 20   false;.        
4580: 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61      row[SchemaTa
4590: 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65 54 61  bleColumn.BaseTa
45a0: 62 6c 65 4e 61 6d 65 5d 20 3d 20 5f 6b 65 79 49  bleName] = _keyI
45b0: 6e 66 6f 5b 6e 5d 2e 74 61 62 6c 65 4e 61 6d 65  nfo[n].tableName
45c0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 6f  ;.            ro
45d0: 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74  w[SchemaTableOpt
45e0: 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 42 61 73 65  ionalColumn.Base
45f0: 43 61 74 61 6c 6f 67 4e 61 6d 65 5d 20 3d 20 5f  CatalogName] = _
4600: 6b 65 79 49 6e 66 6f 5b 6e 5d 2e 64 61 74 61 62  keyInfo[n].datab
4610: 61 73 65 4e 61 6d 65 3b 0a 20 20 20 20 20 20 20  aseName;.       
4620: 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54       row[SchemaT
4630: 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75  ableOptionalColu
4640: 6d 6e 2e 49 73 41 75 74 6f 49 6e 63 72 65 6d 65  mn.IsAutoIncreme
4650: 6e 74 5d 20 3d 20 74 72 75 65 3b 0a 20 20 20 20  nt] = true;.    
4660: 20 20 20 20 20 20 20 20 72 6f 77 5b 22 44 61 74          row["Dat
4670: 61 54 79 70 65 4e 61 6d 65 22 5d 20 3d 20 22 69  aTypeName"] = "i
4680: 6e 74 65 67 65 72 22 3b 0a 0a 20 20 20 20 20 20  nteger";..      
4690: 20 20 20 20 20 20 74 62 6c 2e 52 6f 77 73 2e 41        tbl.Rows.A
46a0: 64 64 28 72 6f 77 29 3b 0a 20 20 20 20 20 20 20  dd(row);.       
46b0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 65     }.          e
46c0: 6c 73 65 0a 20 20 20 20 20 20 20 20 20 20 7b 0a  lse.          {.
46d0: 20 20 20 20 20 20 20 20 20 20 20 20 6c 61 73 74              last
46e0: 2e 53 79 6e 63 28 30 29 3b 0a 20 20 20 20 20 20  .Sync(0);.      
46f0: 20 20 20 20 20 20 75 73 69 6e 67 20 28 44 61 74        using (Dat
4700: 61 54 61 62 6c 65 20 74 62 6c 53 75 62 20 3d 20  aTable tblSub = 
4710: 6c 61 73 74 2e 5f 72 65 61 64 65 72 2e 47 65 74  last._reader.Get
4720: 53 63 68 65 6d 61 54 61 62 6c 65 28 29 29 0a 20  SchemaTable()). 
4730: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
4740: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 65 61             forea
4750: 63 68 20 28 44 61 74 61 52 6f 77 20 72 6f 77 20  ch (DataRow row 
4760: 69 6e 20 74 62 6c 53 75 62 2e 52 6f 77 73 29 0a  in tblSub.Rows).
4770: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a                {.
4780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4790: 6f 62 6a 65 63 74 5b 5d 20 6f 20 3d 20 72 6f 77  object[] o = row
47a0: 2e 49 74 65 6d 41 72 72 61 79 3b 0a 20 20 20 20  .ItemArray;.    
47b0: 20 20 20 20 20 20 20 20 20 20 20 20 44 61 74 61              Data
47c0: 52 6f 77 20 6e 65 77 72 6f 77 20 3d 20 74 62 6c  Row newrow = tbl
47d0: 2e 52 6f 77 73 2e 41 64 64 28 6f 29 3b 0a 20 20  .Rows.Add(o);.  
47e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6e 65                ne
47f0: 77 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65  wrow[SchemaTable
4800: 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49  OptionalColumn.I
4810: 73 48 69 64 64 65 6e 5d 20 3d 20 74 72 75 65 3b  sHidden] = true;
4820: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4830: 20 6e 65 77 72 6f 77 5b 53 63 68 65 6d 61 54 61   newrow[SchemaTa
4840: 62 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e  bleColumn.Column
4850: 4f 72 64 69 6e 61 6c 5d 20 3d 20 74 62 6c 2e 52  Ordinal] = tbl.R
4860: 6f 77 73 2e 43 6f 75 6e 74 20 2d 20 31 3b 0a 20  ows.Count - 1;. 
4870: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20               }. 
4880: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
4890: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
48a0: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d   }.      }.    }
48b0: 0a 20 20 7d 0a 7d 0a                             .  }.}.