• c# 使用SqlBulkCopy 提高大数据插入数据库速度


    自己得一点总结:
      1.BulkCopy采用的是插入方式,不是覆盖方式(原数据不动,在原数据的后面复制上dataTable中的内容)
      2.自增的字段不用赋值
      3.数据库字段名和dataTable列名可以不一样,对应关系用bulkcopy.ColumnMappings.Add("author", "author"); 关联
    public void SaveTable(DataTable dtTable)
            {
                SqlBulkCopy sbc = new SqlBulkCopy(DbHelperSQL.connectionString, SqlBulkCopyOptions.UseInternalTransaction);
                sbc.BulkCopyTimeout = 5000;
                try
                {                
                    sbc.DestinationTableName = "FAST_Temp";
                    sbc.WriteToServer(dtTable);
                }
                catch (Exception ex)
                {
                    //处理异常
                }
                finally
                {
                    //sqlcmd.Clone();
                    //srcConnection.Close();
                    //desConnection.Close();
                }
            }

    另外拓展一下SqlBulkCopyOptions枚举

     成员名称说明
      AllowEncryptedValueModifications

    允许加密值修改。

      CheckConstraints

    在插入数据的同时检查约束。 默认情况下,不检查约束。

      Default

    使用所有选项的默认值。

      FireTriggers

    如果指定,则使服务器激发插入触发器,从而使行插入数据库。

      KeepIdentity

    保留源标识值。 未指定标识值时,该值由目标指派。

      KeepNulls

    在目标表中保留 null 值,而不考虑默认值的设置。 如果未指定,由默认值替换 null 值(适用时)。

      TableLock

    获取批量复制操作持续时间的批量更新锁定。 如果未指定,则使用行锁定。

      UseInternalTransaction

    如果指定,批量复制操作的每一批都将在事务内发生。 如果指示该选项,并且还向构造函数提供SqlTransaction 对象,则发生 ArgumentException

  • 相关阅读:
    Django 06. django框架模型之表关系ForeignKey,ManyToManyField与OneToOneField
    Django 05. django框架模型之models常用字段、属性及异常处理
    Django 04. django框架模型之生成数据表
    Django 03. django框架之路由系统
    Django 02. Django框架之基础
    Django 01. python Web 框架
    Python 操作 MySQL
    MySQL 常见数据类型
    MySQL 命令整理2
    MySQL 命令整理1
  • 原文地址:https://www.cnblogs.com/dansediao/p/5482467.html
Copyright © 2020-2023  润新知