首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

EF与EF Core在保存相关实体上的比较

EF(Entity Framework)和EF Core(Entity Framework Core)是微软开发的两个.NET平台上的ORM(对象关系映射)框架。它们的主要功能是将数据库中的数据映射到应用程序中的对象,并提供了一套强大的API来进行数据库操作。

EF是Entity Framework的缩写,是.NET Framework上的ORM框架。它提供了一种简单的方式来操作数据库,开发人员可以使用面向对象的方式来进行数据库操作,而不需要编写复杂的SQL语句。EF支持多种数据库,包括SQL Server、MySQL、Oracle等,并且提供了丰富的功能,如数据查询、数据更新、事务处理等。

EF Core是Entity Framework Core的缩写,是.NET Core平台上的ORM框架。与EF相比,EF Core是一个轻量级的、跨平台的ORM框架,它在设计上更加灵活和可扩展。EF Core支持多种数据库,包括SQL Server、MySQL、SQLite等,并且提供了类似于EF的功能,如数据查询、数据更新、事务处理等。

在保存相关实体上,EF和EF Core有一些比较:

  1. 性能:EF Core相对于EF来说,性能更好。EF Core采用了更加轻量级的设计,减少了不必要的开销,提高了性能。
  2. 跨平台支持:EF Core支持跨平台开发,可以在Windows、Linux、Mac等多个操作系统上运行。而EF只能在Windows上运行。
  3. 数据库支持:EF Core支持的数据库更加丰富,包括SQL Server、MySQL、SQLite、PostgreSQL等。而EF主要支持SQL Server。
  4. LINQ支持:EF Core对LINQ(Language Integrated Query)的支持更加完善。LINQ是一种强大的查询语言,可以方便地进行数据查询和操作。
  5. 迁移支持:EF Core引入了数据库迁移的概念,可以方便地进行数据库结构的变更和迁移。而EF没有内置的迁移功能,需要使用第三方工具。

在实际应用中,EF和EF Core可以根据具体需求选择使用。如果需要跨平台支持或者对性能要求较高,可以选择EF Core。如果只在Windows平台上运行,并且对数据库支持较为简单,可以选择EF。

