NET问答: Entity Framework 如何快速高效的删除表中所有记录 ?

咨询区

  • Zhenia

在 Entity Framework 中,如何快速高效的删除表中的所有行?

我目前是这样写的。


var rows = from o in dataDb.Tableselect o;
foreach (var row in rows)
{dataDb.Table.Remove(row);
}dataDb.SaveChanges();

但这种做法,测试下来太耗费时间了,请问有什么更高效的做法吗?

回答区


  • Ahmed Alejo

警告:下面的做法仅适合那些小表操作 (?<1000)

这里我采用的是通过 EF 去删除表记录,而不是直接使用 sql,所以此种删除方式适合所有 EF 支持的  RDBM ,声明一下,如果你的表数据很小,或者你不在乎性能,可以简单如下调用。


VotingContext.Votes.RemoveRange(VotingContext.Votes);

为了让代码更干净简洁,可以专门定义一个 扩展方法


public static class EntityExtensions
{public static void Clear<T>(this DbSet<T> dbSet) where T : class{dbSet.RemoveRange(dbSet);}
}

接下来代码意图就明显了。


VotingContext.Votes.Clear();
VotingContext.Voters.Clear();
VotingContext.Candidacy.Clear();
VotingContext.Polls.Clear();
await VotingTestContext.SaveChangesAsync();

  • Rudi Visser

最快的方式当然是使用 SQL 的 TRUNCATE TABLE,它是直接针对表操作而不是单独的行。


dataDb.ExecuteStoreCommand("TRUNCATE TABLE [Table]");

如果你用的是 EFCore 3.1,可以使用下面的语句清空所有行。


context.Database.ExecuteSqlRaw("TRUNCATE TABLE [TableName]");

点评区

其实这是在 EF 操作中经常会遇到的一个问题,通常的做法也就上面这两种。

  • 想更加通用,不考虑性能,采用 EF 直接操作,生成的 sql 大概如下。

static void Main(string[] args){PYZ_LEntities entities = new PYZ_LEntities();entities.Database.Log = Console.WriteLine;entities.Color.RemoveRange(entities.Color);entities.SaveChanges();Console.ReadLine();}

监控到 sql:


Opened connection at 2021/4/5 22:09:12 +08:00SELECT[Extent1].[ID] AS [ID],[Extent1].[ColorName] AS [ColorName],[Extent1].[ColorCode] AS [ColorCode],[Extent1].[IsDelete] AS [IsDelete]FROM [dbo].[Color] AS [Extent1]-- Executing at 2021/4/5 22:09:12 +08:00-- Completed in 5 ms with result: SqlDataReaderClosed connection at 2021/4/5 22:09:12 +08:00Opened connection at 2021/4/5 22:09:12 +08:00Started transaction at 2021/4/5 22:09:12 +08:00DELETE [dbo].[Color]
WHERE ([ID] = @0)-- @0: '1' (Type = Int32)-- Executing at 2021/4/5 22:09:12 +08:00-- Completed in 1 ms with result: 1DELETE [dbo].[Color]
WHERE ([ID] = @0)-- @0: '2' (Type = Int32)-- Executing at 2021/4/5 22:09:12 +08:00-- Completed in 0 ms with result: 1DELETE [dbo].[Color]
WHERE ([ID] = @0)-- @0: '3' (Type = Int32)-- Executing at 2021/4/5 22:09:12 +08:00-- Completed in 0 ms with result: 1Committed transaction at 2021/4/5 22:09:12 +08:00Closed connection at 2021/4/5 22:09:12 +08:00

从输出信息看,清空操作采用的是将所有的sql拼在一个 Transaction 内,性能有所提升,不过确实只适合一些小表????????????

  • 想要定制化,性能优先,直接使用 sql

原文链接:https://stackoverflow.com/questions/15220411/entity-framework-delete-all-rows-in-table

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/303424.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 加减乘除是原子操作吗_聊聊原子操作那些事

