2012-05-12 71 views
0

可能重複:
converting nvarchar value in C# to date/time equivalent in Sql轉換數據類型迄今爲止bulkcopy accure前

我讀txt文件的數據包含不同的列。我需要插入前一列日期/時間的類型轉換爲數據庫

SqlBulkCopy bc = new SqlBulkCopy(Consql.ConnectionString, SqlBulkCopyOptions.TableLock); 
bc.DestinationTableName = "name"; 
bc.ColumnMappings.Add(dt.Columns[0].ColumnName, "IDATE"); 
bc.ColumnMappings.Add(dt.Columns[1].ColumnName, "ITIME"); 
bc.ColumnMappings.Add(dt.Columns[2].ColumnName, "TECHID"); 
bc.ColumnMappings.Add(dt.Columns[5].ColumnName, "CNTRC"); 
bc.BatchSize = dt.Rows.Count; 
Consql.Open(); 
+0

當你定義數據表列,是什麼你是否將它設置爲? –

+0

也許編輯你的問題,包括數據的一個例子,以及你如何構建和添加到DataTable。 –

回答

0

我認爲使用SqlBulkCopy的需要實現IDataReader的接口。 實現它可以將源文件中的值轉換爲所需的類型。

您的自定義的讀者可以關注一下這樣

public class Reader : IDataReader 
    { 
     readonly StreamReader _streamReader; 

     readonly Func<string, object>[] _convertTable; 
     readonly Func<string, bool>[] _constraintsTable; 

     string[] _currentLineValues; 
     string _currentLine; 

     //Constructing reader you can specify your converters  
     public Reader(string filepath, Func<string, bool>[] constraintsTable, Func<string, object>[] convertTable) 
     { 
      _constraintsTable = constraintsTable; 
      _convertTable = convertTable; 
      _streamReader = new StreamReader(filepath); 

      _currentLine = null; 
      _currentLineValues = null; 
     } 


     public object GetValue(int i) 
     { 
      try 
      { 
       return _convertTable[i](_currentLineValues[i]); 
      } 
      catch (Exception) 
      { 
       return null; 
      } 
     } 


     public bool Read() 
     { 
      if (_streamReader.EndOfStream) return false; 

      _currentLine = _streamReader.ReadLine(); 


      _currentLineValues = _currentLine.Split(/*any column splitter*/); 

      var invalidRow = false; 
      for (int i = 0; i < _currentLineValues.Length; i++) 
      { 
       if (!_constraintsTable[i](_currentLineValues[i])) 
       { 
        invalidRow = true; 
        break; 
       } 
      } 

      return !invalidRow || Read(); 
     } 



//other methods... 
} 

而且你可以使用它像這樣(轉換源列的DateTime之一):

static void Main(string[] args) 
     { 
      // Create Reader 
      var reader = GetReader(); 

      // DB connection string 
      var connectionString = @"Server={blah};initial catalog={blah-blah};Integrated Security=true";  

      using (var loader = new SqlBulkCopy(connectionString, SqlBulkCopyOptions.Default)) 
      { 
       loader.ColumnMappings.Add(0, 2); 
       loader.ColumnMappings.Add(1, 1); 
       loader.ColumnMappings.Add(2, 3); 
       loader.ColumnMappings.Add(3, 4); 

       loader.DestinationTableName = "Customers"; 
       loader.WriteToServer(reader); 

       Console.WriteLine("Done!"); 
      } 

      Console.ReadLine(); 
     } 

     static IDataReader GetReader() 
     { 
      var sourceFilepath = "sqlbulktest.txt"; 
      //our converters! 
      var convertTable = GetConvertTable(); 

      var constraintsTable = GetConstraintsTable(); 

      var reader = new Reader(sourceFilepath, constraintsTable, convertTable); 
      return reader; 
     } 

     static Func<string, bool>[] GetConstraintsTable() 
     { 
      var constraintsTable = new Func<string, bool>[4]; 

      constraintsTable[0] = x => !string.IsNullOrEmpty(x); 
      constraintsTable[1] = constraintsTable[0]; 
      constraintsTable[2] = x => true; 
      constraintsTable[3] = x => true; 
      return constraintsTable; 
     } 

     static Func<string, object>[] GetConvertTable() 
     { 
      var convertTable = new Func<object, object>[4]; 

      convertTable[0] = x => x; 


      convertTable[1] = x => x; 


      // Convert to DateTime from specific format! 
      convertTable[2] = x => 
           { 
            DateTime datetime; 
            if (DateTime.TryParseExact(x.ToString(), "dd.MM.yyyy", CultureInfo.InvariantCulture, 
             DateTimeStyles.None, out datetime)) 
            { 
             return datetime; 
            } 
            return null; 
           };  

      convertTable[3] = x => Convert.ToInt32(x); 

      return convertTable; 
     }