腾讯云提供了一系列与数据库相关的产品和服务,包括云数据库SQL Server、云数据库MySQL、云数据库PostgreSQL等。这些产品可以与EF和EF Core结合使用,提供稳定可靠的数据库服务。具体产品介绍和链接地址可以参考腾讯云官方网站:https://cloud.tencent.com/product。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • EF Core下利用Mysql进行数据存储在并发访问下的数据同步问题

    (在查询的5000基础上加3000) 最终的结果是,小刘的银行卡金额8000块钱,刘嫂也拿到了5000块钱。 反思? 故事结束了,很多同学肯定会说,要真有这样的银行不早就倒闭了?...确实,真是的银行不可能是这样来计算的,可是我们的同学在设计程序的时候,却经常是这样的一个思路,先从数据库中取值,然后在取到的值的基础上对该值进行修改。...通俗地讲,就是在我们设计数据库的时候,给实体添加一个Version的属性,对实体进行修改前,比较该实体现在的Version和自己当年取出来的Version是否一致,如果一致,对该实体修改,同时,对Version...所谓的并发令牌,就是在实体的属性中添加一块令牌,当对数据执行修改操作时,系统会在Sql语句后加一个Where条件,筛选被标记成令牌的字段是否与取出来一致,如果不一致了,返回的肯定是影响0行,那么此时,就会对抛出异常...然后在依赖项中选择Nuget包管理器,安装  Pomelo.EntityFrameworkCore.MySql 改引用,该引用可以理解为Mysql的EF Core驱动。

    1.5K50

    在.NET 8 RC1 版本中 MAUI、ASP.NET Core 和 EF8 的新特性

    特定于平台的修复:进行了修复以确保在不同平台(包括iOS,Android,Windows和macOS)上保持一致的用户体验,解决了边框剪切,窗口故障和图像加载问题等问题。...ASP.NET Core 在这里,Blazor 是ASP.NET Core的重心,Blazor 让 Web 开发人员使用 C# 而不是 JavaScript 的又有了八个方面不同的改进(其中一些在 Microsoft...EF Core 8 此数据驱动框架包含在 NuGet 包中,该包拥有超过 809.70 亿次下载,EF Core是 .NET 的现代ORM。它支持 LINQ 查询、更改跟踪、更新和架构迁移。...EF Core通过提供程序插件API与SQL Server,Azure SQL Database,SQLite,Azure Cosmos DB,MySQL,PostgreSQL和其他数据库配合使用。...公告帖子列出了多达70个项目,并附有指向每个项目的更多信息的链接。EF Core 8 中的新增功能[13]中还提供了详细信息.

    69360

    一步步学习EF Core(3.EF Core2.0路线图)

    前言 这几天一直在研究EF Core的官方文档,暂时没有发现什么比较新的和EF6.x差距比较大的东西....具体区别请移步:比较EF Core和EF6.x 我们提供了我们认为重要但还没实施功能列表。...但是在实现下面这些功能之前,虽然EF Core对于许多应用场景来说是一个有效的选择(特别是在.NET Core的平台上,因为EF6.x不起作用.....其中一部分已经在预览1完成了 存储过程映射,允许EF使用存储过程来保存对数据库的更改(FromSql已经提供了对使用存储过程进行查询的良好支持)。...ETag式并发令牌支持提供了统一的编码模式,用于管理与模型配置无关的并发性。 贪婪加载,允许在查询实体时始终检索默认的相关数据集。 过滤加载,允许加载相关实体的一个子集。

    3.1K90

    【ASP.NET Core 基础知识】--数据库连接--使用Entity Framework Core进行数据库访问

    更高的性能: EF Core 设计上更加高效,能够提供更好的性能,特别是在执行大量数据操作时。...跨平台支持: EF Core 是 .NET Core 的一部分,因此可以在多种操作系统上运行,而 EF 主要针对 Windows 平台。...4.2 事务管理 在 Entity Framework Core(EF Core)中,事务管理允许开发者对一组相关数据库操作进行原子性处理,这意味着这些操作要么全部成功,要么全部回滚到最初的状态。...此外,EF Core 支持保存点(Savepoint),这是一种在事务中创建一个可回滚的子事务点的机制。如果操作失败,你可以回滚到最近创建的保存点,而不是回滚整个事务。...预加载相关实体:在查询时,通过使用Include或Explicit Loading来预加载相关实体,减少多次查询数据库的需要。

    61900

    Entity Framework Core 简介

    下面列举一下 EF Core 所支持的项目类型: 运行在 .NET Core 平台上的 Asp.Net Core MVC/Web Api、Console、etc ; 运行在 .NET 4.5+ 版本上的...零、EF Core 开发方法 EF Core 只支持两种开发方式 Code First 和 Database First,在 EF Core 2.0 开始不支持数据库模型的可视化设计器以及数据库设计导航...在 Code First 方法中, EF Core API 使用基于 domain classes 中提供的约定和配置的迁移来创建数据库和表,这种方法在 DDD 中很有用。...一、EF Core 与 EF6 这里列一下 EF Core 目前所具有的 EF6 的功能 DbContext ; DbSet ; Data Model ; 使用Linq-to-Entities查询 ;...以下是 EF Core 目前所不具有的 EF6 的功能 EDMX /模型的图形可视化 ; 实体数据模型向导 ; ObjectContext API ; 使用Entity SQL查询 ; 自动迁移 ; TPT

    1.9K10

    02-EF Core笔记之保存数据

    EF Core通过ChangeTracker跟踪需要写入数据库的更改,当需要保存数据时,调用DbContext的SaveChanges方法完成保存。...Core中,除了独立的模型外,还有与模型关联的数据,这部分数据通过独立模型添加到模型中,在SaveChanges时将会持久化到数据库中。...EF Core对于提供了更细粒度的管理,它允许我们定义删除行为,来控制依赖关系被移除时,如何处理关系的子实体。...工作原理:每当在 SaveChanges 期间执行更新或删除操作时,会将数据库上的并发令牌值与通过 EF Core 读取的原始值进行比较。如果一致则可以完成操作,如果不一致,则终止事务。...在关系数据库上,EF Core 会对任何 UPDATE 或 DELETE 语句的 WHERE 子句中的并发令牌值进行检查。 执行这些语句后,EF Core 会读取受影响的行数。

    1.8K40

    【译】MongoDB EF Core 提供程序:有什么新功能?

    在这篇文章中,我们将使用 MongoDB EF Core 提供程序和 MongoDB Atlas 来展示以下内容: 向实体添加属性并进行更改跟踪 利用出口创建索引 执行复杂查询 事务和乐观并发 与本博客相关的代码可以在...AdaptedFromBook { get; set; } } 现在,我们将为找到的电影实体设置这个新添加的属性,并在保存更改后查看 EF Core 的更改跟踪功能。...您可以在文档中阅读更多相关信息。我们将使用 RowVersion 来演示此用例。这将利用模型类中的 Version 字段,该字段将由 MongoDB EF 提供程序自动更新。...我们还将添加第三部分(是的,这是三部曲),但使用与第二部电影实体相同的 ID 到这个新上下文,然后保存我们的更改。...在 Microsoft Youtube 频道上观看有关 EF Core 9:在 .NET 中发展数据访问的演讲。 原文链接 MongoDB EF Core Provider: What’s New?

    7110

    2022年了有哪些值得推荐的.NET ORM框架?

    前言: 最近有很多同学问我.NET方面有哪些好用的ORM框架,我觉得这方面的介绍网上应该会介绍的比较全面文章,于是我想搜一篇全面的介绍文章发给他们结果我发现网上说来说去基本上就是那几个,于是就有了这篇文章...它解决了对象和关系型数据库之间的数据交互问题,ORM的作用是在关系型数据库和业务实体对象之间作一个映射,这样我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法...以下是一些比较好用且优秀的.NET-ORM框架汇总,排名不分先后可供大家参考学习(假如您有更好的.NET相关ORM推荐请在文末留言,谢谢)。...官方文档教程:https://docs.microsoft.com/zh-cn/ef/ GitHub地址:https://github.com/dotnet/efcore 以下是EF/EF Core相关拓展程序包...EntityFramework.VersionedProperties -  将对象里每次变更历史自动保存到一个特定的属性里。审计或者做历史版本时比较适用。

    5.9K11

    2022年了有哪些值得推荐的.NET ORM框架?

    前言: 最近有很多同学问我.NET方面有哪些好用的ORM框架,我觉得这方面的介绍网上应该会介绍的比较全面文章,于是我想搜一篇全面的介绍文章发给他们结果我发现网上说来说去基本上就是那几个,于是就有了这篇文章...它解决了对象和关系型数据库之间的数据交互问题,ORM的作用是在关系型数据库和业务实体对象之间作一个映射,这样我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象的属性和方法...以下是一些比较好用且优秀的.NET-ORM框架汇总,排名不分先后可供大家参考学习(假如您有更好的.NET相关ORM推荐请在文末留言,谢谢)。...官方文档教程:https://docs.microsoft.com/zh-cn/ef/ GitHub地址:https://github.com/dotnet/efcore 以下是EF/EF Core相关拓展程序包...EntityFramework.VersionedProperties -  将对象里每次变更历史自动保存到一个特定的属性里。审计或者做历史版本时比较适用。

    3.9K20

    EF Core 入门

    0.前言 上一章简单介绍了一下ORM框架,并手写了一个类似ORM的工具类。这一章将介绍一个在C#世界里大名鼎鼎的ORM框架——Entity Framework的Core版。...EF可以在不使用任何配置的前提下,自动解析类与表之间的映射(具体的映射逻辑与我们手写的ORM工具类一致或相近)。 自动跟踪更改。...在直接使用通过EF获取的元素时,EF会自动跟踪哪些字段发生了变化,当手动调用保存的时候,EF就会把数据回传给数据库。...可以延迟加载需要的数据,外键引用属性、查询结果等 丰富的映射关系,支持一对一,一对多,多对多,甚至继承、单表多实例等 可以使用Linq 进行查询 非Core版的可以通过数据库表生成实体类,两种都可以通过实体类生成表...这里简单介绍一下选择Core的原因,微软这几年一直在主推跨平台战略。

    2.6K10

    面向初学者的 Entity Framework Core

    在深入了解EF Core之前,理解什么是ORM非常重要。ORM(对象关系映射)是软件开发中用于在不兼容的系统(如数据库和编程语言)之间转换数据的一种技术。...EF Core中的关键概念 DbContext: DbContext是EF Core中的核心类,用于管理数据库交互操作。它充当了.NET应用程序与数据库之间的桥梁。...例如,如果你向一个实体类添加了新的属性,你可以生成一个迁移,以便将该变更应用到数据库架构上,同时又不会丢失现有数据。...EF Core 以下是在.NET项目中设置EF Core的简单指南。...步骤1:安装EF Core包 在你的.NET项目中,需要安装EF Core相关的包。你可以通过NuGet包管理器或者命令行来进行安装。

    10010

    01-EF Core笔记之创建模型

    数据标注方式比较简单,在类或字段上添加特性标注即可,对实体类型有一定的入侵。...,而在EF Core中模型中为该实体类型定义的属性,这些类型只能通过变更跟踪器进行维护。...在数据库中,数据表之间的关系可以分为一对一、一对多、多对多三种,在实体之间同样有这三种关系,但是EF Core仅支持一对一、一对多关系,如果要实现多对多关系,则需要通过关系实体进行关联。...):基类和子类不在同一个表中,子类中包含基类的所有字段,目前EF Core不支持该模式 EF Core仅支持TPH模式,基类和子类数据将存储在同一个表中。...实体构造函数 EF Core支持实体具有有参的构造函数,默认情况下,EF Core使用无参构造函数来实例化实体对象,如果发现实体类型具有有参的构造函数,则优先使用有参的构造函数。

    3.1K20

    ASP.NET Core MVC+Layui使用EF Core连接MySQL执行简单的CRUD操作

    前言:   本章主要通过一个完整的示例讲解ASP.NET Core MVC+EF Core对MySQL数据库进行简单的CRUD操作,希望能够为刚入门.NET Core的小伙伴们提供一个完整的参考实例。...二、添加EF Core NuGet包:   若要在项目中使用EF Core操作MySQL数据库,需要安装相应的数据库驱动包。...三、创建对应数据库表的实体模型:   注意该篇博客使用的是手动模型优先的方式进行数据库表字段与模型属性映射,当然如果大家觉得这样子比较麻烦的话可以真正意义上的模型优先,直接创建模型在program.cs...在定义 DbSet 属性的代码之后,添加下面代码,对DbContext指定单数的表名来覆盖默认的表名。...八、 ASP.NET Core MVC 和 EF Core实现MySQL CRUD功能: 注意在这里主要展示的EF Core与数据库操作的部分代码,详细代码可下载实例源码查看。

    2.8K10

    .NET 云原生架构师训练营(模块二 基础巩固 EF Core 更新和迁移)--学习笔记

    2.4.6 EF Core -- 更新 状态 自动变更检测 不查询删除和更新 并发 状态 Entity State Property State Entity State Added 添加 Unchanged...,只在数据库更新操作提交的时候才对数据作冲突检测(推荐) 悲观处理:根据命名即对数据库进行操作更新时,对操作持悲观保守的态度,认为产生数据冲突的可能性很大,需要先对请求的数据加锁再进行相关操作 在 Entity...,都会产生最新的版本号,如果更新的时候查询的版本号与之前的版本号不一致,就会报错 在 UpdateAsync 方法中的查询和更新中间如果数据库的行版本号发生了修改,就会报错 ProjectController...Core -- 迁移 生成 SQL 脚本 从空白开始生成sql脚本 dotnet ef migrations script 生成指定版本到最新版本的sql dotnet ef migrations...EF Core -- 其他 database-first dotnet ef dbcontext scaffold "server=172.0.0.1;port=7306;user=root;password

    61620

    EntityFramework Core 学习扫盲

    写在前面 本篇文章虽说是入门学习,但是也不会循规蹈矩地把EF1.0版本一直到现在即将到来的EF Core 2.0版本相关的所有历史和细节完完整整还原出来。...虽然我们目前还没有添加任何约束,但是EF Core会自动地根据Id/XXId的命名方式生成自增主键,而且如果没有在实体上增加[Table]Attribute的话,表的命名也是根据属性命名而定。...主键 默认情况下,EF CORE会将实体中命名为Id或者[TypeName]Id的属性映射为数据库表中的主键。当然有些开发者不喜欢将主键命名为Id,EF CORE也提供了两种方式进行主键的相关设置。...在Fluent Api中,有两种方法可以指定备用键,一种是当开发者将实体中的属性作为另一个实体的外键目标,另一种是手动指定。EF CORE的默认约束是前者。...EF CORE在Data Annotations和Fluent Api形式上为开发者分别提供了三种方法。

    9.6K90

    DDD实战进阶第一波(五):开发一般业务的大健康行业直销系统(实现产品上下文领域层)

    本篇文章主要讲产品上下文中的领域层的主要实现,先简单讲下业务方面的需求:产品SPU与产品SKU,产品SPU主要是产品的名字和相关描述, 产品SKU包括产品SPU的多个规格,每个规格有不同的价格与PV值。...产品上下文主要实现产品的上架功能,为了实现上架功能,我们首先要实现产品上下文的领域POCO模型与领域逻辑, 我们将产品的POCO模型与领域逻辑建立到一个叫Product.Domain的项目中。...,ProductSPU包含了一个ProductSKU的集合(也就是引用),这就代表它们同属一个聚合,在具体使用EF Core做 持久化时,会作为一个事务统一持久化。...领域对象除了包含自身的属性,也应该包括自身的业务逻辑,产品上架的功能比较简单,业务逻辑也比较简单,主要就是如何生成整个领域对象,以及聚合根与实体业务标识符Code的生成规则。...Product.Domain除了要实现领域逻辑之外,还要定义ProductSPU的仓储接口、通过EF Core定义产品上下文与数据库上下文之间的映射关系。

    1.1K50

    每个 .NET 开发人员解决常见问题时都应该了解的 5 个 EF Core 功能

    Entity Framework Core (EF Core) 为希望以高效可靠的方式与数据库交互的 .NET 开发人员带来了翻天覆地的变化。...全局查询过滤器:避免重复的过滤逻辑 问题:您是否厌倦了在每个查询中为“软删除”实体添加相同的筛选条件? 解决方案:使用 EF Core 中的全局查询筛选器在实体的所有查询中自动应用条件。...Product 关键字:EF Core 影子属性、在 EF Core 中跟踪审核数据、实体框架核心审核跟踪 3....关键字:EF Core 编译的查询、优化 EF Core 查询性能、在 Entity Framework Core 中重用查询 4....关键字:EF Core 值转换、在 EF Core 中将枚举转换为字符串、实体框架数据格式 Entity Framework Core 不仅仅是一个数据库工具,它还是一个强大的 ORM,其功能使开发数据驱动的应用程序更轻松

    12410
    领券