原子操作&#xff0c;线程间交互数据最细粒度的同步操作&#xff0c;它可以保证线程间读写某个数值的原子性。由于不需要加重量级的互斥锁进行同步&#xff0c;因此非常轻量&#xff0c;而且也不需要在内核间来回切换调度&#xff0c;效率是非常高的。。那如何使用原子操作了&a…

有关技术管理的一些思考

这些天里工作的环境发生了一些微小的变化&#xff0c;可能以后对基层开发的程序员也会有更加具体的影响。上周参加 Open Party 时&#xff0c;重点听了《那些失败的项目们》&#xff0c;分析了一个项目的提出、实施&#xff0c;直到最后失败的过程。我也在想一个技术团队究竟应…

15个未来高科技产品会让你无法想象!这些开脑洞的设计太牛了!

导读&#xff1a;从衣食住行到生活的方方面面&#xff0c;未来必将会有天翻地覆的变化。大数据、云计算、物联网和人工智能这些年的发展&#xff0c;让我们对并不遥远的未来有了更多想象和期待。那些我们现阶段不可企及的所思所想&#xff0c;将在未来成为大部分人的日常。这么…

解决 .NET Core 在 Linux Container 中获取 CurrentCulture 不正确的问题

背景在将公司一款基于 .NET Framework 的控制台程序迁移到 .NET Core 3.1 时&#xff0c;发现程序中本地化的部分失效&#xff0c;症状类似于对 Thread.CurrentThread.CurrentCulture.Name 的值进行 Substring() 操作时抛出 ArgumentOutOfRangeException 异常。该程序在 Window…

Java程序设计当中包的使用_【学习笔记】 唐大仕—Java程序设计 第4讲 类、包和接口之4.2 类的继承...

【学习笔记】 唐大仕—Java程序设计 第4讲 类、包和接口之4.2 类的继承super的使用1.使用super访问父类的域和方法注意&#xff1a;正是由于继承&#xff0c;使用this可以访问父类的域和方法。但是有时为了明确指明父类的域和方法&#xff0c;就要用关键字super。this和super都…

机器学习资料升级版来了!!!

机器学习一直是一个热门的领域。上次分享的机器学习资料【资源】机器学习资料包来袭受到大家的广泛好评&#xff0c;今天小编打算分享一份机器学习升级版的资料&#xff0c;有斯坦福大学-深度学习基础教程、机器学习实战、人工智能与大数据、Tagging等。顺序最下优化算法Error …

java consumer 使用_java.util.function.Consumer的用法

Consumer类包含两个方法&#xff0c;一个accept方法用来对输入的参数进行自定义操作&#xff0c;因为是个抽象方法&#xff0c;所以需要实例化对象的时候进行Override&#xff0c;另一个andThen方法跟Function的方法一样是一个default方法&#xff0c;已经有内部实现所以不需要…

程序员从初级到中级10个秘诀

Justin James曾发表过一篇博文《10 tips for advancing from a beginner to an intermediate developer》&#xff0c;为我们分享如何才能完成程序员从初级到中级的蜕变&#xff0c;现将中文译文转载于此&#xff0c;供大家借鉴。 在一封与TechRepublic会员交流的邮件当中&…

C# 可空类型

C# 单问号 ? 与 双问号 ?? ? : 单问号用于对 int,double,bool 等无法直接赋值为 null 的数据类型进行 null 的赋值&#xff0c;意思是这个数据类型是 Nullable 类型的。int? i 3;等同于&#xff1a;Nullable<int> i new Nullable<int>(3); int i; //默认值0…

K-Means算法的10个有趣用例

K-means算法具有悠久的历史&#xff0c;并且也是最常用的聚类算法之一。K-means算法实施起来非常简单&#xff0c;因此&#xff0c;它非常适用于机器学习新手爱好者。首先我们来回顾K-Means算法的起源&#xff0c;然后介绍其较为典型的应用场景。起源1967年&#xff0c;James M…

计算数字的出现次数 java_关于Java:如何计算数字在.txt文件中出现的次数

