zoukankan      html  css  js  c++  java
  • SqlBulkCopy 来自数据源的 String 类型的给定值不能转换为指定目标列的类型 bit

    使用SqlBulkCopy批量插入,可以快速对大批量的数量插入,性能非常好

    在使用时出现“来自数据源的 String 类型的给定值不能转换为指定目标列的类型 bit”异常

    为DataTable与要插入的数据表字段位置不一样所至

    DataTable与要插入的数据表要字段名,位置,数据类型都一至才可

    示例,使用使用SqlBulkCopy插入多个表

            public bool BatchInsertUniqeCode(DataTable uniqueCodeProduceContrastDt,DataTable uniqueCodeGenerateDt)
            {
                using(SqlConnection conn= (SqlConnection)(base.DbContext.Database.Connection))
                {
                    if (conn.State == ConnectionState.Closed) { conn.Open(); }
                    SqlTransaction tran = conn.BeginTransaction();
                    SqlBulkCopy upBlock = new SqlBulkCopy(conn, SqlBulkCopyOptions.Default, tran);
                    SqlBulkCopy ugBlock = new SqlBulkCopy(conn, SqlBulkCopyOptions.Default, tran);
                    try
                    {
                        ugBlock.DestinationTableName = "UniqueCodeGenerate";
                        ugBlock.BatchSize = uniqueCodeGenerateDt.Rows.Count;
                        if (uniqueCodeGenerateDt != null && uniqueCodeGenerateDt.Rows.Count > 0)
                        {
                            ugBlock.WriteToServer(uniqueCodeGenerateDt);
                        }
                        ugBlock.Close();
    
    
                        upBlock.DestinationTableName = "UniqueCodeProduceContrast";
                        upBlock.BatchSize = uniqueCodeProduceContrastDt.Rows.Count;
                        if (uniqueCodeProduceContrastDt != null && uniqueCodeProduceContrastDt.Rows.Count > 0)
                        {
                            upBlock.WriteToServer(uniqueCodeProduceContrastDt);
                        }
                        upBlock.Close();
    
                        tran.Commit();
                        return true;
                    }
                    catch(Exception ex)
                    {
                        tran.Rollback();
                        throw ex;
                    }
                    finally
                    {
                        upBlock.Close();
                        ugBlock.Close();
                        conn.Close();
                    }
    
                }
    
            }
  • 相关阅读:
    面向对象(二)-特性
    面向对象(一)-初步认识
    函数(十)-内置模块
    函数(九)-包与模块
    函数(八)-闭包与装饰器
    函数(七)-嵌套作用域
    函数(六)-匿名函数
    CSS阴影效果(Box-shadow)用法趣味讲解
    css 实现div内显示两行或三行,超出部分用省略号显示
    js基础知识(一)--截取字符串
  • 原文地址:https://www.cnblogs.com/berlin/p/6766779.html
Copyright © 2011-2022 走看看