sqlserver數據庫批量插入-SqlBulkCopy

當想在數據庫中插入大量數據時,使用insert 不只效率低,並且會致使一系列的數據庫性能問題html

當使用insert語句進行插入數據時。我使用了兩種方式:sql

  1. 每次插入數據時,都只插入一條數據庫,這個會致使每次插入數據時不斷打開關閉數據庫連接,致使效率太低(最差)
  2. 使用拼接字符串的方式來進行批量插入數據,可是使用StringBuilder 會佔用極大的內存

以上方式對於批量插入數據都不是一個好的選擇, 針對這種狀況我使用了SqlBulkCopy數據庫

sqlbulkCopy:將其它數據源批量加載sqlserver表,就是能夠將其它數據源插入到數據庫中ide

示例代碼:sqlserver

建立測試User表:性能

1 CREATE TABLE [dbo].[Users](
2     [Id] [uniqueidentifier] NOT NULL,
3     [Name] [nvarchar](100) NULL,
4     [Gender] [int] NULL,
5     [Age] [int] NULL,
6     [CityId] [int] NULL,
7     [OpTime] [datetime] NULL,
8     CONSTRAINT [PK_Users] PRIMARY KEY CLUSTERED([Id] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
9  ) ON [PRIMARY]

而後定義一個與表映射的Model,因SqlBulkCopy 的特性,定義的 Model 必須擁有與表全部的字段對應的屬性:也就是定義的model,須要跟數據表的字段順序同樣,由於轉爲datatable時會按照順序插入測試

 1 public enum Gender
 2 {
 3     Man = 1,
 4     Woman
 5 }
 6 
 7 public class User
 8 {
 9     public Guid Id { get; set; }
10     public string Name { get; set; }
11     public Gender? Gender { get; set; }
12     public int? Age { get; set; }
13     public int? CityId { get; set; }
14     public DateTime? OpTime { get; set; }
15 }

製造些數據轉爲DataTable:ui

List轉爲DataTable地址:http://www.javashuo.com/article/p-setqvvkx-bv.htmlspa

 1 List<User> usersToInsert = new List<User>();
 2 usersToInsert.Add(new User() { Id = Guid.NewGuid(), Name = "so1", Gender = Gender.Man, Age = 18, CityId = 1, OpTime = DateTime.Now });
 3 usersToInsert.Add(new User() { Id = Guid.NewGuid(), Name = "so2", Gender = Gender.Man, Age = 19, CityId = 2, OpTime = DateTime.Now });
 4 usersToInsert.Add(new User() { Id = Guid.NewGuid(), Name = "so3", Gender = Gender.Man, Age = 20, CityId = 3, OpTime = DateTime.Now });
 5 usersToInsert.Add(new User() { Id = Guid.NewGuid(), Name = "so4", Gender = Gender.Man, Age = 21, CityId = 4, OpTime = DateTime.Now });
 6 
 7 var data = DataTableExtensions.ToDataTable(usersToInsert);
 8  using (SqlBulkCopy bulkCopy = new SqlBulkCopy(ConnectionString))
 9                 {
10                     bulkCopy.DestinationTableName =
11                         "Users";
12                     try
13                     {
14                         bulkCopy.WriteToServer(data, DataRowState.Added);
15                     }
16                     catch (Exception ex)
17                     {
18                         Console.WriteLine(ex.Message);
19                     }
20                 }
相關文章
相關標籤/搜索