草庐IT

c# - Entity Framework VS 纯 Ado.Net

coder 2023-07-10 原文

EF 是一个被广泛使用的人员,但我不知道我应该如何使用它。我在使用不同方法的不同项目中遇到了很多关于 EF 的问题。所以我脑子里汇集了一些问题。答案让我使用带有存储过程的纯 ado.net。

所以问题是:

  1. n层应用如何处理EF?
    例如,我们有一些带有 EF 的 DAL。我看到很多文章和项目使用存储库、工作单元模式作为 EF 的某种抽象。我认为这种方法扼杀了提高开发速度的大部分好处,并导致了一些事情:

    • EF 负载的重新映射导致某些 DTO 会降低性能(调用一些选择以获取表数据 - 第一个循环,第二个循环 - 将结果映射到由 ef 生成的某些复合类型,接下来 - 使用 linq 过滤映射数据,最后,将其映射到某个 DTO)。准确地重新映射到 DTO 是最大的 efs 好处之一的 killer ;
    • 导致 EF(及其版本)和应用程序之间的强大凝聚力。它将类似于带有 dal 和带有 bll 的演示文稿或带有 bll 和演示文稿的 dal 的 2 层应用程序。我想这不是最佳做法。除了映射之外,加载过程与之前的加载过程相同,因此性能问题再次出现。我们可以尝试将 EF 用作 DAL,而无需在它们下进行任何抽象。但是我们会以其他方式遇到类似的问题。
  2. 我应该为每个应用\线程\原子操作使用一个上下文吗?使用方法 - 每个应用程序\线程一个上下文可能会略微提高性能和调用导航属性的可能性,但我们遇到另一个问题 - 更新此上下文并在上下文中增加加载的数据,我也不确定每个应用程序一个 dbcontext 的并发性\线。每个操作使用上下文将引导我们将 EF 结果重新映射到我们的 DTO。所以你看到我们再次推回问题 1。

  3. 我们能否尝试仅使用 EF + 存储过程?我们再次遇到以前问题的问题。如果不会使用大部分功能,使用 EF 的原因是什么?

所以,是的,EF 非常适合启动项目。当我们只有很少的屏幕和粗略的操作时,它非常方便。

但是接下来呢?

所有这些文字只是未分类的想法。我知道纯粹的 ado.net 会带来另一种挑战。

那么,你对这个话题有什么看法?

最佳答案

按照命名约定,您会发现它叫做:ADO.NET Entity Framework,这意味着 Entity Framework 位于 ADO.NET 之上,所以它不能更快​​,它可能同时执行两者,但是让我们看看 EF 提供的:

  • 您将不会再被编写查询所困,而不知道您所编写的内容是否会被编译。
  • 它让您依赖 C# 或您最喜欢的 .NET 语言来编写您自己的数据约束,您希望直接在您的模型类中接受来自目标用户的数据约束。

最后:EF 和 LINQ 为以后维护您的应用程序提供了强大的功能。

Entity Framework 有三种不同的模型:模型优先、数据库优先和代码优先,了解它们中的每一个。

-关于在进程上进行重新映射时会降低性能的要点,这是因为在第一次运行时,EF 将元数据加载到内存中,这需要时间,因为它从 edmx 文件构建模型的内存中表示。

关于c# - Entity Framework VS 纯 Ado.Net,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22328889/

有关c# - Entity Framework VS 纯 Ado.Net的更多相关文章

  1. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  2. ruby - 如何模拟 Net::HTTP::Post? - 2

    是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou

  3. c# - 如何在 ruby​​ 中调用 C# dll? - 2

    如何在ruby​​中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL

  4. C# 到 Ruby sha1 base64 编码 - 2

    我正在尝试在Ruby中复制Convert.ToBase64String()行为。这是我的C#代码:varsha1=newSHA1CryptoServiceProvider();varpasswordBytes=Encoding.UTF8.GetBytes("password");varpasswordHash=sha1.ComputeHash(passwordBytes);returnConvert.ToBase64String(passwordHash);//returns"W6ph5Mm5Pz8GgiULbPgzG37mj9g="当我在Ruby中尝试同样的事情时,我得到了相同sha

  5. ruby - Net::HTTP 获取源代码和状态 - 2

    我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur

  6. 基于C#实现简易绘图工具【100010177】 - 2

    C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.

  7. Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting - 2

    1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里

  8. .net - .NET 将如何影响 Python 和 Ruby 应用程序? - 2

    我很好奇.NET将如何影响Python和Ruby应用程序。用IronPython/IronRuby编写的应用程序是否会非常特定于.NET环境,以至于它们实际上将变得特定于平台?如果他们不使用任何.NET功能,那么IronPython/IronRuby相对于非.NET同类产品的优势是什么? 最佳答案 我不能说任何关于IronRuby的东西,但是大多数Python实现(如IronPython、Jython和PyPy)都试图尽可能忠实于CPython实现。不过,IronPython正在迅速成为这方面的佼佼者之一,并且在PlanetPyth

  9. ruby - 如何使用 Ruby HTTP::Net 处理 404 错误? - 2

    我正在尝试解析网页,但有时会收到404错误。这是我用来获取网页的代码:result=Net::HTTP::getURI.parse(URI.escape(url))如何测试result是否为404错误代码? 最佳答案 像这样重写你的代码:uri=URI.parse(url)result=Net::HTTP.start(uri.host,uri.port){|http|http.get(uri.path)}putsresult.codeputsresult.body这将打印状态码和正文。

  10. .net - 是否有 Ruby .NET 编译器? - 2

    是否有适用于Ruby语言的.NETFramework编译器?我听说过DLR(动态语言运行时),这是否将使Ruby能够用于.NET开发? 最佳答案 IronRuby是Microsoft支持的项目,建立在动态语言运行时之上。 关于.net-是否有Ruby.NET编译器?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/199638/

随机推荐