1. SqlBulkCopy

可以利用这个类实现快速大批量新增数据的效果, 但在使用过程中发现了一个问题: 无法将数据源中的DateTime类型转换成数据库中的int类型

看起来就是数据列不对应导致的, 不过一开始也不确定,后面试验确定 SqlBulkCopy 自建的DataTable数据源writeToServer在未添加列与列的映射(ColumnMappings)时候即使列名一致 也并不是按列名写入数据的,而是按列的索引进行添加的.

故解决方法有二个:

  (1) 在自建的数据源DataTable中补充前面的列 (若列处于需要添加的字段后面 则不用);

  (2) SqlBulkCopy 列映射集合中添加 sqlBulkCopy.ColumnMappings.Add(sourceColumn, destinationColumn);  将每列与目标数据库中的表关联;

代码如下:

         public bool BulkAddData(string recordsString)
         {
             string[] records = recordsString.Split('$');
             bool boolIsSuccess = false;
             DataTable dtTemp = new DataTable();
             dtTemp.Columns.Add(new DataColumn("ID", typeof(int)));  //(1)ID在目标表中是自增列,并且是第一列
             dtTemp.Columns.Add(new DataColumn("ScanUserID", typeof(int)));
             dtTemp.Columns.Add(new DataColumn("ScanDate", typeof(DateTime)));
             dtTemp.Columns.Add(new DataColumn("PO", typeof(string)));
             dtTemp.Columns.Add(new DataColumn("SerialNumber", typeof(string)));
             dtTemp.Columns.Add(new DataColumn("Container", typeof(string)));
             dtTemp.Columns.Add(new DataColumn("ModelName", typeof(string)));
             dtTemp.Columns.Add(new DataColumn("ModelID", typeof(int)));

             foreach (string record in records)
             {
                 DataRow dr = dtTemp.NewRow();
                 string[] strModel = record.Split(',');
                 )
                 {
                     // ID是自增列,不用赋值
                     dr[]);
                     dr[]);
                     dr[];
                     dr[];
                     dr[];
                     dr[];
                     dr[]);
                 }
                 dtTemp.Rows.Add(dr);
             }
             string strConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString.ToString();
             using (SqlConnection conn = new SqlConnection(strConnectionString))
             {
                 conn.Open();
                 SqlTransaction tran = conn.BeginTransaction();
                 SqlBulkCopy sqlBulkCopy = new SqlBulkCopy(conn, SqlBulkCopyOptions.Default, tran);
                 sqlBulkCopy.DestinationTableName = "T_DeliveryRecord";
                 sqlBulkCopy.BatchSize = dtTemp.Rows.Count;
                 //(2) SqlBulkCopy 的表映射默认是按索引来和目标表对应的, 可通过以下方法强制对应
                 //sqlBulkCopy.ColumnMappings.Add("ScanUserID", "ScanUserID");
                 //sqlBulkCopy.ColumnMappings.Add("ScanDate", "ScanDate");
                 //sqlBulkCopy.ColumnMappings.Add("PO", "PO");
                 //sqlBulkCopy.ColumnMappings.Add("SerialNumber", "SerialNumber");
                 //sqlBulkCopy.ColumnMappings.Add("Container", "Container");
                 //sqlBulkCopy.ColumnMappings.Add("ModelName", "ModelName");
                 //sqlBulkCopy.ColumnMappings.Add("ModelID", "ModelID");

                 try
                 {
                     sqlBulkCopy.WriteToServer(dtTemp);
                     tran.Commit();
                     boolIsSuccess = true;
                 }
                 catch
                 {
                     tran.Rollback();
                     boolIsSuccess = false;
                 }
                 finally
                 {
                     sqlBulkCopy.Close();
                 }
             }

             return boolIsSuccess;
         }

ID是我的主键自增的列,位于表的第一位, 所以dtTemp中没有ID列的时候 ScanDate的数据 将插入数据库中的ScanUserID这个int类型的字段中出现上面提到的类型错误; 也就是列的不对应;

所以用方法(1) 解决本问题时, 临时数据表的字段名及顺序需要与目标表一致, 有默认值或者自增的字段不需要赋值; 当然这种情况的列只是作为占位,字段名不用对应也可以:如上面的dtTemp.Columns.Add(new DataColumn("ID", typeof(int))) 改成 dtTemp.Columns.Add(new DataColumn("AA", typeof(int))) 一样也是可以的 );

attention: 注意如果给自增列赋值且SqlBulkCopyOptions.KeepIdentity 将导致目标表该自增列的自增失效;

