EF批量插入数据(Z.EntityFramework.Extensions)

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.运行效果

 

转载于:https://www.cnblogs.com/lgxlsm/p/7844833.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值