早上好&#xff0c;我正在做一些Java练习&#xff0c;偶然发现了这个问题。 我有一个.txt文件&#xff0c;其中包含多个数字&#xff0c;每行一个。 练习的目的是查看哪些数字等于10 ^ 0&#xff0c;...&#xff0c;10 ^ n直到达到n。 然后&#xff0c;我必须在.txt中写入每个数…

Asp.net中的HttpModule和HttpHandler的简单用法

在Asp.net中&#xff0c;HttpModule和HttpHandler均可以截取IIS消息进行处理&#xff0c;这使得我们制作人员能够非常方便的进行诸如图片水印添加&#xff0c;图片盗链检查等功能。 下面先就HttpModule的使用方法进行简单说明&#xff1a; using System;using System.Web;names…

C# $的用法

今天闲来无事&#xff0c;就随便在网上乱看&#xff0c;突然想到Jquery的$符号很强大&#xff0c;那么C#有没有这个东西呢&#xff0c;一查&#xff0c;果然有。经查证发现&#xff0c;这个是在C#6.0出现的一个新特性&#xff0c;也就是一个小语法糖&#xff0c;其作用相当于对…

想转行人工智能?机会来了!!!

一个坏消息&#xff1a;2018年1月 教育部印发的《普通高中课程方案和语文等学科课程标准》新加入了数据结构、人工智能、开源硬件设计等 AI 相关的课程。这意味着职场新人和准备找工作的同学们&#xff0c;为了在今后十年内不被淘汰&#xff0c;你们要补课了&#xff0c;从初中…

tankwar java_TankWar 单机(JAVA版) 版本0.3 画出坦克

其实就是通过自定义的panel 重写里面的paint方法 使用Graphics类画一个圆然后把自定的panel添加到窗口中由于想到tank不能只画一个 所以我们封装一个tank类 里面有一个draw方法 用来画 坦克通过实例化tank 调用draw方法就能实现画tank了具体代码如下&#xff1a;Tank类pac…

轻量NuGet服务—BaGet

相信大家都受益过nuget.org&#xff0c;上面的海量的库、工具、模板为我们开发提供了极大的帮助&#xff0c;其中有很多都是非常宽松的开源协议&#xff0c;在此感谢那无私奉献的人。有的时候&#xff0c;在企业内部&#xff0c;有些库是私有的&#xff0c;专项的&#xff0c;要…

光驱读盘不正常

问&#xff1a;我的电脑安装的是Windows XP操作系统&#xff0c;安装好后出现了一个问题&#xff0c;就是不能连续读光盘&#xff0c;插入第一张光盘一切正常&#xff0c;打开光驱放入第二张光盘&#xff0c;发现里边的内容竟是第一张光盘的内容&#xff0c;重新启动机器后&…

在安卓上安装java_如何在Android上安装JavaCV并使用FrameGrabber

有人能告诉我我在哪里做错了吗&#xff1f;这些是我遵循的步骤&#xff1a;>从Android开发者网站下载了adt-bundle-windows>创建了一个新项目和一个libs / armeabi文件夹>将所有* .so文件从javacv-android-arm.jar,opencv-2.4.3-android-arm.zip和ffmpeg-1.0-android-…

使用 Github Actions artifact 在 workflow job 之间共享数据

AgileConfig 在使用 react 编写UI后&#xff0c;变成了一个彻彻底底的前后端分离的项目&#xff0c;上一次解决了把react spa 跟asp.net core 站点集成起来ASP.NET Core 集成 React SPA 应用。本来我每次提交代码的时候都需要手动运行npm run build,然后把dist的内容复制到asp…

撤回的微信消息真的看不到?78行Python代码帮你看穿一切!

导读&#xff1a;Python曾经对我说&#xff1a;"时日不多&#xff0c;赶紧用Python"。于是看到了一个基于python的微信开源库&#xff1a;itchat&#xff0c;玩了一天&#xff0c;做了一个程序&#xff0c;把私聊撤回的信息可以收集起来并发送到个人微信的文件传输助…