1. 程式人生 > >EF批量插入數據(Z.EntityFramework.Extensions)

EF批量插入數據(Z.EntityFramework.Extensions)

con log amp example 效果 nds ati stat spa

EF用原生的插入數據方法DbSet.ADD()和 DbSet.AddRange()都很慢。所以要做大型的批量插入只能另選它法。

1.Nugget

技術分享

2.代碼

using EF6._0Test.EF;
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;

namespace EF6._0Test
{
    class Program
    {
        static void Main(string[] args)
        {
            
using (Jason_TestEntities db = new Jason_TestEntities()) { List<wolf_example> list = new List<wolf_example>(); for (int i = 0; i < 50000; i++) { list.Add(new wolf_example() { type
= i, Name = "Name" + i.ToString(), Money = i, CTime = DateTime.Now, UserID = i, Remak = "Remak" + i.ToString(), Sex = i, IsShow
= true, }); } Stopwatch watch = Stopwatch.StartNew(); db.BulkInsert(list); db.BulkSaveChanges(); watch.Stop(); Console.WriteLine(string.Format("{0} 條數據, 用時 {1} milliseconds.", list.Count(), watch.ElapsedMilliseconds)); Console.ReadLine(); } } } }

3.運行效果

技術分享

EF批量插入數據(Z.EntityFramework.Extensions)