C# 平时碰见的问题【1】的更多相关文章

  1. C# 平时碰见的问题【6】

    EF Code First 设置复合主键的方法 除了单纯多对多的关系表外, 我们可能在关系表上加其他的属性: 比如[订单行] 对应的[订单]和[商品]就需要多一个数量字段 而又不想在这个[订单行]表上 ...

  2. C# 平时碰见的问题【5】

    vs按F5启动调试,项目不会编译的解决办法 工具 -> 选项 -> 项目和解决方案 -> 运行时, 当项目过期(下拉框) -> 不要选[从不生成] 附英文版的:

  3. C# 平时碰见的问题【4】

    1. 模糊查询 like的参数化写法 string keyword="value"; // 要模糊匹配的值 错误示范:   sql:    string strSql=" ...

  4. C# 平时碰见的问题【3】

    今天发现一个问题纳闷了半个小时, 需求是处理project文件里边的数据内容,其中需要判断任务名称不存在重复; 在测试的时候弄了两行一样的任务,如预想: 任务[xxx]重复 然后删掉重复的任务行,继续 ...

  5. C# 平时碰见的问题【2】

    问题1 修改命名空间后 .ashx 类型创建失败 [情景] 在调整前后台项目结构的时候,修改了默认命名空间(XXX.Admin 修改成XXX.Web),结果调试的时候发现XXX.Admin.Ajax. ...

  6. Android使用静默安装时碰见的问题

    升级时碰见的异常 private void installPackage(String appName,final File apk) { if (!apk.exists()) { setHasNew ...

  7. 使用karma测试平时写的小demo(arguments为例)

    有人说前端自动化测试非常困难,我觉得确实如此.在项目中,我个人也不放心写的测试,还是要手动测试.但是我们平时写demo学习时,完全可以使用自动化测试. 传统demo 1,新建一个html 2,写入js ...

  8. CSS3动画几个平时没注意的属性

    一.timing-function: steps() 一开始在使用CSS3的时候并没有太注意这个timing-function,只是注意到自定义贝塞尔曲线. 1)一个项目中的实例 先来看看左边加了st ...

  9. 这些HTML、CSS知识点,面试和平时开发都需要 No1-No4

    系列知识点汇总 这些HTML.CSS知识点,面试和平时开发都需要 No1-No4(知识点:HTML.CSS.盒子模型.内容布局) 这些HTML.CSS知识点,面试和平时开发都需要 No5-No7(知识 ...

随机推荐

  1. sql获取时间

    SELECT CONVERT(varchar(10), getdate(), 120)--当前年月日,Example:2013-11-19 SELECT CONVERT(varchar(10), ge ...

  2. .NET设计规范————类型设计规范

    类型设计规范 从CLR的角度看,只有值类型和引用类型两种类型,但是从框架设计的角度我们把类型从逻辑上分了更多的组.如下所示: 类是引用类型的一般情况,占了框架中的大多情况,类的流行归于它支持面向对象的 ...

  3. 在android中用跑马灯的效果显示textview

    大家好,在我们通常的android project中,通常需要用到textview这一个布局文件,并且对于这一个显示布局所需要的文本文字内容. 下面我们就来介绍一种方法来实现在android中用跑马灯 ...

  4. #Deep Learning回顾#之基于深度学习的目标检测(阅读小结)

    原文链接:https://www.52ml.net/20287.html 这篇博文主要讲了深度学习在目标检测中的发展. 博文首先介绍了传统的目标检测算法过程: 传统的目标检测一般使用滑动窗口的框架,主 ...

  5. UVA 1149 Bin Packing

    传送门 A set of n 1-dimensional items have to be packed in identical bins. All bins have exactly the sa ...

  6. uniq DEMO

    测试数据: [weblogic@etp-mall-dev7][/tmp]$ cat msn.txt aaa bbb bbb ccc ccc ddd bbb eee aaa ccc bbb sss op ...

  7. java前端选择

    在做web开发的时候难免遇到一个问题,那就是,选择什么样的框架.下面把前端的框架简单的列一下. 1.flex Apache基金会今天发布了Flex 4.8版本,这是Adobe将Flex捐献给Apach ...

  8. Python的数据处理学习(二)

    本文参考Paul Barry所著的<Head First Python>一书,参考代码均可由http://python.itcarlow.ie/站点下载.本文若有任何谬误希望不吝赐教~ 二 ...

  9. 架设证书服务器 及 让IIS启用HTTPS服务

    一.架设证书服务器(CA服务)1.在系统控制面板中,找到“添加/删除程序”,点击左侧的“添加/删除windows组件”,在列表中找到“证书服务”,安装之.2.CA类型,这里有四种选择,这里以“独立根C ...

  10. 小白日记25:kali渗透测试之提权(五)--利用配置不当提权

    利用配置不当提权 与漏洞提权相比,更常见的方法.在大部分企业环境下,会有相应的补丁更新策略,因此难以通过相应漏洞进行入侵.当入侵一台服务器后,无法照当相应的补丁进行提权,可通过寻找是否存在配置不当进行 ...