【C#--数据】1.使用SqlBulkCopy批量导入数据库的示例

这篇博客展示了如何使用C#的SqlBulkCopy类批量导入数据到数据库。首先创建了包含ID和UserID列的示例DataTable,然后通过建立数据库连接,实例化SqlBulkCopy对象,设置目标表名和导入数据量,最后执行导入并计算执行时间。此方法适用于大量数据的高效导入。
摘要由CSDN通过智能技术生成

使用SqlBulkCopy批量导入数据库的示例

VS建立控制台应用(.NET Framework)项目(SqlBurkCopyDemo),代码如下:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace SqlBurkCopyDemo
{
    public class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("正在插入测试数据");
            TimeSpan span = new TimeSpan();
            try
            {
                //Copy copy = new Copy();
                //span = copy.InsertData();
                span = InsertData();
            }
            catch (Exception ex)
            {
                Console.WriteLine("异常!");
            }
            Console.WriteLine("共花费时间" + span.ToString() + "秒");
            Console.ReadLine();
        }

        public static 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要避免在使用 SqlBulkCopy 导入 Excel 数据SQL 数据库时插入重复数据,可以使用以下步骤: 1. 读取 Excel 文件并将其转换为 DataTable 对象。 ``` using (var package = new ExcelPackage(file)) { ExcelWorksheet worksheet = package.Workbook.Worksheets[0]; DataTable table = new DataTable(); foreach (var firstRowCell in worksheet.Cells[1, 1, 1, worksheet.Dimension.End.Column]) { table.Columns.Add(firstRowCell.Text); } for (var rowNumber = 2; rowNumber <= worksheet.Dimension.End.Row; rowNumber++) { var row = worksheet.Cells[rowNumber, 1, rowNumber, worksheet.Dimension.End.Column]; var newRow = table.Rows.Add(); foreach (var cell in row) { newRow[cell.Start.Column - 1] = cell.Value; } } } ``` 2. 在创建 SqlBulkCopy 对象时,将 KeepIdentity 和 CheckConstraints 选项设置为 true。 ``` SqlBulkCopy bulkCopy = new SqlBulkCopy(connection, SqlBulkCopyOptions.KeepIdentity | SqlBulkCopyOptions.CheckConstraints, null); ``` 3. 在将数据源的列映射到目标表的列时,使用 ColumnMappings 属性,并设置 SourceColumn 和 DestinationColumn 属性。 ``` bulkCopy.ColumnMappings.Add("sourceColumn", "destinationColumn"); ``` 4. 在调用 WriteToServer 方法之前,使用 SqlBulkCopy 类的 BatchSize 属性设置每批次传输的行数。 ``` bulkCopy.BatchSize = 1000; ``` 5. 在写入目标表之前,遍历 DataTable 对象中的每行数据,检查是否存在重复数据。 ``` foreach (DataRow row in table.Rows) { // 判断是否存在重复数据 if (!IsDuplicateData(connection, row)) { bulkCopy.WriteToServer(row); } } private bool IsDuplicateData(SqlConnection connection, DataRow row) { // 查询目标表是否已经存在该行数据 // 如果存在,返回 true,否则返回 false return false; } ``` 这样做可以避免插入重复数据,因为在写入目标表之前,会检查是否存在重复数据,如果存在,则不会写入该行数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值