首页 > 其他分享 >如何使用 EF Core 7 批量删除数据

如何使用 EF Core 7 批量删除数据

时间:2022-12-22 09:11:33浏览次数:39  
标签:Core await 批量 删除 EF db new

在 EF Core 7 中,我们可以使用批量操作来删除多条数据。这种方式与之前的版本有所不同,本文将对比 EFCore 7 和之前版本批量删除数据的不同方式。

删除给定 ID 的数据

在 EF Core 7 中,我们可以使用以下代码来删除给定 ID 的数据:

await using var db = new MyContext();
await db.MyEntities.Where(static x => x.Id == 1).ExecuteDeleteAsync();

在之前的版本中,我们可以使用以下代码来删除给定 ID 的数据:

await using var db = new MyDbContext();
// delete id == 1 by attaching it to the context
var myEntity = new MyEntity
{
    Id = 1
};
db.Attach(myEntity);
db.Remove(myEntity);
await db.SaveChangesAsync();

删除 Age 大于 10 的数据

在 EF Core 7 中,我们可以使用以下代码来删除 Age 大于 10 的数据:

await using var db = new MyDbContext();
await db.MyEntities.Where(static x => x.Age > 10).ExecuteDeleteAsync();

在之前的版本中,我们可以使用以下代码来删除 Age 大于 10 的数据:

await using var db = new MyDbContext();
// delete age > 10 
var entities = db.MyEntities.Where(static x => x.Age > 10).ToList();
db.MyEntities.RemoveRange(entities);
await db.SaveChangesAsync();

总结

在 EF Core 7 中,我们可以使用 ExecuteDeleteAsync 方法来批量删除数据,这个方法的用法与之前的版本不同。使用这种方法,我们可以方便地在数据库中删除多条数据,提升了删除数据的效率。

参考资料

  • EF Core 7 ExecuteUpdate 和 ExecuteDelete[1]

本文采用 Chat OpenAI 辅助注水浇筑而成,如有雷同,完全有可能。

  • 本文作者: newbe36524
  • 本文链接: https://www.newbe.pro/ChatAI/How-to-batch-delete-data-by-efcore-7/
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!

参考资料

[1]

EF Core 7 ExecuteUpdate 和 ExecuteDelete: https://learn.microsoft.com/ef/core/what-is-new/ef-core-7.0/whatsnew?source=recommendations&WT.mc_id=DX-MVP-5003606#executeupdate-and-executedelete-bulk-updates

标签:Core,await,批量,删除,EF,db,new
From: https://www.cnblogs.com/newbe36524/p/16989662.html

相关文章

  • define宏定义
     #define命令是C语言中的一个宏定义命令,它用来将一个标识符定义为一个字符串,该标识符被称为宏名,被定义的字符串称为被替换文本。 该命令有两种格式:一种是简......
  • Codeforces Round #785 (Div. 2) A-C
    ProblemA题意问给一个长度为2的小写字符串,字符串从ab开始,然后第一个位置和第二个位置上的字符不能相等,问按照这个方式排序,给出的字符串是第几个然后这道题首先分情况讨......
  • ifdef与ifndef的区别
    看:https://blog.csdn.net/ustczwc/article/details/9070941        ......
  • [LeetCode] 1753. Maximum Score From Removing Stones
    Youareplayingasolitairegamewith threepiles ofstonesofsizes a​​​​​​, b,​​​​​​and c​​​​​​respectively.Eachturnyouchoosetw......
  • Codeforces Round #840 (Div. 2)
    A题意:给定n个整数,可以交换任意两个数二进制上的某一位。求任意操作次数后数组中最大值与最小值的最大差。核心思路:这个思路还是很显然的大胆的猜结论,贪心的考虑每一个......
  • Spring IOC源码(四):IOC容器之 beanDefinition解析
    1、源码解析配置文件的bean定义解析在obtainFreshBeanFactory()方法中完成的,核心解析是在DefaultBeanDefinitionDocumentReader的parseBeanDefinitions()方法中完成。......
  • .Net Core 三个常用的生命周期(transient/scope/singleton)
    1、单例(AddSingleton:注入一次,一直有效)区别:服务在第一次请求时被创建,后边再次请求都会沿用这个已创建的服务。2、作用域(AddScoped:在一定的区域内有效)区别:服......
  • 回流(Reflow)与重绘(Repaint)
    哪些实际操作会导致回流与重绘最“贵”的操作:改变DOM元素的几何属性这个改变几乎可以说是“牵一发动全身”——当一个DOM元素的几何属性发生变化时,所有和它相关的节......
  • error LNK2005 xxxx already defined in LIBCMT.lib
    uafxcw.lib(afxmem.obj):errorLNK2005:"void*__cdecloperatornew(unsignedint)"(??2@YAPAXI@Z)alreadydefinedinLIBCMT.lib(new_scalar.obj)查看冲突:在项......
  • JDK源码之CompletableFuture(三)anyOf,allOf是怎么实现的?
    ​​JDK源码之CompletableFuture(一)结果返回原理​​JDK源码之CompletableFuture(二)链式调用原理JDK源码之CompletableFuture(三)anyOf,allOf是怎么实现的?目录​​一、全部返回......