System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 9837a695a1e7a519c7a2e53cd2c899ef24374841:


0000: 2f 2f 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  //--------------
0010: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0020: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0030: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0040: 2d 2d 2d 2d 2d 2d 2d 0d 0a 2f 2f 20 3c 63 6f 70  -------..// <cop
0050: 79 72 69 67 68 74 20 66 69 6c 65 3d 22 53 71 6c  yright file="Sql
0060: 42 75 69 6c 64 65 72 2e 63 73 22 20 63 6f 6d 70  Builder.cs" comp
0070: 61 6e 79 3d 22 4d 69 63 72 6f 73 6f 66 74 22 3e  any="Microsoft">
0080: 0d 0a 2f 2f 20 20 20 20 20 20 50 6f 72 74 69 6f  ..//      Portio
0090: 6e 73 20 6f 66 20 74 68 69 73 20 66 69 6c 65 20  ns of this file 
00a0: 63 6f 70 79 72 69 67 68 74 20 28 63 29 20 4d 69  copyright (c) Mi
00b0: 63 72 6f 73 6f 66 74 20 43 6f 72 70 6f 72 61 74  crosoft Corporat
00c0: 69 6f 6e 0d 0a 2f 2f 20 20 20 20 20 20 61 6e 64  ion..//      and
00d0: 20 61 72 65 20 72 65 6c 65 61 73 65 64 20 75 6e   are released un
00e0: 64 65 72 20 74 68 65 20 4d 69 63 72 6f 73 6f 66  der the Microsof
00f0: 74 20 50 75 6c 69 63 20 4c 69 63 65 6e 73 65 2e  t Pulic License.
0100: 20 20 53 65 65 0d 0a 2f 2f 20 20 20 20 20 20 68    See..//      h
0110: 74 74 70 3a 2f 2f 61 72 63 68 69 76 65 2e 6d 73  ttp://archive.ms
0120: 64 6e 2e 6d 69 63 72 6f 73 6f 66 74 2e 63 6f 6d  dn.microsoft.com
0130: 2f 45 46 53 61 6d 70 6c 65 50 72 6f 76 69 64 65  /EFSampleProvide
0140: 72 2f 50 72 6f 6a 65 63 74 2f 4c 69 63 65 6e 73  r/Project/Licens
0150: 65 2e 61 73 70 78 0d 0a 2f 2f 20 20 20 20 20 20  e.aspx..//      
0160: 6f 72 20 4c 69 63 65 6e 73 65 2e 74 78 74 20 66  or License.txt f
0170: 6f 72 20 64 65 74 61 69 6c 73 2e 0d 0a 2f 2f 20  or details...// 
0180: 20 20 20 20 20 41 6c 6c 20 72 69 67 68 74 73 20       All rights 
0190: 72 65 73 65 72 76 65 64 2e 0d 0a 2f 2f 20 3c 2f  reserved...// </
01a0: 63 6f 70 79 72 69 67 68 74 3e 0d 0a 2f 2f 2d 2d  copyright>..//--
01b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01f0: 2d 2d 2d 0d 0a 0d 0a 6e 61 6d 65 73 70 61 63 65  ---....namespace
0200: 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c   System.Data.SQL
0210: 69 74 65 0d 0a 7b 0d 0a 20 20 75 73 69 6e 67 20  ite..{..  using 
0220: 53 79 73 74 65 6d 3b 0d 0a 20 20 75 73 69 6e 67  System;..  using
0230: 20 53 79 73 74 65 6d 2e 43 6f 6c 6c 65 63 74 69   System.Collecti
0240: 6f 6e 73 2e 47 65 6e 65 72 69 63 3b 0d 0a 20 20  ons.Generic;..  
0250: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 69 61  using System.Dia
0260: 67 6e 6f 73 74 69 63 73 3b 0d 0a 20 20 75 73 69  gnostics;..  usi
0270: 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 43  ng System.Data.C
0280: 6f 6d 6d 6f 6e 2e 43 6f 6d 6d 61 6e 64 54 72 65  ommon.CommandTre
0290: 65 73 3b 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c 73 75  es;....  /// <su
02a0: 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20 54 68  mmary>..  /// Th
02b0: 69 73 20 63 6c 61 73 73 20 69 73 20 6c 69 6b 65  is class is like
02c0: 20 53 74 72 69 6e 67 42 75 69 6c 64 65 72 2e 20   StringBuilder. 
02d0: 20 57 68 69 6c 65 20 74 72 61 76 65 72 73 69 6e   While traversin
02e0: 67 20 74 68 65 20 74 72 65 65 20 66 6f 72 20 74  g the tree for t
02f0: 68 65 20 66 69 72 73 74 20 74 69 6d 65 2c 20 0d  he first time, .
0300: 0a 20 20 2f 2f 2f 20 77 65 20 64 6f 20 6e 6f 74  .  /// we do not
0310: 20 6b 6e 6f 77 20 61 6c 6c 20 74 68 65 20 73 74   know all the st
0320: 72 69 6e 67 73 20 74 68 61 74 20 6e 65 65 64 20  rings that need 
0330: 74 6f 20 62 65 20 61 70 70 65 6e 64 65 64 20 65  to be appended e
0340: 2e 67 2e 20 74 68 69 6e 67 73 20 74 68 61 74 20  .g. things that 
0350: 6e 65 65 64 20 74 6f 20 62 65 0d 0a 20 20 2f 2f  need to be..  //
0360: 2f 20 72 65 6e 61 6d 65 64 2c 20 6e 65 73 74 65  / renamed, neste
0370: 64 20 73 65 6c 65 63 74 20 73 74 61 74 65 6d 65  d select stateme
0380: 6e 74 73 20 65 74 63 2e 20 20 53 6f 2c 20 77 65  nts etc.  So, we
0390: 20 75 73 65 20 61 20 62 75 69 6c 64 65 72 20 74   use a builder t
03a0: 68 61 74 20 63 61 6e 20 63 6f 6c 6c 65 63 74 0d  hat can collect.
03b0: 0a 20 20 2f 2f 2f 20 61 6c 6c 20 6b 69 6e 64 73  .  /// all kinds
03c0: 20 6f 66 20 73 71 6c 20 66 72 61 67 6d 65 6e 74   of sql fragment
03d0: 73 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  s...  /// </summ
03e0: 61 72 79 3e 0d 0a 20 20 69 6e 74 65 72 6e 61 6c  ary>..  internal
03f0: 20 73 65 61 6c 65 64 20 63 6c 61 73 73 20 53 71   sealed class Sq
0400: 6c 42 75 69 6c 64 65 72 20 3a 20 49 53 71 6c 46  lBuilder : ISqlF
0410: 72 61 67 6d 65 6e 74 0d 0a 20 20 7b 0d 0a 20 20  ragment..  {..  
0420: 20 20 70 72 69 76 61 74 65 20 4c 69 73 74 3c 6f    private List<o
0430: 62 6a 65 63 74 3e 20 5f 73 71 6c 46 72 61 67 6d  bject> _sqlFragm
0440: 65 6e 74 73 3b 0d 0a 20 20 20 20 70 72 69 76 61  ents;..    priva
0450: 74 65 20 4c 69 73 74 3c 6f 62 6a 65 63 74 3e 20  te List<object> 
0460: 73 71 6c 46 72 61 67 6d 65 6e 74 73 0d 0a 20 20  sqlFragments..  
0470: 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74 0d 0a    {..      get..
0480: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
0490: 20 69 66 20 28 6e 75 6c 6c 20 3d 3d 20 5f 73 71   if (null == _sq
04a0: 6c 46 72 61 67 6d 65 6e 74 73 29 0d 0a 20 20 20  lFragments)..   
04b0: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
04c0: 20 20 5f 73 71 6c 46 72 61 67 6d 65 6e 74 73 20    _sqlFragments 
04d0: 3d 20 6e 65 77 20 4c 69 73 74 3c 6f 62 6a 65 63  = new List<objec
04e0: 74 3e 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  t>();..        }
04f0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
0500: 20 5f 73 71 6c 46 72 61 67 6d 65 6e 74 73 3b 0d   _sqlFragments;.
0510: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d  .      }..    }.
0520: 0a 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  .....    /// <su
0530: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
0540: 41 64 64 20 61 6e 20 6f 62 6a 65 63 74 20 74 6f  Add an object to
0550: 20 74 68 65 20 6c 69 73 74 20 2d 20 77 65 20 64   the list - we d
0560: 6f 20 6e 6f 74 20 76 65 72 69 66 79 20 74 68 61  o not verify tha
0570: 74 20 69 74 20 69 73 20 61 20 70 72 6f 70 65 72  t it is a proper
0580: 20 73 71 6c 20 66 72 61 67 6d 65 6e 74 0d 0a 20   sql fragment.. 
0590: 20 20 20 2f 2f 2f 20 73 69 6e 63 65 20 74 68 69     /// since thi
05a0: 73 20 69 73 20 61 6e 20 69 6e 74 65 72 6e 61 6c  s is an internal
05b0: 20 6d 65 74 68 6f 64 2e 0d 0a 20 20 20 20 2f 2f   method...    //
05c0: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
05d0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
05e0: 65 3d 22 73 22 3e 3c 2f 70 61 72 61 6d 3e 0d 0a  e="s"></param>..
05f0: 20 20 20 20 70 75 62 6c 69 63 20 76 6f 69 64 20      public void 
0600: 41 70 70 65 6e 64 28 6f 62 6a 65 63 74 20 73 29  Append(object s)
0610: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 44  ..    {..      D
0620: 65 62 75 67 2e 41 73 73 65 72 74 28 73 20 21 3d  ebug.Assert(s !=
0630: 20 6e 75 6c 6c 29 3b 0d 0a 20 20 20 20 20 20 73   null);..      s
0640: 71 6c 46 72 61 67 6d 65 6e 74 73 2e 41 64 64 28  qlFragments.Add(
0650: 73 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  s);..    }....  
0660: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
0670: 0a 20 20 20 20 2f 2f 2f 20 54 68 69 73 20 69 73  .    /// This is
0680: 20 74 6f 20 70 72 65 74 74 79 20 70 72 69 6e 74   to pretty print
0690: 20 74 68 65 20 53 51 4c 2e 20 20 54 68 65 20 77   the SQL.  The w
06a0: 72 69 74 65 72 20 3c 73 65 65 20 63 72 65 66 3d  riter <see cref=
06b0: 22 53 71 6c 57 72 69 74 65 72 2e 57 72 69 74 65  "SqlWriter.Write
06c0: 22 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 6e 65 65  "/>..    /// nee
06d0: 64 73 20 74 6f 20 6b 6e 6f 77 20 61 62 6f 75 74  ds to know about
06e0: 20 6e 65 77 20 6c 69 6e 65 73 20 73 6f 20 74 68   new lines so th
06f0: 61 74 20 69 74 20 63 61 6e 20 61 64 64 20 74 68  at it can add th
0700: 65 20 72 69 67 68 74 20 61 6d 6f 75 6e 74 20 6f  e right amount o
0710: 66 20 0d 0a 20 20 20 20 2f 2f 2f 20 69 6e 64 65  f ..    /// inde
0720: 6e 74 61 74 69 6f 6e 20 61 74 20 74 68 65 20 62  ntation at the b
0730: 65 67 69 6e 6e 69 6e 67 20 6f 66 20 6c 69 6e 65  eginning of line
0740: 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  s...    /// </su
0750: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 75 62 6c  mmary>..    publ
0760: 69 63 20 76 6f 69 64 20 41 70 70 65 6e 64 4c 69  ic void AppendLi
0770: 6e 65 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  ne()..    {..   
0780: 20 20 20 73 71 6c 46 72 61 67 6d 65 6e 74 73 2e     sqlFragments.
0790: 41 64 64 28 22 5c 72 5c 6e 22 29 3b 0d 0a 20 20  Add("\r\n");..  
07a0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c    }....    /// <
07b0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
07c0: 2f 20 57 68 65 74 68 65 72 20 74 68 65 20 62 75  / Whether the bu
07d0: 69 6c 64 65 72 20 69 73 20 65 6d 70 74 79 2e 20  ilder is empty. 
07e0: 20 54 68 69 73 20 69 73 20 75 73 65 64 20 62 79   This is used by
07f0: 20 74 68 65 20 3c 73 65 65 20 63 72 65 66 3d 22   the <see cref="
0800: 53 71 6c 47 65 6e 65 72 61 74 6f 72 2e 56 69 73  SqlGenerator.Vis
0810: 69 74 28 44 62 50 72 6f 6a 65 63 74 45 78 70 72  it(DbProjectExpr
0820: 65 73 73 69 6f 6e 29 22 2f 3e 0d 0a 20 20 20 20  ession)"/>..    
0830: 2f 2f 2f 20 74 6f 20 64 65 74 65 72 6d 69 6e 65  /// to determine
0840: 20 77 68 65 74 68 65 72 20 61 20 73 71 6c 20 73   whether a sql s
0850: 74 61 74 65 6d 65 6e 74 20 63 61 6e 20 62 65 20  tatement can be 
0860: 72 65 75 73 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f  reused...    ///
0870: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20   </summary>..   
0880: 20 70 75 62 6c 69 63 20 62 6f 6f 6c 20 49 73 45   public bool IsE
0890: 6d 70 74 79 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  mpty..    {..   
08a0: 20 20 20 67 65 74 20 7b 20 72 65 74 75 72 6e 20     get { return 
08b0: 28 28 6e 75 6c 6c 20 3d 3d 20 5f 73 71 6c 46 72  ((null == _sqlFr
08c0: 61 67 6d 65 6e 74 73 29 20 7c 7c 20 28 30 20 3d  agments) || (0 =
08d0: 3d 20 5f 73 71 6c 46 72 61 67 6d 65 6e 74 73 2e  = _sqlFragments.
08e0: 43 6f 75 6e 74 29 29 3b 20 7d 0d 0a 20 20 20 20  Count)); }..    
08f0: 7d 0d 0a 0d 0a 20 20 20 20 23 72 65 67 69 6f 6e  }....    #region
0900: 20 49 53 71 6c 46 72 61 67 6d 65 6e 74 20 4d 65   ISqlFragment Me
0910: 6d 62 65 72 73 0d 0a 0d 0a 20 20 20 20 2f 2f 2f  mbers....    ///
0920: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
0930: 2f 2f 2f 20 57 65 20 64 65 6c 65 67 61 74 65 20  /// We delegate 
0940: 74 68 65 20 77 72 69 74 69 6e 67 20 6f 66 20 74  the writing of t
0950: 68 65 20 66 72 61 67 6d 65 6e 74 20 74 6f 20 74  he fragment to t
0960: 68 65 20 61 70 70 72 6f 70 72 69 61 74 65 20 74  he appropriate t
0970: 79 70 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ype...    /// </
0980: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
0990: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 77  / <param name="w
09a0: 72 69 74 65 72 22 3e 3c 2f 70 61 72 61 6d 3e 0d  riter"></param>.
09b0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
09c0: 6e 61 6d 65 3d 22 73 71 6c 47 65 6e 65 72 61 74  name="sqlGenerat
09d0: 6f 72 22 3e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  or"></param>..  
09e0: 20 20 70 75 62 6c 69 63 20 76 6f 69 64 20 57 72    public void Wr
09f0: 69 74 65 53 71 6c 28 53 71 6c 57 72 69 74 65 72  iteSql(SqlWriter
0a00: 20 77 72 69 74 65 72 2c 20 53 71 6c 47 65 6e 65   writer, SqlGene
0a10: 72 61 74 6f 72 20 73 71 6c 47 65 6e 65 72 61 74  rator sqlGenerat
0a20: 6f 72 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  or)..    {..    
0a30: 20 20 69 66 20 28 6e 75 6c 6c 20 21 3d 20 5f 73    if (null != _s
0a40: 71 6c 46 72 61 67 6d 65 6e 74 73 29 0d 0a 20 20  qlFragments)..  
0a50: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 66      {..        f
0a60: 6f 72 65 61 63 68 20 28 6f 62 6a 65 63 74 20 6f  oreach (object o
0a70: 20 69 6e 20 5f 73 71 6c 46 72 61 67 6d 65 6e 74   in _sqlFragment
0a80: 73 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  s)..        {.. 
0a90: 20 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20           string 
0aa0: 73 74 72 20 3d 20 28 6f 20 61 73 20 53 74 72 69  str = (o as Stri
0ab0: 6e 67 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  ng);..          
0ac0: 69 66 20 28 6e 75 6c 6c 20 21 3d 20 73 74 72 29  if (null != str)
0ad0: 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20  ..          {.. 
0ae0: 20 20 20 20 20 20 20 20 20 20 20 77 72 69 74 65             write
0af0: 72 2e 57 72 69 74 65 28 73 74 72 29 3b 0d 0a 20  r.Write(str);.. 
0b00: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
0b10: 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20        else..    
0b20: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
0b30: 20 20 20 20 20 49 53 71 6c 46 72 61 67 6d 65 6e       ISqlFragmen
0b40: 74 20 73 71 6c 46 72 61 67 6d 65 6e 74 20 3d 20  t sqlFragment = 
0b50: 28 6f 20 61 73 20 49 53 71 6c 46 72 61 67 6d 65  (o as ISqlFragme
0b60: 6e 74 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  nt);..          
0b70: 20 20 69 66 20 28 6e 75 6c 6c 20 21 3d 20 73 71    if (null != sq
0b80: 6c 46 72 61 67 6d 65 6e 74 29 0d 0a 20 20 20 20  lFragment)..    
0b90: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
0ba0: 20 20 20 20 20 20 20 20 20 73 71 6c 46 72 61 67           sqlFrag
0bb0: 6d 65 6e 74 2e 57 72 69 74 65 53 71 6c 28 77 72  ment.WriteSql(wr
0bc0: 69 74 65 72 2c 20 73 71 6c 47 65 6e 65 72 61 74  iter, sqlGenerat
0bd0: 6f 72 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  or);..          
0be0: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20    }..           
0bf0: 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20   else..         
0c00: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
0c10: 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e      throw new In
0c20: 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78  validOperationEx
0c30: 63 65 70 74 69 6f 6e 28 29 3b 0d 0a 20 20 20 20  ception();..    
0c40: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
0c50: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
0c60: 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  }..      }..    
0c70: 7d 0d 0a 0d 0a 20 20 20 20 23 65 6e 64 72 65 67  }....    #endreg
0c80: 69 6f 6e 0d 0a 20 20 7d 0d 0a 7d 0d 0a           ion..  }..}..