ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

EF批量操作数据之EntityFramework.Extended

2021-05-17 20:30:39  阅读:284  来源: 互联网

标签:Extended 批量 EF DateTime EntityFramework LogData Numeber1 context new


EF批量操作数据之EntityFramework.Extended

一、安装EntityFramework.Extended(环境为VS2019)

(1)

 

(2)

 

 

(3)

 

(4)

 

 安装成功

 

 

二 、使用实例

1.首先引用命名空间

    using EntityFramework.Extensions;

2.批量添加 数据 AddRange()发放,EF自带改方法

TestOne _context = new DBA.TestOne();
DateTime start = DateTime.Now;
for (int i = 0; i < 10000; i++)
{
    _context.Numeber1.Add(new Numeber1()
    {
        Num1 = i
    });
    _context.SaveChanges();
}
Console.WriteLine(_context.Numeber1.Count());
Console.WriteLine("总时长秒数:" + (DateTime.Now - start).TotalSeconds); //调试状态下 500多秒,非调试状态下 280秒

//批量新增
List<Numeber1> list = new List<Numeber1>();
for (int i = 0; i < 10000; i++)
{
    list.Add(new Numeber1()
    {
        Num1 = i
    });
}
_context.Numeber1.AddRange(list);
_context.SaveChanges();
Console.WriteLine("总时长秒数:" + (DateTime.Now - start).TotalSeconds); //批量添加9秒钟


3.批量更新 

//data为修改的行数
int   data =context.LogData.Where(a=>a.EntityKey=="aa").Update(b=> new LogData { EntityName = "ss" });
//第二种写法,这种是针对DbSet的,已经标注过时了
 var data = context.LogData.Update(a => a.EntityKey == "aa",b=> new LogData { EntityName = "ss" });
//批量更新
TestOne _context = new DBA.TestOne();
DateTime start = DateTime.Now;
int count = _context.Numeber1.Where(q => q.ID > 10000).Update(q => new Numeber1()
{
    Num1 = q.Num1 * 1000
});
_context.SaveChanges();
Console.WriteLine("总共更新数据:" + count);
Console.WriteLine("总时长秒数:" + (DateTime.Now - start).TotalSeconds); //批量更新:1秒多时间

4.批量 删除

//记得引用
using EntityFramework.Extensions;
//这两种写法都可以,Context是你的EF上下文对象.
context.LogData.Delete(a => a.EntityKey == "aa");
context.LogData.Where(a => a.EntityKey == "aa").Delete();
//批量删除操作
TestOne _context = new DBA.TestOne();
DateTime start = DateTime.Now;
int count = _context.Numeber1.Where(q => q.ID <= 30000).Delete();
_context.SaveChanges();
Console.WriteLine("总共删除数据:" + count);
Console.WriteLine("总时长秒数:" + (DateTime.Now - start).TotalSeconds); //批量删除:1秒左右时间


5.批量查询  

   var count =context.LogData.FutureCount();
                    var data = context.LogData.FutureFirstOrDefault(); 
                    var datalist = context.LogData.Future();
                    //在同一个代码上下文中,count,data,datalist这三个对象
                    //任意一个,第一次tolist或者.Value的时候,会连接一次数据库
                    //同时查询这三个数据,而不会分三次查询
                    var datalists = datalist.ToList();
                    int countdata = count.Value;  


6.查询缓存 

//使用默认的缓存时间
var tasks = db.Tasks
    .Where(t => t.CompleteDate == null)
    .FromCache();

//查询结果缓存300秒
var tasks = db.Tasks
    .Where(t => t.AssignedId == myUserId && t.CompleteDate == null)
    .FromCache(CachePolicy.WithDurationExpiration(TimeSpan.FromSeconds(300)));

标签:Extended,批量,EF,DateTime,EntityFramework,LogData,Numeber1,context,new
来源: https://blog.csdn.net/QYUANC/article/details/116947484

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有