zoukankan      html  css  js  c++  java
  • 关于SqlBulkCopy SQL批量导入需要注意,列名是区分大小写的

    最近在做数据从Excel批量导入MSSQL时,传统的是使用Insert Into Table方法,不过这个方便比较慢

    通过使用 SqlBulkCopy 可以批量导入到数据库。

    默认批量导入数据库,需要DataTable的构架和MSSQL的表结构一样。但是使用ColumnMappings可以对列明进行映射。

    例如

    List<string[]> list = new List<string[]>();
    
    list.Add(new string[] { "staffid", "员工ID" });
    
    list.Add(new string[] { "StaffCode", "员工号" });
    list.Add(new string[] { "displayname", "中文姓名" });
    list.Add(new string[] { "username", "登录名" });
    
    using (SqlBulkCopy sqlRevdBulkCopy = new SqlBulkCopy(ConStr, SqlBulkCopyOptions.KeepIdentity))//引用SqlBulkCopy
    {
    sqlRevdBulkCopy.DestinationTableName = strTableName;//数据库中对应的表名
    
    for (int i = 0; i < list.Count; i++)
    {
    sqlRevdBulkCopy.ColumnMappings.Add(list[i][1], list[i][0]);
    }
    
    sqlRevdBulkCopy.WriteToServer(dtData);//数据导入数据库
    
    sqlRevdBulkCopy.Close();//关闭连接
    }
    

      其中有两点需要注意:

    (1)SqlBulkCopyOptions.KeepIdentity 这个参数允许自增型主键导入

    (2)表的列名是区分大小写的。这点非常重要。笔者就是花了2-3个小时解决这个问题。

    因此程序运行,总是提示列名不匹配,后来仔细查看数据库一列是qq,但是在映射里写成了QQ。传统的我们认为MSSQL的SQL是不区分大小写的(SQL_PRC_CI_AS排序)

    但是,没想到批量导入竟然列名区分大小写。

  • 相关阅读:
    ASP.NET服务器控件开发(4)复合控件
    C#特性对象集合初始化器
    C#特性匿名类型与隐式类型局部变量
    在Handler中使用Session
    使用 UDPClient 生成聊天客户端
    当下10大最热门的网站开发技术
    C#特性扩展方法
    50个非常有用的PHP工具
    c# 调用.bat文件
    c# 特性/属性(Attribute) 以及使用反射查看自定义特性
  • 原文地址:https://www.cnblogs.com/mqingqing123/p/4664250.html
Copyright © 2011-2022 走看看