System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 07ce3e91523ba7a77501daa4a4adc29b7822a5b3:


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 2e 43 6f 6d 6d 6f 6e 3b 0a 20 20 75 73 69  ta.Common;.  usi
0170: 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 43  ng System.Data.C
0180: 6f 6d 6d 6f 6e 2e 43 6f 6d 6d 61 6e 64 54 72 65  ommon.CommandTre
0190: 65 73 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74  es;.  using Syst
01a0: 65 6d 2e 44 61 74 61 2e 4d 65 74 61 64 61 74 61  em.Data.Metadata
01b0: 2e 45 64 6d 3b 0a 20 20 75 73 69 6e 67 20 53 79  .Edm;.  using Sy
01c0: 73 74 65 6d 2e 44 69 61 67 6e 6f 73 74 69 63 73  stem.Diagnostics
01d0: 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  ;.  using System
01e0: 2e 43 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47 65 6e  .Collections.Gen
01f0: 65 72 69 63 3b 0a 20 20 75 73 69 6e 67 20 53 79  eric;.  using Sy
0200: 73 74 65 6d 2e 54 65 78 74 3b 0a 20 20 75 73 69  stem.Text;.  usi
0210: 6e 67 20 53 79 73 74 65 6d 2e 47 6c 6f 62 61 6c  ng System.Global
0220: 69 7a 61 74 69 6f 6e 3b 0a 0a 20 20 69 6e 74 65  ization;..  inte
0230: 72 6e 61 6c 20 63 6c 61 73 73 20 53 51 4c 69 74  rnal class SQLit
0240: 65 50 72 6f 76 69 64 65 72 53 65 72 76 69 63 65  eProviderService
0250: 73 20 3a 20 44 62 50 72 6f 76 69 64 65 72 53 65  s : DbProviderSe
0260: 72 76 69 63 65 73 2c 20 49 53 51 4c 69 74 65 53  rvices, ISQLiteS
0270: 63 68 65 6d 61 45 78 74 65 6e 73 69 6f 6e 73 0a  chemaExtensions.
0280: 20 20 7b 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c    {.    internal
0290: 20 73 74 61 74 69 63 20 72 65 61 64 6f 6e 6c 79   static readonly
02a0: 20 53 51 4c 69 74 65 50 72 6f 76 69 64 65 72 53   SQLiteProviderS
02b0: 65 72 76 69 63 65 73 20 49 6e 73 74 61 6e 63 65  ervices Instance
02c0: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 50 72 6f   = new SQLitePro
02d0: 76 69 64 65 72 53 65 72 76 69 63 65 73 28 29 3b  viderServices();
02e0: 0a 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64 20  ..    protected 
02f0: 6f 76 65 72 72 69 64 65 20 44 62 43 6f 6d 6d 61  override DbComma
0300: 6e 64 44 65 66 69 6e 69 74 69 6f 6e 20 43 72 65  ndDefinition Cre
0310: 61 74 65 44 62 43 6f 6d 6d 61 6e 64 44 65 66 69  ateDbCommandDefi
0320: 6e 69 74 69 6f 6e 28 44 62 50 72 6f 76 69 64 65  nition(DbProvide
0330: 72 4d 61 6e 69 66 65 73 74 20 6d 61 6e 69 66 65  rManifest manife
0340: 73 74 2c 20 44 62 43 6f 6d 6d 61 6e 64 54 72 65  st, DbCommandTre
0350: 65 20 63 6f 6d 6d 61 6e 64 54 72 65 65 29 0a 20  e commandTree). 
0360: 20 20 20 7b 0a 20 20 20 20 20 20 44 62 43 6f 6d     {.      DbCom
0370: 6d 61 6e 64 20 70 72 6f 74 6f 74 79 70 65 20 3d  mand prototype =
0380: 20 43 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 6d   CreateCommand(m
0390: 61 6e 69 66 65 73 74 2c 20 63 6f 6d 6d 61 6e 64  anifest, command
03a0: 54 72 65 65 29 3b 0a 20 20 20 20 20 20 44 62 43  Tree);.      DbC
03b0: 6f 6d 6d 61 6e 64 44 65 66 69 6e 69 74 69 6f 6e  ommandDefinition
03c0: 20 72 65 73 75 6c 74 20 3d 20 74 68 69 73 2e 43   result = this.C
03d0: 72 65 61 74 65 43 6f 6d 6d 61 6e 64 44 65 66 69  reateCommandDefi
03e0: 6e 69 74 69 6f 6e 28 70 72 6f 74 6f 74 79 70 65  nition(prototype
03f0: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
0400: 72 65 73 75 6c 74 3b 0a 20 20 20 20 7d 0a 0a 20  result;.    }.. 
0410: 20 20 20 70 72 69 76 61 74 65 20 44 62 43 6f 6d     private DbCom
0420: 6d 61 6e 64 20 43 72 65 61 74 65 43 6f 6d 6d 61  mand CreateComma
0430: 6e 64 28 44 62 50 72 6f 76 69 64 65 72 4d 61 6e  nd(DbProviderMan
0440: 69 66 65 73 74 20 6d 61 6e 69 66 65 73 74 2c 20  ifest manifest, 
0450: 44 62 43 6f 6d 6d 61 6e 64 54 72 65 65 20 63 6f  DbCommandTree co
0460: 6d 6d 61 6e 64 54 72 65 65 29 0a 20 20 20 20 7b  mmandTree).    {
0470: 0a 20 20 20 20 20 20 69 66 20 28 6d 61 6e 69 66  .      if (manif
0480: 65 73 74 20 3d 3d 20 6e 75 6c 6c 29 0a 20 20 20  est == null).   
0490: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41       throw new A
04a0: 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70  rgumentNullExcep
04b0: 74 69 6f 6e 28 22 6d 61 6e 69 66 65 73 74 22 29  tion("manifest")
04c0: 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 63 6f 6d  ;..      if (com
04d0: 6d 61 6e 64 54 72 65 65 20 3d 3d 20 6e 75 6c 6c  mandTree == null
04e0: 29 0a 20 20 20 20 20 20 20 20 74 68 72 6f 77 20  ).        throw 
04f0: 6e 65 77 20 41 72 67 75 6d 65 6e 74 4e 75 6c 6c  new ArgumentNull
0500: 45 78 63 65 70 74 69 6f 6e 28 22 63 6f 6d 6d 61  Exception("comma
0510: 6e 64 54 72 65 65 22 29 3b 0a 0a 20 20 20 20 20  ndTree");..     
0520: 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63   SQLiteCommand c
0530: 6f 6d 6d 61 6e 64 20 3d 20 6e 65 77 20 53 51 4c  ommand = new SQL
0540: 69 74 65 43 6f 6d 6d 61 6e 64 28 29 3b 0a 20 20  iteCommand();.  
0550: 20 20 20 20 74 72 79 0a 20 20 20 20 20 20 7b 0a      try.      {.
0560: 20 20 20 20 20 20 20 20 4c 69 73 74 3c 44 62 50          List<DbP
0570: 61 72 61 6d 65 74 65 72 3e 20 70 61 72 61 6d 65  arameter> parame
0580: 74 65 72 73 3b 0a 20 20 20 20 20 20 20 20 43 6f  ters;.        Co
0590: 6d 6d 61 6e 64 54 79 70 65 20 63 6f 6d 6d 61 6e  mmandType comman
05a0: 64 54 79 70 65 3b 0a 0a 20 20 20 20 20 20 20 20  dType;..        
05b0: 63 6f 6d 6d 61 6e 64 2e 43 6f 6d 6d 61 6e 64 54  command.CommandT
05c0: 65 78 74 20 3d 20 53 71 6c 47 65 6e 65 72 61 74  ext = SqlGenerat
05d0: 6f 72 2e 47 65 6e 65 72 61 74 65 53 71 6c 28 28  or.GenerateSql((
05e0: 53 51 4c 69 74 65 50 72 6f 76 69 64 65 72 4d 61  SQLiteProviderMa
05f0: 6e 69 66 65 73 74 29 6d 61 6e 69 66 65 73 74 2c  nifest)manifest,
0600: 20 63 6f 6d 6d 61 6e 64 54 72 65 65 2c 20 6f 75   commandTree, ou
0610: 74 20 70 61 72 61 6d 65 74 65 72 73 2c 20 6f 75  t parameters, ou
0620: 74 20 63 6f 6d 6d 61 6e 64 54 79 70 65 29 3b 0a  t commandType);.
0630: 20 20 20 20 20 20 20 20 63 6f 6d 6d 61 6e 64 2e          command.
0640: 43 6f 6d 6d 61 6e 64 54 79 70 65 20 3d 20 63 6f  CommandType = co
0650: 6d 6d 61 6e 64 54 79 70 65 3b 0a 0a 20 20 20 20  mmandType;..    
0660: 20 20 20 20 2f 2f 20 47 65 74 20 74 68 65 20 66      // Get the f
0670: 75 6e 63 74 69 6f 6e 20 28 69 66 20 61 6e 79 29  unction (if any)
0680: 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20 62 79 20   implemented by 
0690: 74 68 65 20 63 6f 6d 6d 61 6e 64 20 74 72 65 65  the command tree
06a0: 20 73 69 6e 63 65 20 74 68 69 73 20 69 6e 66 6c   since this infl
06b0: 75 65 6e 63 65 73 20 6f 75 72 20 69 6e 74 65 72  uences our inter
06c0: 70 72 65 74 61 74 69 6f 6e 20 6f 66 20 70 61 72  pretation of par
06d0: 61 6d 65 74 65 72 73 0a 20 20 20 20 20 20 20 20  ameters.        
06e0: 45 64 6d 46 75 6e 63 74 69 6f 6e 20 66 75 6e 63  EdmFunction func
06f0: 74 69 6f 6e 20 3d 20 6e 75 6c 6c 3b 0a 20 20 20  tion = null;.   
0700: 20 20 20 20 20 69 66 20 28 63 6f 6d 6d 61 6e 64       if (command
0710: 54 72 65 65 20 69 73 20 44 62 46 75 6e 63 74 69  Tree is DbFuncti
0720: 6f 6e 43 6f 6d 6d 61 6e 64 54 72 65 65 29 0a 20  onCommandTree). 
0730: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
0740: 20 20 20 66 75 6e 63 74 69 6f 6e 20 3d 20 28 28     function = ((
0750: 44 62 46 75 6e 63 74 69 6f 6e 43 6f 6d 6d 61 6e  DbFunctionComman
0760: 64 54 72 65 65 29 63 6f 6d 6d 61 6e 64 54 72 65  dTree)commandTre
0770: 65 29 2e 45 64 6d 46 75 6e 63 74 69 6f 6e 3b 0a  e).EdmFunction;.
0780: 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20          }..     
0790: 20 20 20 2f 2f 20 4e 6f 77 20 6d 61 6b 65 20 73     // Now make s
07a0: 75 72 65 20 77 65 20 70 6f 70 75 6c 61 74 65 20  ure we populate 
07b0: 74 68 65 20 63 6f 6d 6d 61 6e 64 27 73 20 70 61  the command's pa
07c0: 72 61 6d 65 74 65 72 73 20 66 72 6f 6d 20 74 68  rameters from th
07d0: 65 20 43 51 54 27 73 20 70 61 72 61 6d 65 74 65  e CQT's paramete
07e0: 72 73 3a 0a 20 20 20 20 20 20 20 20 66 6f 72 65  rs:.        fore
07f0: 61 63 68 20 28 4b 65 79 56 61 6c 75 65 50 61 69  ach (KeyValuePai
0800: 72 3c 73 74 72 69 6e 67 2c 20 54 79 70 65 55 73  r<string, TypeUs
0810: 61 67 65 3e 20 71 75 65 72 79 50 61 72 61 6d 65  age> queryParame
0820: 74 65 72 20 69 6e 20 63 6f 6d 6d 61 6e 64 54 72  ter in commandTr
0830: 65 65 2e 50 61 72 61 6d 65 74 65 72 73 29 0a 20  ee.Parameters). 
0840: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
0850: 20 20 20 53 51 4c 69 74 65 50 61 72 61 6d 65 74     SQLiteParamet
0860: 65 72 20 70 61 72 61 6d 65 74 65 72 3b 0a 0a 20  er parameter;.. 
0870: 20 20 20 20 20 20 20 20 20 2f 2f 20 55 73 65 20           // Use 
0880: 74 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e  the correspondin
0890: 67 20 66 75 6e 63 74 69 6f 6e 20 70 61 72 61 6d  g function param
08a0: 65 74 65 72 20 54 79 70 65 55 73 61 67 65 20 77  eter TypeUsage w
08b0: 68 65 72 65 20 61 76 61 69 6c 61 62 6c 65 20 28  here available (
08c0: 63 75 72 72 65 6e 74 6c 79 2c 20 74 68 65 20 53  currently, the S
08d0: 53 44 4c 20 66 61 63 65 74 73 20 61 6e 64 20 0a  SDL facets and .
08e0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 74 79 70            // typ
08f0: 65 20 74 72 75 6d 70 20 75 73 65 72 2d 64 65 66  e trump user-def
0900: 69 6e 65 64 20 66 61 63 65 74 73 20 61 6e 64 20  ined facets and 
0910: 74 79 70 65 20 69 6e 20 74 68 65 20 45 6e 74 69  type in the Enti
0920: 74 79 43 6f 6d 6d 61 6e 64 29 2e 0a 20 20 20 20  tyCommand)..    
0930: 20 20 20 20 20 20 46 75 6e 63 74 69 6f 6e 50 61        FunctionPa
0940: 72 61 6d 65 74 65 72 20 66 75 6e 63 74 69 6f 6e  rameter function
0950: 50 61 72 61 6d 65 74 65 72 3b 0a 20 20 20 20 20  Parameter;.     
0960: 20 20 20 20 20 69 66 20 28 6e 75 6c 6c 20 21 3d       if (null !=
0970: 20 66 75 6e 63 74 69 6f 6e 20 26 26 20 66 75 6e   function && fun
0980: 63 74 69 6f 6e 2e 50 61 72 61 6d 65 74 65 72 73  ction.Parameters
0990: 2e 54 72 79 47 65 74 56 61 6c 75 65 28 71 75 65  .TryGetValue(que
09a0: 72 79 50 61 72 61 6d 65 74 65 72 2e 4b 65 79 2c  ryParameter.Key,
09b0: 20 66 61 6c 73 65 2c 20 6f 75 74 20 66 75 6e 63   false, out func
09c0: 74 69 6f 6e 50 61 72 61 6d 65 74 65 72 29 29 0a  tionParameter)).
09d0: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
09e0: 20 20 20 20 20 20 20 20 70 61 72 61 6d 65 74 65          paramete
09f0: 72 20 3d 20 43 72 65 61 74 65 53 71 6c 50 61 72  r = CreateSqlPar
0a00: 61 6d 65 74 65 72 28 66 75 6e 63 74 69 6f 6e 50  ameter(functionP
0a10: 61 72 61 6d 65 74 65 72 2e 4e 61 6d 65 2c 20 66  arameter.Name, f
0a20: 75 6e 63 74 69 6f 6e 50 61 72 61 6d 65 74 65 72  unctionParameter
0a30: 2e 54 79 70 65 55 73 61 67 65 2c 20 66 75 6e 63  .TypeUsage, func
0a40: 74 69 6f 6e 50 61 72 61 6d 65 74 65 72 2e 4d 6f  tionParameter.Mo
0a50: 64 65 2c 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65  de, DBNull.Value
0a60: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  );.          }. 
0a70: 20 20 20 20 20 20 20 20 20 65 6c 73 65 0a 20 20           else.  
0a80: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
0a90: 20 20 20 20 20 20 70 61 72 61 6d 65 74 65 72 20        parameter 
0aa0: 3d 20 43 72 65 61 74 65 53 71 6c 50 61 72 61 6d  = CreateSqlParam
0ab0: 65 74 65 72 28 71 75 65 72 79 50 61 72 61 6d 65  eter(queryParame
0ac0: 74 65 72 2e 4b 65 79 2c 20 71 75 65 72 79 50 61  ter.Key, queryPa
0ad0: 72 61 6d 65 74 65 72 2e 56 61 6c 75 65 2c 20 50  rameter.Value, P
0ae0: 61 72 61 6d 65 74 65 72 4d 6f 64 65 2e 49 6e 2c  arameterMode.In,
0af0: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 29 3b 0a   DBNull.Value);.
0b00: 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20            }..   
0b10: 20 20 20 20 20 20 20 63 6f 6d 6d 61 6e 64 2e 50         command.P
0b20: 61 72 61 6d 65 74 65 72 73 2e 41 64 64 28 70 61  arameters.Add(pa
0b30: 72 61 6d 65 74 65 72 29 3b 0a 20 20 20 20 20 20  rameter);.      
0b40: 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20    }..        // 
0b50: 4e 6f 77 20 61 64 64 20 70 61 72 61 6d 65 74 65  Now add paramete
0b60: 72 73 20 61 64 64 65 64 20 61 73 20 70 61 72 74  rs added as part
0b70: 20 6f 66 20 53 51 4c 20 67 65 6e 20 28 6e 6f 74   of SQL gen (not
0b80: 65 3a 20 74 68 69 73 20 66 65 61 74 75 72 65 20  e: this feature 
0b90: 69 73 20 6f 6e 6c 79 20 73 61 66 65 20 66 6f 72  is only safe for
0ba0: 20 44 4d 4c 20 53 51 4c 20 67 65 6e 20 77 68 69   DML SQL gen whi
0bb0: 63 68 0a 20 20 20 20 20 20 20 20 2f 2f 20 64 6f  ch.        // do
0bc0: 65 73 20 6e 6f 74 20 73 75 70 70 6f 72 74 20 75  es not support u
0bd0: 73 65 72 20 70 61 72 61 6d 65 74 65 72 73 2c 20  ser parameters, 
0be0: 77 68 65 72 65 20 74 68 65 72 65 20 69 73 20 6e  where there is n
0bf0: 6f 20 72 69 73 6b 20 6f 66 20 6e 61 6d 65 20 63  o risk of name c
0c00: 6f 6c 6c 69 73 69 6f 6e 29 0a 20 20 20 20 20 20  ollision).      
0c10: 20 20 69 66 20 28 6e 75 6c 6c 20 21 3d 20 70 61    if (null != pa
0c20: 72 61 6d 65 74 65 72 73 20 26 26 20 30 20 3c 20  rameters && 0 < 
0c30: 70 61 72 61 6d 65 74 65 72 73 2e 43 6f 75 6e 74  parameters.Count
0c40: 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20  ).        {.    
0c50: 20 20 20 20 20 20 69 66 20 28 21 28 63 6f 6d 6d        if (!(comm
0c60: 61 6e 64 54 72 65 65 20 69 73 20 44 62 49 6e 73  andTree is DbIns
0c70: 65 72 74 43 6f 6d 6d 61 6e 64 54 72 65 65 29 20  ertCommandTree) 
0c80: 26 26 0a 20 20 20 20 20 20 20 20 20 20 20 20 21  &&.            !
0c90: 28 63 6f 6d 6d 61 6e 64 54 72 65 65 20 69 73 20  (commandTree is 
0ca0: 44 62 55 70 64 61 74 65 43 6f 6d 6d 61 6e 64 54  DbUpdateCommandT
0cb0: 72 65 65 29 20 26 26 0a 20 20 20 20 20 20 20 20  ree) &&.        
0cc0: 20 20 20 20 21 28 63 6f 6d 6d 61 6e 64 54 72 65      !(commandTre
0cd0: 65 20 69 73 20 44 62 44 65 6c 65 74 65 43 6f 6d  e is DbDeleteCom
0ce0: 6d 61 6e 64 54 72 65 65 29 29 0a 20 20 20 20 20  mandTree)).     
0cf0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20       {.         
0d00: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76     throw new Inv
0d10: 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63  alidOperationExc
0d20: 65 70 74 69 6f 6e 28 22 53 71 6c 47 65 6e 50 61  eption("SqlGenPa
0d30: 72 61 6d 65 74 65 72 73 4e 6f 74 50 65 72 6d 69  rametersNotPermi
0d40: 74 74 65 64 22 29 3b 0a 20 20 20 20 20 20 20 20  tted");.        
0d50: 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 66    }..          f
0d60: 6f 72 65 61 63 68 20 28 44 62 50 61 72 61 6d 65  oreach (DbParame
0d70: 74 65 72 20 70 61 72 61 6d 65 74 65 72 20 69 6e  ter parameter in
0d80: 20 70 61 72 61 6d 65 74 65 72 73 29 0a 20 20 20   parameters).   
0d90: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
0da0: 20 20 20 20 20 63 6f 6d 6d 61 6e 64 2e 50 61 72       command.Par
0db0: 61 6d 65 74 65 72 73 2e 41 64 64 28 70 61 72 61  ameters.Add(para
0dc0: 6d 65 74 65 72 29 3b 0a 20 20 20 20 20 20 20 20  meter);.        
0dd0: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20    }.        }.. 
0de0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 63 6f         return co
0df0: 6d 6d 61 6e 64 3b 0a 20 20 20 20 20 20 7d 0a 20  mmand;.      }. 
0e00: 20 20 20 20 20 63 61 74 63 68 0a 20 20 20 20 20       catch.     
0e10: 20 7b 0a 20 20 20 20 20 20 20 20 63 6f 6d 6d 61   {.        comma
0e20: 6e 64 2e 44 69 73 70 6f 73 65 28 29 3b 0a 20 20  nd.Dispose();.  
0e30: 20 20 20 20 20 20 74 68 72 6f 77 3b 0a 20 20 20        throw;.   
0e40: 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20     }.    }..    
0e50: 70 72 6f 74 65 63 74 65 64 20 6f 76 65 72 72 69  protected overri
0e60: 64 65 20 73 74 72 69 6e 67 20 47 65 74 44 62 50  de string GetDbP
0e70: 72 6f 76 69 64 65 72 4d 61 6e 69 66 65 73 74 54  roviderManifestT
0e80: 6f 6b 65 6e 28 44 62 43 6f 6e 6e 65 63 74 69 6f  oken(DbConnectio
0e90: 6e 20 63 6f 6e 6e 65 63 74 69 6f 6e 29 0a 20 20  n connection).  
0ea0: 20 20 7b 0a 20 20 20 20 20 20 69 66 20 28 53 74    {.      if (St
0eb0: 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70  ring.IsNullOrEmp
0ec0: 74 79 28 63 6f 6e 6e 65 63 74 69 6f 6e 2e 43 6f  ty(connection.Co
0ed0: 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e 67 29 29  nnectionString))
0ee0: 0a 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e  .        throw n
0ef0: 65 77 20 41 72 67 75 6d 65 6e 74 4e 75 6c 6c 45  ew ArgumentNullE
0f00: 78 63 65 70 74 69 6f 6e 28 22 43 6f 6e 6e 65 63  xception("Connec
0f10: 74 69 6f 6e 53 74 72 69 6e 67 22 29 3b 0a 0a 20  tionString");.. 
0f20: 20 20 20 20 20 62 6f 6f 6c 20 70 61 72 73 65 56       bool parseV
0f30: 69 61 46 72 61 6d 65 77 6f 72 6b 20 3d 20 66 61  iaFramework = fa
0f40: 6c 73 65 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  lse;..      if (
0f50: 63 6f 6e 6e 65 63 74 69 6f 6e 20 69 73 20 53 51  connection is SQ
0f60: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 29 0a  LiteConnection).
0f70: 20 20 20 20 20 20 20 20 20 20 70 61 72 73 65 56            parseV
0f80: 69 61 46 72 61 6d 65 77 6f 72 6b 20 3d 20 28 28  iaFramework = ((
0f90: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
0fa0: 29 63 6f 6e 6e 65 63 74 69 6f 6e 29 2e 50 61 72  )connection).Par
0fb0: 73 65 56 69 61 46 72 61 6d 65 77 6f 72 6b 3b 0a  seViaFramework;.
0fc0: 0a 20 20 20 20 20 20 53 6f 72 74 65 64 4c 69 73  .      SortedLis
0fd0: 74 3c 73 74 72 69 6e 67 2c 20 73 74 72 69 6e 67  t<string, string
0fe0: 3e 20 6f 70 74 73 20 3d 20 70 61 72 73 65 56 69  > opts = parseVi
0ff0: 61 46 72 61 6d 65 77 6f 72 6b 20 3f 0a 20 20 20  aFramework ?.   
1000: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e         SQLiteCon
1010: 6e 65 63 74 69 6f 6e 2e 50 61 72 73 65 43 6f 6e  nection.ParseCon
1020: 6e 65 63 74 69 6f 6e 53 74 72 69 6e 67 56 69 61  nectionStringVia
1030: 46 72 61 6d 65 77 6f 72 6b 28 63 6f 6e 6e 65 63  Framework(connec
1040: 74 69 6f 6e 2e 43 6f 6e 6e 65 63 74 69 6f 6e 53  tion.ConnectionS
1050: 74 72 69 6e 67 2c 20 66 61 6c 73 65 29 20 3a 0a  tring, false) :.
1060: 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65            SQLite
1070: 43 6f 6e 6e 65 63 74 69 6f 6e 2e 50 61 72 73 65  Connection.Parse
1080: 43 6f 6e 6e 65 63 74 69 6f 6e 53 74 72 69 6e 67  ConnectionString
1090: 28 63 6f 6e 6e 65 63 74 69 6f 6e 2e 43 6f 6e 6e  (connection.Conn
10a0: 65 63 74 69 6f 6e 53 74 72 69 6e 67 29 3b 0a 0a  ectionString);..
10b0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c        return SQL
10c0: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 2e 46 69  iteConnection.Fi
10d0: 6e 64 4b 65 79 28 6f 70 74 73 2c 20 22 44 61 74  ndKey(opts, "Dat
10e0: 65 54 69 6d 65 46 6f 72 6d 61 74 22 2c 20 22 49  eTimeFormat", "I
10f0: 53 4f 38 36 30 31 22 29 3b 0a 20 20 20 20 7d 0a  SO8601");.    }.
1100: 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64 20 6f  .    protected o
1110: 76 65 72 72 69 64 65 20 44 62 50 72 6f 76 69 64  verride DbProvid
1120: 65 72 4d 61 6e 69 66 65 73 74 20 47 65 74 44 62  erManifest GetDb
1130: 50 72 6f 76 69 64 65 72 4d 61 6e 69 66 65 73 74  ProviderManifest
1140: 28 73 74 72 69 6e 67 20 76 65 72 73 69 6f 6e 48  (string versionH
1150: 69 6e 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  int).    {.     
1160: 20 72 65 74 75 72 6e 20 6e 65 77 20 53 51 4c 69   return new SQLi
1170: 74 65 50 72 6f 76 69 64 65 72 4d 61 6e 69 66 65  teProviderManife
1180: 73 74 28 76 65 72 73 69 6f 6e 48 69 6e 74 29 3b  st(versionHint);
1190: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
11a0: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
11b0: 2f 20 43 72 65 61 74 65 73 20 61 20 53 51 4c 69  / Creates a SQLi
11c0: 74 65 50 61 72 61 6d 65 74 65 72 20 67 69 76 65  teParameter give
11d0: 6e 20 61 20 6e 61 6d 65 2c 20 74 79 70 65 2c 20  n a name, type, 
11e0: 61 6e 64 20 64 69 72 65 63 74 69 6f 6e 0a 20 20  and direction.  
11f0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
1200: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
1210: 61 74 69 63 20 53 51 4c 69 74 65 50 61 72 61 6d  atic SQLiteParam
1220: 65 74 65 72 20 43 72 65 61 74 65 53 71 6c 50 61  eter CreateSqlPa
1230: 72 61 6d 65 74 65 72 28 73 74 72 69 6e 67 20 6e  rameter(string n
1240: 61 6d 65 2c 20 54 79 70 65 55 73 61 67 65 20 74  ame, TypeUsage t
1250: 79 70 65 2c 20 50 61 72 61 6d 65 74 65 72 4d 6f  ype, ParameterMo
1260: 64 65 20 6d 6f 64 65 2c 20 6f 62 6a 65 63 74 20  de mode, object 
1270: 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20  value).    {.   
1280: 20 20 20 69 6e 74 3f 20 73 69 7a 65 3b 0a 0a 20     int? size;.. 
1290: 20 20 20 20 20 53 51 4c 69 74 65 50 61 72 61 6d       SQLiteParam
12a0: 65 74 65 72 20 72 65 73 75 6c 74 20 3d 20 6e 65  eter result = ne
12b0: 77 20 53 51 4c 69 74 65 50 61 72 61 6d 65 74 65  w SQLiteParamete
12c0: 72 28 6e 61 6d 65 2c 20 76 61 6c 75 65 29 3b 0a  r(name, value);.
12d0: 0a 20 20 20 20 20 20 2f 2f 20 2e 44 69 72 65 63  .      // .Direc
12e0: 74 69 6f 6e 0a 20 20 20 20 20 20 50 61 72 61 6d  tion.      Param
12f0: 65 74 65 72 44 69 72 65 63 74 69 6f 6e 20 64 69  eterDirection di
1300: 72 65 63 74 69 6f 6e 20 3d 20 4d 65 74 61 64 61  rection = Metada
1310: 74 61 48 65 6c 70 65 72 73 2e 50 61 72 61 6d 65  taHelpers.Parame
1320: 74 65 72 4d 6f 64 65 54 6f 50 61 72 61 6d 65 74  terModeToParamet
1330: 65 72 44 69 72 65 63 74 69 6f 6e 28 6d 6f 64 65  erDirection(mode
1340: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 72 65 73  );.      if (res
1350: 75 6c 74 2e 44 69 72 65 63 74 69 6f 6e 20 21 3d  ult.Direction !=
1360: 20 64 69 72 65 63 74 69 6f 6e 29 0a 20 20 20 20   direction).    
1370: 20 20 7b 0a 20 20 20 20 20 20 20 20 72 65 73 75    {.        resu
1380: 6c 74 2e 44 69 72 65 63 74 69 6f 6e 20 3d 20 64  lt.Direction = d
1390: 69 72 65 63 74 69 6f 6e 3b 0a 20 20 20 20 20 20  irection;.      
13a0: 7d 0a 0a 20 20 20 20 20 20 2f 2f 20 2e 53 69 7a  }..      // .Siz
13b0: 65 20 61 6e 64 20 2e 44 62 54 79 70 65 0a 20 20  e and .DbType.  
13c0: 20 20 20 20 2f 2f 20 6f 75 74 70 75 74 20 70 61      // output pa
13d0: 72 61 6d 65 74 65 72 73 20 61 72 65 20 68 61 6e  rameters are han
13e0: 64 6c 65 64 20 64 69 66 66 65 72 65 6e 74 6c 79  dled differently
13f0: 20 28 77 65 20 6e 65 65 64 20 74 6f 20 65 6e 73   (we need to ens
1400: 75 72 65 20 74 68 65 72 65 20 69 73 20 73 70 61  ure there is spa
1410: 63 65 20 66 6f 72 20 72 65 74 75 72 6e 0a 20 20  ce for return.  
1420: 20 20 20 20 2f 2f 20 76 61 6c 75 65 73 20 77 68      // values wh
1430: 65 72 65 20 74 68 65 20 75 73 65 72 20 68 61 73  ere the user has
1440: 20 6e 6f 74 20 67 69 76 65 6e 20 61 20 73 70 65   not given a spe
1450: 63 69 66 69 63 20 53 69 7a 65 2f 4d 61 78 4c 65  cific Size/MaxLe
1460: 6e 67 74 68 29 0a 20 20 20 20 20 20 62 6f 6f 6c  ngth).      bool
1470: 20 69 73 4f 75 74 50 61 72 61 6d 20 3d 20 6d 6f   isOutParam = mo
1480: 64 65 20 21 3d 20 50 61 72 61 6d 65 74 65 72 4d  de != ParameterM
1490: 6f 64 65 2e 49 6e 3b 0a 20 20 20 20 20 20 44 62  ode.In;.      Db
14a0: 54 79 70 65 20 73 71 6c 44 62 54 79 70 65 20 3d  Type sqlDbType =
14b0: 20 47 65 74 53 71 6c 44 62 54 79 70 65 28 74 79   GetSqlDbType(ty
14c0: 70 65 2c 20 69 73 4f 75 74 50 61 72 61 6d 2c 20  pe, isOutParam, 
14d0: 6f 75 74 20 73 69 7a 65 29 3b 0a 20 20 20 20 20  out size);.     
14e0: 20 69 66 20 28 72 65 73 75 6c 74 2e 44 62 54 79   if (result.DbTy
14f0: 70 65 20 21 3d 20 73 71 6c 44 62 54 79 70 65 29  pe != sqlDbType)
1500: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
1510: 20 72 65 73 75 6c 74 2e 44 62 54 79 70 65 20 3d   result.DbType =
1520: 20 73 71 6c 44 62 54 79 70 65 3b 0a 20 20 20 20   sqlDbType;.    
1530: 20 20 7d 0a 0a 20 20 20 20 20 20 2f 2f 20 4e 6f    }..      // No
1540: 74 65 20 74 68 61 74 20 77 65 20 6f 76 65 72 77  te that we overw
1550: 72 69 74 65 20 27 66 61 63 65 74 27 20 70 61 72  rite 'facet' par
1560: 61 6d 65 74 65 72 73 20 77 68 65 72 65 20 65 69  ameters where ei
1570: 74 68 65 72 20 74 68 65 20 76 61 6c 75 65 20 69  ther the value i
1580: 73 20 64 69 66 66 65 72 65 6e 74 20 6f 72 0a 20  s different or. 
1590: 20 20 20 20 20 2f 2f 20 74 68 65 72 65 20 69 73       // there is
15a0: 20 61 6e 20 6f 75 74 70 75 74 20 70 61 72 61 6d   an output param
15b0: 65 74 65 72 2e 0a 20 20 20 20 20 20 69 66 20 28  eter..      if (
15c0: 73 69 7a 65 2e 48 61 73 56 61 6c 75 65 20 26 26  size.HasValue &&
15d0: 20 28 69 73 4f 75 74 50 61 72 61 6d 20 7c 7c 20   (isOutParam || 
15e0: 72 65 73 75 6c 74 2e 53 69 7a 65 20 21 3d 20 73  result.Size != s
15f0: 69 7a 65 2e 56 61 6c 75 65 29 29 0a 20 20 20 20  ize.Value)).    
1600: 20 20 7b 0a 20 20 20 20 20 20 20 20 72 65 73 75    {.        resu
1610: 6c 74 2e 53 69 7a 65 20 3d 20 73 69 7a 65 2e 56  lt.Size = size.V
1620: 61 6c 75 65 3b 0a 20 20 20 20 20 20 7d 0a 0a 20  alue;.      }.. 
1630: 20 20 20 20 20 2f 2f 20 2e 49 73 4e 75 6c 6c 61       // .IsNulla
1640: 62 6c 65 0a 20 20 20 20 20 20 62 6f 6f 6c 20 69  ble.      bool i
1650: 73 4e 75 6c 6c 61 62 6c 65 20 3d 20 4d 65 74 61  sNullable = Meta
1660: 64 61 74 61 48 65 6c 70 65 72 73 2e 49 73 4e 75  dataHelpers.IsNu
1670: 6c 6c 61 62 6c 65 28 74 79 70 65 29 3b 0a 20 20  llable(type);.  
1680: 20 20 20 20 69 66 20 28 69 73 4f 75 74 50 61 72      if (isOutPar
1690: 61 6d 20 7c 7c 20 69 73 4e 75 6c 6c 61 62 6c 65  am || isNullable
16a0: 20 21 3d 20 72 65 73 75 6c 74 2e 49 73 4e 75 6c   != result.IsNul
16b0: 6c 61 62 6c 65 29 0a 20 20 20 20 20 20 7b 0a 20  lable).      {. 
16c0: 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e 49 73         result.Is
16d0: 4e 75 6c 6c 61 62 6c 65 20 3d 20 69 73 4e 75 6c  Nullable = isNul
16e0: 6c 61 62 6c 65 3b 0a 20 20 20 20 20 20 7d 0a 0a  lable;.      }..
16f0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 72 65 73        return res
1700: 75 6c 74 3b 0a 20 20 20 20 7d 0a 0a 0a 20 20 20  ult;.    }...   
1710: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
1720: 20 20 20 2f 2f 2f 20 44 65 74 65 72 6d 69 6e 65     /// Determine
1730: 73 20 44 62 54 79 70 65 20 66 6f 72 20 74 68 65  s DbType for the
1740: 20 67 69 76 65 6e 20 70 72 69 6d 69 74 69 76 65   given primitive
1750: 20 74 79 70 65 2e 20 45 78 74 72 61 63 74 73 20   type. Extracts 
1760: 66 61 63 65 74 0a 20 20 20 20 2f 2f 2f 20 69 6e  facet.    /// in
1770: 66 6f 72 6d 61 74 69 6f 6e 20 61 73 20 77 65 6c  formation as wel
1780: 6c 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  l..    /// </sum
1790: 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74  mary>.    privat
17a0: 65 20 73 74 61 74 69 63 20 44 62 54 79 70 65 20  e static DbType 
17b0: 47 65 74 53 71 6c 44 62 54 79 70 65 28 54 79 70  GetSqlDbType(Typ
17c0: 65 55 73 61 67 65 20 74 79 70 65 2c 20 62 6f 6f  eUsage type, boo
17d0: 6c 20 69 73 4f 75 74 50 61 72 61 6d 2c 20 6f 75  l isOutParam, ou
17e0: 74 20 69 6e 74 3f 20 73 69 7a 65 29 0a 20 20 20  t int? size).   
17f0: 20 7b 0a 20 20 20 20 20 20 2f 2f 20 6f 6e 6c 79   {.      // only
1800: 20 73 75 70 70 6f 72 74 65 64 20 66 6f 72 20 70   supported for p
1810: 72 69 6d 69 74 69 76 65 20 74 79 70 65 0a 20 20  rimitive type.  
1820: 20 20 20 20 50 72 69 6d 69 74 69 76 65 54 79 70      PrimitiveTyp
1830: 65 4b 69 6e 64 20 70 72 69 6d 69 74 69 76 65 54  eKind primitiveT
1840: 79 70 65 4b 69 6e 64 20 3d 20 4d 65 74 61 64 61  ypeKind = Metada
1850: 74 61 48 65 6c 70 65 72 73 2e 47 65 74 50 72 69  taHelpers.GetPri
1860: 6d 69 74 69 76 65 54 79 70 65 4b 69 6e 64 28 74  mitiveTypeKind(t
1870: 79 70 65 29 3b 0a 0a 20 20 20 20 20 20 73 69 7a  ype);..      siz
1880: 65 20 3d 20 64 65 66 61 75 6c 74 28 69 6e 74 3f  e = default(int?
1890: 29 3b 0a 0a 20 20 20 20 20 20 73 77 69 74 63 68  );..      switch
18a0: 20 28 70 72 69 6d 69 74 69 76 65 54 79 70 65 4b   (primitiveTypeK
18b0: 69 6e 64 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  ind).      {.   
18c0: 20 20 20 20 20 63 61 73 65 20 50 72 69 6d 69 74       case Primit
18d0: 69 76 65 54 79 70 65 4b 69 6e 64 2e 42 69 6e 61  iveTypeKind.Bina
18e0: 72 79 3a 0a 20 20 20 20 20 20 20 20 20 20 2f 2f  ry:.          //
18f0: 20 66 6f 72 20 6f 75 74 70 75 74 20 70 61 72 61   for output para
1900: 6d 65 74 65 72 73 2c 20 65 6e 73 75 72 65 20 74  meters, ensure t
1910: 68 65 72 65 20 69 73 20 73 70 61 63 65 2e 2e 2e  here is space...
1920: 0a 20 20 20 20 20 20 20 20 20 20 73 69 7a 65 20  .          size 
1930: 3d 20 47 65 74 50 61 72 61 6d 65 74 65 72 53 69  = GetParameterSi
1940: 7a 65 28 74 79 70 65 2c 20 69 73 4f 75 74 50 61  ze(type, isOutPa
1950: 72 61 6d 29 3b 0a 20 20 20 20 20 20 20 20 20 20  ram);.          
1960: 72 65 74 75 72 6e 20 47 65 74 42 69 6e 61 72 79  return GetBinary
1970: 44 62 54 79 70 65 28 74 79 70 65 29 3b 0a 0a 20  DbType(type);.. 
1980: 20 20 20 20 20 20 20 63 61 73 65 20 50 72 69 6d         case Prim
1990: 69 74 69 76 65 54 79 70 65 4b 69 6e 64 2e 42 6f  itiveTypeKind.Bo
19a0: 6f 6c 65 61 6e 3a 0a 20 20 20 20 20 20 20 20 20  olean:.         
19b0: 20 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e 42   return DbType.B
19c0: 6f 6f 6c 65 61 6e 3b 0a 0a 20 20 20 20 20 20 20  oolean;..       
19d0: 20 63 61 73 65 20 50 72 69 6d 69 74 69 76 65 54   case PrimitiveT
19e0: 79 70 65 4b 69 6e 64 2e 42 79 74 65 3a 0a 20 20  ypeKind.Byte:.  
19f0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 44          return D
1a00: 62 54 79 70 65 2e 42 79 74 65 3b 0a 0a 20 20 20  bType.Byte;..   
1a10: 20 20 20 20 20 63 61 73 65 20 50 72 69 6d 69 74       case Primit
1a20: 69 76 65 54 79 70 65 4b 69 6e 64 2e 54 69 6d 65  iveTypeKind.Time
1a30: 3a 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  :.          retu
1a40: 72 6e 20 44 62 54 79 70 65 2e 54 69 6d 65 3b 0a  rn DbType.Time;.
1a50: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 50 72  .        case Pr
1a60: 69 6d 69 74 69 76 65 54 79 70 65 4b 69 6e 64 2e  imitiveTypeKind.
1a70: 44 61 74 65 54 69 6d 65 4f 66 66 73 65 74 3a 0a  DateTimeOffset:.
1a80: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
1a90: 20 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d 65   DbType.DateTime
1aa0: 4f 66 66 73 65 74 3b 0a 0a 20 20 20 20 20 20 20  Offset;..       
1ab0: 20 63 61 73 65 20 50 72 69 6d 69 74 69 76 65 54   case PrimitiveT
1ac0: 79 70 65 4b 69 6e 64 2e 44 61 74 65 54 69 6d 65  ypeKind.DateTime
1ad0: 3a 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  :.          retu
1ae0: 72 6e 20 44 62 54 79 70 65 2e 44 61 74 65 54 69  rn DbType.DateTi
1af0: 6d 65 3b 0a 0a 20 20 20 20 20 20 20 20 63 61 73  me;..        cas
1b00: 65 20 50 72 69 6d 69 74 69 76 65 54 79 70 65 4b  e PrimitiveTypeK
1b10: 69 6e 64 2e 44 65 63 69 6d 61 6c 3a 0a 20 20 20  ind.Decimal:.   
1b20: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 44 62         return Db
1b30: 54 79 70 65 2e 44 65 63 69 6d 61 6c 3b 0a 0a 20  Type.Decimal;.. 
1b40: 20 20 20 20 20 20 20 63 61 73 65 20 50 72 69 6d         case Prim
1b50: 69 74 69 76 65 54 79 70 65 4b 69 6e 64 2e 44 6f  itiveTypeKind.Do
1b60: 75 62 6c 65 3a 0a 20 20 20 20 20 20 20 20 20 20  uble:.          
1b70: 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e 44 6f  return DbType.Do
1b80: 75 62 6c 65 3b 0a 0a 20 20 20 20 20 20 20 20 63  uble;..        c
1b90: 61 73 65 20 50 72 69 6d 69 74 69 76 65 54 79 70  ase PrimitiveTyp
1ba0: 65 4b 69 6e 64 2e 47 75 69 64 3a 0a 20 20 20 20  eKind.Guid:.    
1bb0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 44 62 54        return DbT
1bc0: 79 70 65 2e 47 75 69 64 3b 0a 0a 20 20 20 20 20  ype.Guid;..     
1bd0: 20 20 20 63 61 73 65 20 50 72 69 6d 69 74 69 76     case Primitiv
1be0: 65 54 79 70 65 4b 69 6e 64 2e 49 6e 74 31 36 3a  eTypeKind.Int16:
1bf0: 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72  .          retur
1c00: 6e 20 44 62 54 79 70 65 2e 49 6e 74 31 36 3b 0a  n DbType.Int16;.
1c10: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 50 72  .        case Pr
1c20: 69 6d 69 74 69 76 65 54 79 70 65 4b 69 6e 64 2e  imitiveTypeKind.
1c30: 49 6e 74 33 32 3a 0a 20 20 20 20 20 20 20 20 20  Int32:.         
1c40: 20 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e 49   return DbType.I
1c50: 6e 74 33 32 3b 0a 0a 20 20 20 20 20 20 20 20 63  nt32;..        c
1c60: 61 73 65 20 50 72 69 6d 69 74 69 76 65 54 79 70  ase PrimitiveTyp
1c70: 65 4b 69 6e 64 2e 49 6e 74 36 34 3a 0a 20 20 20  eKind.Int64:.   
1c80: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 44 62         return Db
1c90: 54 79 70 65 2e 49 6e 74 36 34 3b 0a 0a 20 20 20  Type.Int64;..   
1ca0: 20 20 20 20 20 63 61 73 65 20 50 72 69 6d 69 74       case Primit
1cb0: 69 76 65 54 79 70 65 4b 69 6e 64 2e 53 42 79 74  iveTypeKind.SByt
1cc0: 65 3a 0a 20 20 20 20 20 20 20 20 20 20 72 65 74  e:.          ret
1cd0: 75 72 6e 20 44 62 54 79 70 65 2e 53 42 79 74 65  urn DbType.SByte
1ce0: 3b 0a 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  ;..        case 
1cf0: 50 72 69 6d 69 74 69 76 65 54 79 70 65 4b 69 6e  PrimitiveTypeKin
1d00: 64 2e 53 69 6e 67 6c 65 3a 0a 20 20 20 20 20 20  d.Single:.      
1d10: 20 20 20 20 72 65 74 75 72 6e 20 44 62 54 79 70      return DbTyp
1d20: 65 2e 53 69 6e 67 6c 65 3b 0a 0a 20 20 20 20 20  e.Single;..     
1d30: 20 20 20 63 61 73 65 20 50 72 69 6d 69 74 69 76     case Primitiv
1d40: 65 54 79 70 65 4b 69 6e 64 2e 53 74 72 69 6e 67  eTypeKind.String
1d50: 3a 0a 20 20 20 20 20 20 20 20 20 20 73 69 7a 65  :.          size
1d60: 20 3d 20 47 65 74 50 61 72 61 6d 65 74 65 72 53   = GetParameterS
1d70: 69 7a 65 28 74 79 70 65 2c 20 69 73 4f 75 74 50  ize(type, isOutP
1d80: 61 72 61 6d 29 3b 0a 20 20 20 20 20 20 20 20 20  aram);.         
1d90: 20 72 65 74 75 72 6e 20 47 65 74 53 74 72 69 6e   return GetStrin
1da0: 67 44 62 54 79 70 65 28 74 79 70 65 29 3b 0a 0a  gDbType(type);..
1db0: 20 20 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a          default:
1dc0: 0a 20 20 20 20 20 20 20 20 20 20 44 65 62 75 67  .          Debug
1dd0: 2e 46 61 69 6c 28 22 75 6e 6b 6e 6f 77 6e 20 50  .Fail("unknown P
1de0: 72 69 6d 69 74 69 76 65 54 79 70 65 4b 69 6e 64  rimitiveTypeKind
1df0: 20 22 20 2b 20 70 72 69 6d 69 74 69 76 65 54 79   " + primitiveTy
1e00: 70 65 4b 69 6e 64 29 3b 0a 20 20 20 20 20 20 20  peKind);.       
1e10: 20 20 20 72 65 74 75 72 6e 20 44 62 54 79 70 65     return DbType
1e20: 2e 4f 62 6a 65 63 74 3b 0a 20 20 20 20 20 20 7d  .Object;.      }
1e30: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
1e40: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
1e50: 2f 20 44 65 74 65 72 6d 69 6e 65 73 20 70 72 65  / Determines pre
1e60: 66 65 72 72 65 64 20 76 61 6c 75 65 20 66 6f 72  ferred value for
1e70: 20 53 71 6c 50 61 72 61 6d 65 74 65 72 2e 53 69   SqlParameter.Si
1e80: 7a 65 2e 20 52 65 74 75 72 6e 73 20 6e 75 6c 6c  ze. Returns null
1e90: 0a 20 20 20 20 2f 2f 2f 20 77 68 65 72 65 20 74  .    /// where t
1ea0: 68 65 72 65 20 69 73 20 6e 6f 20 70 72 65 66 65  here is no prefe
1eb0: 72 65 6e 63 65 2e 0a 20 20 20 20 2f 2f 2f 20 3c  rence..    /// <
1ec0: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72  /summary>.    pr
1ed0: 69 76 61 74 65 20 73 74 61 74 69 63 20 69 6e 74  ivate static int
1ee0: 3f 20 47 65 74 50 61 72 61 6d 65 74 65 72 53 69  ? GetParameterSi
1ef0: 7a 65 28 54 79 70 65 55 73 61 67 65 20 74 79 70  ze(TypeUsage typ
1f00: 65 2c 20 62 6f 6f 6c 20 69 73 4f 75 74 50 61 72  e, bool isOutPar
1f10: 61 6d 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  am).    {.      
1f20: 69 6e 74 20 6d 61 78 4c 65 6e 67 74 68 3b 0a 20  int maxLength;. 
1f30: 20 20 20 20 20 69 66 20 28 4d 65 74 61 64 61 74       if (Metadat
1f40: 61 48 65 6c 70 65 72 73 2e 54 72 79 47 65 74 4d  aHelpers.TryGetM
1f50: 61 78 4c 65 6e 67 74 68 28 74 79 70 65 2c 20 6f  axLength(type, o
1f60: 75 74 20 6d 61 78 4c 65 6e 67 74 68 29 29 0a 20  ut maxLength)). 
1f70: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 2f       {.        /
1f80: 2f 20 69 66 20 74 68 65 20 4d 61 78 4c 65 6e 67  / if the MaxLeng
1f90: 74 68 20 66 61 63 65 74 20 68 61 73 20 61 20 73  th facet has a s
1fa0: 70 65 63 69 66 69 63 20 76 61 6c 75 65 20 75 73  pecific value us
1fb0: 65 20 69 74 0a 20 20 20 20 20 20 20 20 72 65 74  e it.        ret
1fc0: 75 72 6e 20 6d 61 78 4c 65 6e 67 74 68 3b 0a 20  urn maxLength;. 
1fd0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 65 6c 73       }.      els
1fe0: 65 20 69 66 20 28 69 73 4f 75 74 50 61 72 61 6d  e if (isOutParam
1ff0: 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  ).      {.      
2000: 20 20 2f 2f 20 69 66 20 74 68 65 20 70 61 72 61    // if the para
2010: 6d 65 74 65 72 20 69 73 20 61 20 72 65 74 75 72  meter is a retur
2020: 6e 2f 6f 75 74 2f 69 6e 6f 75 74 20 70 61 72 61  n/out/inout para
2030: 6d 65 74 65 72 2c 20 65 6e 73 75 72 65 20 74 68  meter, ensure th
2040: 65 72 65 20 0a 20 20 20 20 20 20 20 20 2f 2f 20  ere .        // 
2050: 69 73 20 73 70 61 63 65 20 66 6f 72 20 61 6e 79  is space for any
2060: 20 76 61 6c 75 65 0a 20 20 20 20 20 20 20 20 72   value.        r
2070: 65 74 75 72 6e 20 69 6e 74 2e 4d 61 78 56 61 6c  eturn int.MaxVal
2080: 75 65 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ue;.      }.    
2090: 20 20 65 6c 73 65 0a 20 20 20 20 20 20 7b 0a 20    else.      {. 
20a0: 20 20 20 20 20 20 20 2f 2f 20 6e 6f 20 76 61 6c         // no val
20b0: 75 65 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  ue.        retur
20c0: 6e 20 64 65 66 61 75 6c 74 28 69 6e 74 3f 29 3b  n default(int?);
20d0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a  .      }.    }..
20e0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
20f0: 3e 0a 20 20 20 20 2f 2f 2f 20 43 68 6f 6f 73 65  >.    /// Choose
2100: 73 20 74 68 65 20 61 70 70 72 6f 70 72 69 61 74  s the appropriat
2110: 65 20 44 62 54 79 70 65 20 66 6f 72 20 74 68 65  e DbType for the
2120: 20 67 69 76 65 6e 20 73 74 72 69 6e 67 20 74 79   given string ty
2130: 70 65 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  pe..    /// </su
2140: 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61  mmary>.    priva
2150: 74 65 20 73 74 61 74 69 63 20 44 62 54 79 70 65  te static DbType
2160: 20 47 65 74 53 74 72 69 6e 67 44 62 54 79 70 65   GetStringDbType
2170: 28 54 79 70 65 55 73 61 67 65 20 74 79 70 65 29  (TypeUsage type)
2180: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 44 65 62  .    {.      Deb
2190: 75 67 2e 41 73 73 65 72 74 28 74 79 70 65 2e 45  ug.Assert(type.E
21a0: 64 6d 54 79 70 65 2e 42 75 69 6c 74 49 6e 54 79  dmType.BuiltInTy
21b0: 70 65 4b 69 6e 64 20 3d 3d 20 42 75 69 6c 74 49  peKind == BuiltI
21c0: 6e 54 79 70 65 4b 69 6e 64 2e 50 72 69 6d 69 74  nTypeKind.Primit
21d0: 69 76 65 54 79 70 65 20 26 26 0a 20 20 20 20 20  iveType &&.     
21e0: 20 20 20 50 72 69 6d 69 74 69 76 65 54 79 70 65     PrimitiveType
21f0: 4b 69 6e 64 2e 53 74 72 69 6e 67 20 3d 3d 20 28  Kind.String == (
2200: 28 50 72 69 6d 69 74 69 76 65 54 79 70 65 29 74  (PrimitiveType)t
2210: 79 70 65 2e 45 64 6d 54 79 70 65 29 2e 50 72 69  ype.EdmType).Pri
2220: 6d 69 74 69 76 65 54 79 70 65 4b 69 6e 64 2c 20  mitiveTypeKind, 
2230: 22 6f 6e 6c 79 20 76 61 6c 69 64 20 66 6f 72 20  "only valid for 
2240: 73 74 72 69 6e 67 20 74 79 70 65 22 29 3b 0a 0a  string type");..
2250: 20 20 20 20 20 20 44 62 54 79 70 65 20 64 62 54        DbType dbT
2260: 79 70 65 3b 0a 0a 20 20 20 20 20 20 2f 2f 20 53  ype;..      // S
2270: 70 65 63 69 66 69 63 20 74 79 70 65 20 64 65 70  pecific type dep
2280: 65 6e 64 73 20 6f 6e 20 77 68 65 74 68 65 72 20  ends on whether 
2290: 74 68 65 20 73 74 72 69 6e 67 20 69 73 20 61 20  the string is a 
22a0: 75 6e 69 63 6f 64 65 20 73 74 72 69 6e 67 20 61  unicode string a
22b0: 6e 64 20 77 68 65 74 68 65 72 20 69 74 20 69 73  nd whether it is
22c0: 20 61 20 66 69 78 65 64 20 6c 65 6e 67 74 68 20   a fixed length 
22d0: 73 74 72 69 6e 67 2e 0a 20 20 20 20 20 20 2f 2f  string..      //
22e0: 20 42 79 20 64 65 66 61 75 6c 74 2c 20 61 73 73   By default, ass
22f0: 75 6d 65 20 77 69 64 65 73 74 20 74 79 70 65 20  ume widest type 
2300: 28 75 6e 69 63 6f 64 65 29 20 61 6e 64 20 6d 6f  (unicode) and mo
2310: 73 74 20 63 6f 6d 6d 6f 6e 20 74 79 70 65 20 28  st common type (
2320: 76 61 72 69 61 62 6c 65 20 6c 65 6e 67 74 68 29  variable length)
2330: 0a 20 20 20 20 20 20 62 6f 6f 6c 20 75 6e 69 63  .      bool unic
2340: 6f 64 65 3b 0a 20 20 20 20 20 20 62 6f 6f 6c 20  ode;.      bool 
2350: 66 69 78 65 64 4c 65 6e 67 74 68 3b 0a 20 20 20  fixedLength;.   
2360: 20 20 20 69 66 20 28 21 4d 65 74 61 64 61 74 61     if (!Metadata
2370: 48 65 6c 70 65 72 73 2e 54 72 79 47 65 74 49 73  Helpers.TryGetIs
2380: 46 69 78 65 64 4c 65 6e 67 74 68 28 74 79 70 65  FixedLength(type
2390: 2c 20 6f 75 74 20 66 69 78 65 64 4c 65 6e 67 74  , out fixedLengt
23a0: 68 29 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20  h)).      {.    
23b0: 20 20 20 20 66 69 78 65 64 4c 65 6e 67 74 68 20      fixedLength 
23c0: 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 7d  = false;.      }
23d0: 0a 0a 20 20 20 20 20 20 69 66 20 28 21 4d 65 74  ..      if (!Met
23e0: 61 64 61 74 61 48 65 6c 70 65 72 73 2e 54 72 79  adataHelpers.Try
23f0: 47 65 74 49 73 55 6e 69 63 6f 64 65 28 74 79 70  GetIsUnicode(typ
2400: 65 2c 20 6f 75 74 20 75 6e 69 63 6f 64 65 29 29  e, out unicode))
2410: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
2420: 20 75 6e 69 63 6f 64 65 20 3d 20 74 72 75 65 3b   unicode = true;
2430: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
2440: 69 66 20 28 66 69 78 65 64 4c 65 6e 67 74 68 29  if (fixedLength)
2450: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
2460: 20 64 62 54 79 70 65 20 3d 20 28 75 6e 69 63 6f   dbType = (unico
2470: 64 65 20 3f 20 44 62 54 79 70 65 2e 53 74 72 69  de ? DbType.Stri
2480: 6e 67 46 69 78 65 64 4c 65 6e 67 74 68 20 3a 20  ngFixedLength : 
2490: 44 62 54 79 70 65 2e 41 6e 73 69 53 74 72 69 6e  DbType.AnsiStrin
24a0: 67 46 69 78 65 64 4c 65 6e 67 74 68 29 3b 0a 20  gFixedLength);. 
24b0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 65 6c 73       }.      els
24c0: 65 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  e.      {.      
24d0: 20 20 64 62 54 79 70 65 20 3d 20 28 75 6e 69 63    dbType = (unic
24e0: 6f 64 65 20 3f 20 44 62 54 79 70 65 2e 53 74 72  ode ? DbType.Str
24f0: 69 6e 67 20 3a 20 44 62 54 79 70 65 2e 41 6e 73  ing : DbType.Ans
2500: 69 53 74 72 69 6e 67 29 3b 0a 20 20 20 20 20 20  iString);.      
2510: 7d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 64  }.      return d
2520: 62 54 79 70 65 3b 0a 20 20 20 20 7d 0a 0a 20 20  bType;.    }..  
2530: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
2540: 20 20 20 20 2f 2f 2f 20 43 68 6f 6f 73 65 73 20      /// Chooses 
2550: 74 68 65 20 61 70 70 72 6f 70 72 69 61 74 65 20  the appropriate 
2560: 44 62 54 79 70 65 20 66 6f 72 20 74 68 65 20 67  DbType for the g
2570: 69 76 65 6e 20 62 69 6e 61 72 79 20 74 79 70 65  iven binary type
2580: 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
2590: 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74 65  ary>.    private
25a0: 20 73 74 61 74 69 63 20 44 62 54 79 70 65 20 47   static DbType G
25b0: 65 74 42 69 6e 61 72 79 44 62 54 79 70 65 28 54  etBinaryDbType(T
25c0: 79 70 65 55 73 61 67 65 20 74 79 70 65 29 0a 20  ypeUsage type). 
25d0: 20 20 20 7b 0a 20 20 20 20 20 20 44 65 62 75 67     {.      Debug
25e0: 2e 41 73 73 65 72 74 28 74 79 70 65 2e 45 64 6d  .Assert(type.Edm
25f0: 54 79 70 65 2e 42 75 69 6c 74 49 6e 54 79 70 65  Type.BuiltInType
2600: 4b 69 6e 64 20 3d 3d 20 42 75 69 6c 74 49 6e 54  Kind == BuiltInT
2610: 79 70 65 4b 69 6e 64 2e 50 72 69 6d 69 74 69 76  ypeKind.Primitiv
2620: 65 54 79 70 65 20 26 26 0a 20 20 20 20 20 20 20  eType &&.       
2630: 20 50 72 69 6d 69 74 69 76 65 54 79 70 65 4b 69   PrimitiveTypeKi
2640: 6e 64 2e 42 69 6e 61 72 79 20 3d 3d 20 28 28 50  nd.Binary == ((P
2650: 72 69 6d 69 74 69 76 65 54 79 70 65 29 74 79 70  rimitiveType)typ
2660: 65 2e 45 64 6d 54 79 70 65 29 2e 50 72 69 6d 69  e.EdmType).Primi
2670: 74 69 76 65 54 79 70 65 4b 69 6e 64 2c 20 22 6f  tiveTypeKind, "o
2680: 6e 6c 79 20 76 61 6c 69 64 20 66 6f 72 20 62 69  nly valid for bi
2690: 6e 61 72 79 20 74 79 70 65 22 29 3b 0a 0a 20 20  nary type");..  
26a0: 20 20 20 20 2f 2f 20 53 70 65 63 69 66 69 63 20      // Specific 
26b0: 74 79 70 65 20 64 65 70 65 6e 64 73 20 6f 6e 20  type depends on 
26c0: 77 68 65 74 68 65 72 20 74 68 65 20 62 69 6e 61  whether the bina
26d0: 72 79 20 76 61 6c 75 65 20 69 73 20 66 69 78 65  ry value is fixe
26e0: 64 20 6c 65 6e 67 74 68 2e 20 42 79 20 64 65 66  d length. By def
26f0: 61 75 6c 74 2c 20 61 73 73 75 6d 65 20 76 61 72  ault, assume var
2700: 69 61 62 6c 65 20 6c 65 6e 67 74 68 2e 0a 20 20  iable length..  
2710: 20 20 20 20 62 6f 6f 6c 20 66 69 78 65 64 4c 65      bool fixedLe
2720: 6e 67 74 68 3b 0a 20 20 20 20 20 20 69 66 20 28  ngth;.      if (
2730: 21 4d 65 74 61 64 61 74 61 48 65 6c 70 65 72 73  !MetadataHelpers
2740: 2e 54 72 79 47 65 74 49 73 46 69 78 65 64 4c 65  .TryGetIsFixedLe
2750: 6e 67 74 68 28 74 79 70 65 2c 20 6f 75 74 20 66  ngth(type, out f
2760: 69 78 65 64 4c 65 6e 67 74 68 29 29 0a 20 20 20  ixedLength)).   
2770: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 66 69 78     {.        fix
2780: 65 64 4c 65 6e 67 74 68 20 3d 20 66 61 6c 73 65  edLength = false
2790: 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20  ;.      }..     
27a0: 20 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e 42   return DbType.B
27b0: 69 6e 61 72 79 3b 0a 20 20 20 20 20 20 2f 2f 20  inary;.      // 
27c0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
27d0: 6e 20 66 69 78 65 64 4c 65 6e 67 74 68 20 3f 20  n fixedLength ? 
27e0: 44 62 54 79 70 65 2e 42 69 6e 61 72 79 20 3a 20  DbType.Binary : 
27f0: 44 62 54 79 70 65 2e 56 61 72 42 69 6e 61 72 79  DbType.VarBinary
2800: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 23 72 65  ;.    }..    #re
2810: 67 69 6f 6e 20 49 53 51 4c 69 74 65 53 63 68 65  gion ISQLiteSche
2820: 6d 61 45 78 74 65 6e 73 69 6f 6e 73 20 4d 65 6d  maExtensions Mem
2830: 62 65 72 73 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73  bers..    /// <s
2840: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
2850: 43 72 65 61 74 65 73 20 74 65 6d 70 6f 72 61 72  Creates temporar
2860: 79 20 74 61 62 6c 65 73 20 6f 6e 20 74 68 65 20  y tables on the 
2870: 63 6f 6e 6e 65 63 74 69 6f 6e 20 73 6f 20 73 63  connection so sc
2880: 68 65 6d 61 20 69 6e 66 6f 72 6d 61 74 69 6f 6e  hema information
2890: 20 63 61 6e 20 62 65 20 71 75 65 72 69 65 64 0a   can be queried.
28a0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
28b0: 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61  y>.    /// <rema
28c0: 72 6b 73 3e 0a 20 20 20 20 2f 2f 2f 20 54 68 65  rks>.    /// The
28d0: 72 65 27 73 20 61 20 6c 6f 74 20 6f 66 20 77 6f  re's a lot of wo
28e0: 72 6b 20 69 6e 76 6f 6c 76 65 64 20 69 6e 20 67  rk involved in g
28f0: 65 74 74 69 6e 67 20 73 63 68 65 6d 61 20 69 6e  etting schema in
2900: 66 6f 72 6d 61 74 69 6f 6e 20 6f 75 74 20 6f 66  formation out of
2910: 20 53 51 4c 69 74 65 2c 20 62 75 74 20 4c 49 4e   SQLite, but LIN
2920: 51 20 65 78 70 65 63 74 73 20 74 6f 0a 20 20 20  Q expects to.   
2930: 20 2f 2f 2f 20 62 65 20 61 62 6c 65 20 74 6f 20   /// be able to 
2940: 71 75 65 72 79 20 6f 6e 20 73 63 68 65 6d 61 20  query on schema 
2950: 74 61 62 6c 65 73 2e 20 20 54 68 65 72 65 66 6f  tables.  Therefo
2960: 72 65 20 77 65 20 6e 65 65 64 20 74 6f 20 22 66  re we need to "f
2970: 61 6b 65 22 20 69 74 20 62 79 20 67 65 6e 65 72  ake" it by gener
2980: 61 74 69 6e 67 20 74 65 6d 70 6f 72 61 72 79 20  ating temporary 
2990: 74 61 62 6c 65 73 0a 20 20 20 20 2f 2f 2f 20 66  tables.    /// f
29a0: 69 6c 6c 65 64 20 77 69 74 68 20 74 68 65 20 73  illed with the s
29b0: 63 68 65 6d 61 20 6f 66 20 74 68 65 20 63 75 72  chema of the cur
29c0: 72 65 6e 74 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e  rent connection.
29d0: 20 20 57 65 20 67 65 74 20 61 77 61 79 20 77 69    We get away wi
29e0: 74 68 20 6d 61 6b 69 6e 67 20 74 68 69 73 20 69  th making this i
29f0: 6e 66 6f 72 6d 61 74 69 6f 6e 20 73 74 61 74 69  nformation stati
2a00: 63 0a 20 20 20 20 2f 2f 2f 20 62 65 63 61 75 73  c.    /// becaus
2a10: 65 20 73 63 68 65 6d 61 20 69 6e 66 6f 72 6d 61  e schema informa
2a20: 74 69 6f 6e 20 73 65 65 6d 73 20 74 6f 20 61 6c  tion seems to al
2a30: 77 61 79 73 20 62 65 20 71 75 65 72 69 65 64 20  ways be queried 
2a40: 6f 6e 20 61 20 6e 65 77 20 63 6f 6e 6e 65 63 74  on a new connect
2a50: 69 6f 6e 20 6f 62 6a 65 63 74 2c 20 73 6f 20 74  ion object, so t
2a60: 68 65 20 73 63 68 65 6d 61 20 69 73 0a 20 20 20  he schema is.   
2a70: 20 2f 2f 2f 20 61 6c 77 61 79 73 20 66 72 65 73   /// always fres
2a80: 68 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d  h..    /// </rem
2a90: 61 72 6b 73 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  arks>.    /// <p
2aa0: 61 72 61 6d 20 6e 61 6d 65 3d 22 63 6e 6e 22 3e  aram name="cnn">
2ab0: 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 75  The connection u
2ac0: 70 6f 6e 20 77 68 69 63 68 20 74 6f 20 62 75 69  pon which to bui
2ad0: 6c 64 20 74 68 65 20 73 63 68 65 6d 61 20 74 61  ld the schema ta
2ae0: 62 6c 65 73 3c 2f 70 61 72 61 6d 3e 0a 20 20 20  bles</param>.   
2af0: 20 76 6f 69 64 20 49 53 51 4c 69 74 65 53 63 68   void ISQLiteSch
2b00: 65 6d 61 45 78 74 65 6e 73 69 6f 6e 73 2e 42 75  emaExtensions.Bu
2b10: 69 6c 64 54 65 6d 70 53 63 68 65 6d 61 28 53 51  ildTempSchema(SQ
2b20: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63  LiteConnection c
2b30: 6e 6e 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  nn).    {.      
2b40: 73 74 72 69 6e 67 5b 5d 20 61 72 72 20 3d 20 6e  string[] arr = n
2b50: 65 77 20 73 74 72 69 6e 67 5b 5d 20 7b 20 22 54  ew string[] { "T
2b60: 41 42 4c 45 53 22 2c 20 22 43 4f 4c 55 4d 4e 53  ABLES", "COLUMNS
2b70: 22 2c 20 22 56 49 45 57 53 22 2c 20 22 56 49 45  ", "VIEWS", "VIE
2b80: 57 43 4f 4c 55 4d 4e 53 22 2c 20 22 49 4e 44 45  WCOLUMNS", "INDE
2b90: 58 45 53 22 2c 20 22 49 4e 44 45 58 43 4f 4c 55  XES", "INDEXCOLU
2ba0: 4d 4e 53 22 2c 20 22 46 4f 52 45 49 47 4e 4b 45  MNS", "FOREIGNKE
2bb0: 59 53 22 2c 20 22 43 41 54 41 4c 4f 47 53 22 20  YS", "CATALOGS" 
2bc0: 7d 3b 0a 0a 20 20 20 20 20 20 75 73 69 6e 67 20  };..      using 
2bd0: 28 44 61 74 61 54 61 62 6c 65 20 74 61 62 6c 65  (DataTable table
2be0: 20 3d 20 63 6e 6e 2e 47 65 74 53 63 68 65 6d 61   = cnn.GetSchema
2bf0: 28 22 54 61 62 6c 65 73 22 2c 20 6e 65 77 20 73  ("Tables", new s
2c00: 74 72 69 6e 67 5b 5d 20 7b 20 22 74 65 6d 70 22  tring[] { "temp"
2c10: 2c 20 6e 75 6c 6c 2c 20 53 74 72 69 6e 67 2e 46  , null, String.F
2c20: 6f 72 6d 61 74 28 22 53 43 48 45 4d 41 7b 30 7d  ormat("SCHEMA{0}
2c30: 22 2c 20 61 72 72 5b 30 5d 29 20 7d 29 29 0a 20  ", arr[0]) })). 
2c40: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69       {.        i
2c50: 66 20 28 74 61 62 6c 65 2e 52 6f 77 73 2e 43 6f  f (table.Rows.Co
2c60: 75 6e 74 20 3e 20 30 29 20 72 65 74 75 72 6e 3b  unt > 0) return;
2c70: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
2c80: 66 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20  for (int n = 0; 
2c90: 6e 20 3c 20 61 72 72 2e 4c 65 6e 67 74 68 3b 20  n < arr.Length; 
2ca0: 6e 2b 2b 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  n++).      {.   
2cb0: 20 20 20 20 20 75 73 69 6e 67 20 28 44 61 74 61       using (Data
2cc0: 54 61 62 6c 65 20 74 61 62 6c 65 20 3d 20 63 6e  Table table = cn
2cd0: 6e 2e 47 65 74 53 63 68 65 6d 61 28 61 72 72 5b  n.GetSchema(arr[
2ce0: 6e 5d 29 29 0a 20 20 20 20 20 20 20 20 7b 0a 20  n])).        {. 
2cf0: 20 20 20 20 20 20 20 20 20 44 61 74 61 54 61 62           DataTab
2d00: 6c 65 54 6f 54 61 62 6c 65 28 63 6e 6e 2c 20 74  leToTable(cnn, t
2d10: 61 62 6c 65 2c 20 53 74 72 69 6e 67 2e 46 6f 72  able, String.For
2d20: 6d 61 74 28 22 53 43 48 45 4d 41 7b 30 7d 22 2c  mat("SCHEMA{0}",
2d30: 20 61 72 72 5b 6e 5d 29 29 3b 0a 20 20 20 20 20   arr[n]));.     
2d40: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 0a 20 20     }.      }..  
2d50: 20 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74      using (SQLit
2d60: 65 43 6f 6d 6d 61 6e 64 20 63 6d 64 20 3d 20 63  eCommand cmd = c
2d70: 6e 6e 2e 43 72 65 61 74 65 43 6f 6d 6d 61 6e 64  nn.CreateCommand
2d80: 28 29 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20  ()).      {.    
2d90: 20 20 20 20 63 6d 64 2e 43 6f 6d 6d 61 6e 64 54      cmd.CommandT
2da0: 65 78 74 20 3d 20 50 72 6f 70 65 72 74 69 65 73  ext = Properties
2db0: 2e 52 65 73 6f 75 72 63 65 73 2e 53 51 4c 5f 43  .Resources.SQL_C
2dc0: 4f 4e 53 54 52 41 49 4e 54 53 3b 0a 20 20 20 20  ONSTRAINTS;.    
2dd0: 20 20 20 20 63 6d 64 2e 45 78 65 63 75 74 65 4e      cmd.ExecuteN
2de0: 6f 6e 51 75 65 72 79 28 29 3b 0a 0a 20 20 20 20  onQuery();..    
2df0: 20 20 20 20 63 6d 64 2e 43 6f 6d 6d 61 6e 64 54      cmd.CommandT
2e00: 65 78 74 20 3d 20 50 72 6f 70 65 72 74 69 65 73  ext = Properties
2e10: 2e 52 65 73 6f 75 72 63 65 73 2e 53 51 4c 5f 43  .Resources.SQL_C
2e20: 4f 4e 53 54 52 41 49 4e 54 43 4f 4c 55 4d 4e 53  ONSTRAINTCOLUMNS
2e30: 3b 0a 20 20 20 20 20 20 20 20 63 6d 64 2e 45 78  ;.        cmd.Ex
2e40: 65 63 75 74 65 4e 6f 6e 51 75 65 72 79 28 29 3b  ecuteNonQuery();
2e50: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a  .      }.    }..
2e60: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
2e70: 3e 0a 20 20 20 20 2f 2f 2f 20 54 75 72 6e 20 61  >.    /// Turn a
2e80: 20 64 61 74 61 74 61 62 6c 65 20 69 6e 74 6f 20   datatable into 
2e90: 61 20 74 61 62 6c 65 20 69 6e 20 74 68 65 20 74  a table in the t
2ea0: 65 6d 70 6f 72 61 72 79 20 64 61 74 61 62 61 73  emporary databas
2eb0: 65 20 66 6f 72 20 74 68 65 20 63 6f 6e 6e 65 63  e for the connec
2ec0: 74 69 6f 6e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  tion.    /// </s
2ed0: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
2ee0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 63 6e 6e  <param name="cnn
2ef0: 22 3e 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  ">The connection
2f00: 20 74 6f 20 6d 61 6b 65 20 74 68 65 20 74 65 6d   to make the tem
2f10: 70 6f 72 61 72 79 20 74 61 62 6c 65 20 69 6e 3c  porary table in<
2f20: 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20  /param>.    /// 
2f30: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 74 61 62  <param name="tab
2f40: 6c 65 22 3e 54 68 65 20 74 61 62 6c 65 20 74 6f  le">The table to
2f50: 20 77 72 69 74 65 20 6f 75 74 3c 2f 70 61 72 61   write out</para
2f60: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  m>.    /// <para
2f70: 6d 20 6e 61 6d 65 3d 22 64 65 73 74 22 3e 54 68  m name="dest">Th
2f80: 65 20 74 65 6d 70 6f 72 61 72 79 20 74 61 62 6c  e temporary tabl
2f90: 65 20 6e 61 6d 65 20 74 6f 20 77 72 69 74 65 20  e name to write 
2fa0: 74 6f 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 70  to</param>.    p
2fb0: 72 69 76 61 74 65 20 76 6f 69 64 20 44 61 74 61  rivate void Data
2fc0: 54 61 62 6c 65 54 6f 54 61 62 6c 65 28 53 51 4c  TableToTable(SQL
2fd0: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6e  iteConnection cn
2fe0: 6e 2c 20 44 61 74 61 54 61 62 6c 65 20 74 61 62  n, DataTable tab
2ff0: 6c 65 2c 20 73 74 72 69 6e 67 20 64 65 73 74 29  le, string dest)
3000: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 53 74 72  .    {.      Str
3010: 69 6e 67 42 75 69 6c 64 65 72 20 73 71 6c 20 3d  ingBuilder sql =
3020: 20 6e 65 77 20 53 74 72 69 6e 67 42 75 69 6c 64   new StringBuild
3030: 65 72 28 29 3b 0a 20 20 20 20 20 20 53 51 4c 69  er();.      SQLi
3040: 74 65 43 6f 6d 6d 61 6e 64 42 75 69 6c 64 65 72  teCommandBuilder
3050: 20 62 75 69 6c 64 65 72 20 3d 20 6e 65 77 20 53   builder = new S
3060: 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 42 75 69 6c  QLiteCommandBuil
3070: 64 65 72 28 29 3b 0a 0a 20 20 20 20 20 20 75 73  der();..      us
3080: 69 6e 67 20 28 53 51 4c 69 74 65 43 6f 6d 6d 61  ing (SQLiteComma
3090: 6e 64 20 63 6d 64 20 3d 20 63 6e 6e 2e 43 72 65  nd cmd = cnn.Cre
30a0: 61 74 65 43 6f 6d 6d 61 6e 64 28 29 29 0a 20 20  ateCommand()).  
30b0: 20 20 20 20 75 73 69 6e 67 20 28 44 61 74 61 54      using (DataT
30c0: 61 62 6c 65 20 73 6f 75 72 63 65 20 3d 20 6e 65  able source = ne
30d0: 77 20 44 61 74 61 54 61 62 6c 65 28 29 29 0a 20  w DataTable()). 
30e0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 73       {.        s
30f0: 71 6c 2e 41 70 70 65 6e 64 46 6f 72 6d 61 74 28  ql.AppendFormat(
3100: 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61  CultureInfo.Inva
3110: 72 69 61 6e 74 43 75 6c 74 75 72 65 2c 20 22 43  riantCulture, "C
3120: 52 45 41 54 45 20 54 45 4d 50 20 54 41 42 4c 45  REATE TEMP TABLE
3130: 20 7b 30 7d 20 28 22 2c 20 62 75 69 6c 64 65 72   {0} (", builder
3140: 2e 51 75 6f 74 65 49 64 65 6e 74 69 66 69 65 72  .QuoteIdentifier
3150: 28 64 65 73 74 29 29 3b 0a 20 20 20 20 20 20 20  (dest));.       
3160: 20 73 74 72 69 6e 67 20 73 65 70 61 72 61 74 6f   string separato
3170: 72 20 3d 20 53 74 72 69 6e 67 2e 45 6d 70 74 79  r = String.Empty
3180: 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 65 61 63  ;.        foreac
3190: 68 20 28 44 61 74 61 43 6f 6c 75 6d 6e 20 64 63  h (DataColumn dc
31a0: 20 69 6e 20 74 61 62 6c 65 2e 43 6f 6c 75 6d 6e   in table.Column
31b0: 73 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  s).        {.   
31c0: 20 20 20 20 20 20 20 44 62 54 79 70 65 20 64 62         DbType db
31d0: 74 79 70 65 4e 61 6d 65 20 3d 20 53 51 4c 69 74  typeName = SQLit
31e0: 65 43 6f 6e 76 65 72 74 2e 54 79 70 65 54 6f 44  eConvert.TypeToD
31f0: 62 54 79 70 65 28 64 63 2e 44 61 74 61 54 79 70  bType(dc.DataTyp
3200: 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 74  e);.          st
3210: 72 69 6e 67 20 74 79 70 65 4e 61 6d 65 20 3d 20  ring typeName = 
3220: 53 51 4c 69 74 65 43 6f 6e 76 65 72 74 2e 44 62  SQLiteConvert.Db
3230: 54 79 70 65 54 6f 54 79 70 65 4e 61 6d 65 28 64  TypeToTypeName(d
3240: 62 74 79 70 65 4e 61 6d 65 29 3b 0a 0a 20 20 20  btypeName);..   
3250: 20 20 20 20 20 20 20 73 71 6c 2e 41 70 70 65 6e         sql.Appen
3260: 64 46 6f 72 6d 61 74 28 43 75 6c 74 75 72 65 49  dFormat(CultureI
3270: 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c  nfo.InvariantCul
3280: 74 75 72 65 2c 20 22 7b 32 7d 7b 30 7d 20 7b 31  ture, "{2}{0} {1
3290: 7d 20 43 4f 4c 4c 41 54 45 20 4e 4f 43 41 53 45  } COLLATE NOCASE
32a0: 22 2c 20 62 75 69 6c 64 65 72 2e 51 75 6f 74 65  ", builder.Quote
32b0: 49 64 65 6e 74 69 66 69 65 72 28 64 63 2e 43 6f  Identifier(dc.Co
32c0: 6c 75 6d 6e 4e 61 6d 65 29 2c 20 74 79 70 65 4e  lumnName), typeN
32d0: 61 6d 65 2c 20 73 65 70 61 72 61 74 6f 72 29 3b  ame, separator);
32e0: 0a 20 20 20 20 20 20 20 20 20 20 73 65 70 61 72  .          separ
32f0: 61 74 6f 72 20 3d 20 22 2c 20 22 3b 0a 20 20 20  ator = ", ";.   
3300: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 73       }.        s
3310: 71 6c 2e 41 70 70 65 6e 64 28 22 29 22 29 3b 0a  ql.Append(")");.
3320: 0a 20 20 20 20 20 20 20 20 63 6d 64 2e 43 6f 6d  .        cmd.Com
3330: 6d 61 6e 64 54 65 78 74 20 3d 20 73 71 6c 2e 54  mandText = sql.T
3340: 6f 53 74 72 69 6e 67 28 29 3b 0a 20 20 20 20 20  oString();.     
3350: 20 20 20 63 6d 64 2e 45 78 65 63 75 74 65 4e 6f     cmd.ExecuteNo
3360: 6e 51 75 65 72 79 28 29 3b 0a 0a 20 20 20 20 20  nQuery();..     
3370: 20 20 20 63 6d 64 2e 43 6f 6d 6d 61 6e 64 54 65     cmd.CommandTe
3380: 78 74 20 3d 20 53 74 72 69 6e 67 2e 46 6f 72 6d  xt = String.Form
3390: 61 74 28 22 53 45 4c 45 43 54 20 2a 20 46 52 4f  at("SELECT * FRO
33a0: 4d 20 54 45 4d 50 2e 7b 30 7d 20 57 48 45 52 45  M TEMP.{0} WHERE
33b0: 20 31 3d 32 22 2c 20 62 75 69 6c 64 65 72 2e 51   1=2", builder.Q
33c0: 75 6f 74 65 49 64 65 6e 74 69 66 69 65 72 28 64  uoteIdentifier(d
33d0: 65 73 74 29 29 3b 0a 20 20 20 20 20 20 20 20 75  est));.        u
33e0: 73 69 6e 67 20 28 53 51 4c 69 74 65 44 61 74 61  sing (SQLiteData
33f0: 41 64 61 70 74 65 72 20 61 64 70 20 3d 20 6e 65  Adapter adp = ne
3400: 77 20 53 51 4c 69 74 65 44 61 74 61 41 64 61 70  w SQLiteDataAdap
3410: 74 65 72 28 63 6d 64 29 29 0a 20 20 20 20 20 20  ter(cmd)).      
3420: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 62 75    {.          bu
3430: 69 6c 64 65 72 2e 44 61 74 61 41 64 61 70 74 65  ilder.DataAdapte
3440: 72 20 3d 20 61 64 70 3b 0a 0a 20 20 20 20 20 20  r = adp;..      
3450: 20 20 20 20 61 64 70 2e 46 69 6c 6c 28 73 6f 75      adp.Fill(sou
3460: 72 63 65 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  rce);..         
3470: 20 66 6f 72 65 61 63 68 20 28 44 61 74 61 52 6f   foreach (DataRo
3480: 77 20 72 6f 77 20 69 6e 20 74 61 62 6c 65 2e 52  w row in table.R
3490: 6f 77 73 29 0a 20 20 20 20 20 20 20 20 20 20 7b  ows).          {
34a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6f 62 6a  .            obj
34b0: 65 63 74 5b 5d 20 61 72 72 20 3d 20 72 6f 77 2e  ect[] arr = row.
34c0: 49 74 65 6d 41 72 72 61 79 3b 0a 0a 20 20 20 20  ItemArray;..    
34d0: 20 20 20 20 20 20 20 20 73 6f 75 72 63 65 2e 52          source.R
34e0: 6f 77 73 2e 41 64 64 28 61 72 72 29 3b 0a 20 20  ows.Add(arr);.  
34f0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3500: 20 20 20 20 61 64 70 2e 55 70 64 61 74 65 28 73      adp.Update(s
3510: 6f 75 72 63 65 29 3b 0a 20 20 20 20 20 20 20 20  ource);.        
3520: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  }.      }.    }.
3530: 0a 20 20 20 20 23 65 6e 64 72 65 67 69 6f 6e 0a  .    #endregion.
3540: 20 20 7d 0a 7d 0a 0a                               }.}..