EF 批量添加数据
原文:https://www.cnblogs.com/liuruitao/p/10049191.html
原文:https://www.cnblogs.com/yaopengfei/p/7751545.html
环境:
就只安装了两个包,除此之外无其它任何配置,
EntityFramework、Z.EntityFramework.Extensions
一个简单的测试:
- using System;
- using System.Collections.Generic;
- using System.Data.Entity;
- namespace ConsoleApp2
- {
- class Program
- {
- static void Main(string[] args)
- {
- using (var db = new BlogEntities())
- {
- //添加一条数据
- //Blog entity = new Blog();
- //entity.BlogId = 1;
- //entity.Title = "title1";
- //entity.CreateDate = DateTime.Now;
- //db.Blogs.Add(entity);
- //db.SaveChanges();
- //查看 添加的数据 和 数据库链接地址
- //int i = db.Blogs.ToList().Count;
- //var d = db.Blogs.FirstOrDefault();
- //var str = db.Database.Connection.ConnectionString;
- int total = ;
- //测试1
- DateTime dt1 = DateTime.Now;
- for (int i = ; i < total; i++)
- {
- Blog entity = new Blog();
- entity.BlogId = ;
- entity.Title = "title" + i.ToString();
- entity.CreateDate = DateTime.Now;
- db.Blogs.Add(entity);
- db.SaveChanges();
- }
- Console.WriteLine("不批量插入1:" + (DateTime.Now - dt1).TotalMilliseconds);
- //测试2 和测试1的区别 在于 db.SaveChanges(); 的位置
- DateTime dt2 = DateTime.Now;
- for (int i = ; i < total; i++)
- {
- Blog entity = new Blog();
- entity.BlogId = ;
- entity.Title = "title" + i.ToString();
- entity.CreateDate = DateTime.Now;
- db.Blogs.Add(entity);
- }
- db.SaveChanges();
- Console.WriteLine("不批量插入2:" + (DateTime.Now - dt2).TotalMilliseconds);
- //测试3 需要引入Z.EntityFramework.Extensions 批量插入
- DateTime dt3 = DateTime.Now;
- List<Blog> list = new List<Blog>();
- for (int i = ; i < total; i++)
- {
- Blog entity = new Blog();
- entity.BlogId = ;
- entity.Title = "title" + i.ToString();
- entity.CreateDate = DateTime.Now;
- list.Add(entity);
- }
- db.BulkInsert(list);
- db.SaveChanges();
- Console.WriteLine("批量插入:" + (DateTime.Now - dt3).TotalMilliseconds);
- Console.ReadKey();
- }
- }
- }
- public class Blog
- {
- public int BlogId { get; set; }
- public string Title { get; set; }
- public DateTime CreateDate { get; set; }
- }
- public class BlogEntities : DbContext
- {
- public DbSet<Blog> Blogs { get; set; }
- }
- }
EF 批量添加数据的更多相关文章
- EF批量添加数据性能慢的问题的解决方案
//EF批量添加数据性能慢的问题的解决方案 public ActionResult BatchAdd() { using (var db = new ToneRoad.CEA.DbContext.Db ...
- EF批量添加数据之修改SQL Server执行上限
asp.net core 项目 打开Startup.cs services.AddDbContext<MyContext>( options => { options.UseSqlS ...
- .Net中批量添加数据的几种实现方法比较
在.Net中经常会遇到批量添加数据,如将Excel中的数据导入数据库,直接在DataGridView控件中添加数据再保存到数据库等等. 方法一:一条一条循环添加 通常我们的第一反应是采用for或for ...
- ThinkPHP批量添加数据和getField()示例
批量添加数据 // 批量添加数据 $User = M('users'); $dataList[] = array('name'=>'thinkphp','email'=>'thinkphp ...
- thinkphp3.2 批量添加数据
这是我遇到的thinkphp3.2 当中最让我无语的坑 批量添加数据有个方法是 addAll() 这个方法一定要注意数组的键名,一定要整齐!!! 可以在存入数据前,用ksort()方法将数组的键名排序 ...
- spring boot之使用通用Mapper批量添加数据
通用Mapper是一款针对mybatis进行扩展的轻量级组件,使用起来非常方便.当调用其针对mysql进行批量添加数据的方法时,发现报错,仔细研究了一番,发现是在使用通用Mapper上出现了问题.下面 ...
- Yii2如何批量添加数据
批量添加这个操作,在实际开发中经常用得到,今天小编抽空给大家整理些有关yii2批量添加的问题,感兴趣的朋友一起看看吧. 在上篇文章给大家介绍了关于浅析Yii2 gridview实现批量删除教程,当然, ...
- ADO.NET- 中批量添加数据的几种实现方法比较
在.Net中经常会遇到批量添加数据,如将Excel中的数据导入数据库,直接在DataGridView控件中添加数据再保存到数据库等等. 方法一:一条一条循环添加 通常我们的第一反应是采用for或for ...
- 使用EF批量新增数据十分缓慢
使用EF来批量新增数据,发现效率非常的差,几千条数据时甚至需要几分钟来执行,迫于无奈使用sql来执行了. 今天偶然看到一篇关于EF的文章,才发觉原来是自己对EF不够了解的原因. 一般新增时我们是将所有 ...
随机推荐
- 12306火车票余票查询&Python实现邮件发送
查询余票接口 打开12306官网,并进入余票查询页面,同时开启chrome浏览器F12控制台,以北京到上海为例,搜索2018年10月1日的余票信息,点击搜索按钮,可以在控制台发送了一条GET请求,请求 ...
- drf-更新四大接口-单改整体-单改局部-群改整体-群改局部-04
目录 复习 基于前一天序列化基础 整体单改 单与整体局部修改 复习 """ 1.ModelSerializer序列化类 models.py class BaseModel ...
- CNN网络结点计算总结(1998)
图 来源:Gradient-Based Learning Applied to Document Recognition 参阅CSDN:https://blog.csdn.net/dcxhun3/ar ...
- Tomcat中的Host和Engine级别的servlet容器
这边文章主要介绍的是Host容器 和 Engine容器.如果你想在同一个Tomcat上部署运行多个Context容器的话,你就需要使用Host容器,从理论上来讲,如果你的Tomcat只想要部署一个Co ...
- 缓存策略:redis缓存之springCache
最近通过同学,突然知道服务器的缓存有很多猫腻,这里通过网上查询其他人的资料,进行记录: 缓存策略 比较简单的缓存策略: 1.失效:应用程序先从cache取数据,没有得到,则从数据库中取数据,成功后,放 ...
- MySQL mysql-5.7.21-winx64.zip安装指南
一.下载mysql-5.7.21-winx64.zip压缩包 二.解压 1.在目录mysql-5.7.21-winx64下新建data文件夹 !!!如果已经存在data文件夹,请删除其中ib_logf ...
- docker 网络模式详解
一.前言 Docker作为目前最火的轻量级容器技术,有很多令人称道的功能,如Docker的镜像管理.然而,Docker同样有着很多不完善的地方,网络方面就是Docker比较薄弱的部分.因此,我们有必要 ...
- 使用HandyJSON导致的内存泄漏问题相关解决方法
在移动开发中,与服务器打交道是不可避免的,从服务器拿到的接口数据最终都会被我们解析成模型,现在比较常见的数据传输格式是json格式,对json格式的解析可以使用原生的解析方式,也可以使用第三方的,我们 ...
- JavaWeb【Servlet】
概念 Servlet是在服务器上运行的小程序.一个Servlet请求对应一个Java类(对应一个Wrapper容器),可以通过请求-响应模式访问这个驻留在内存中的小程序. Tomcat容器等级 上图表 ...
- Redis+Sentinel安装与配置
在这里我们搭建的是一个1主3从的redis+3个哨兵集群的环境,由于是在一台物理机上,所有我们用端口区分. 物理机IP:192.168.0.12 主节点master端口:6301 从节点slave1端 ...