今天来讲解一下 .NET 中的重要成员 Entity Framework Core。...Entity Framework Core (以下简称 EF Core),是 EF6 之后微软推出的开源的轻量级可扩展跨平台 ORM 框架。...EF Core 需要和 .NET Core 应用程序一起使用,并且需要 .NET 4.5+ 版本。...以下是 EF Core 目前所不具有的 EF6 的功能 EDMX /模型的图形可视化 ; 实体数据模型向导 ; ObjectContext API ; 使用Entity SQL查询 ; 自动迁移 ; TPT...; TPC ; 多对多关系 ; Entity Splitting ; Spatial Data ; 延迟加载 ; 使用DbContext进行存储过程映射以进行CUD操作 ; 种子数据 ; 自动迁移 。
.NET Core CLI 此种方法对于 ASP.NET Core 也可以使用,其实当执行命令 dotnet ef migrations 时,会启动所在程序集(Program.cs),和正常启动ASP.NET...Core 一样,所以会依赖注入 MyDbContext等 # 全局安装 EF Core 工具 dotnet tool install --global dotnet-ef # 安装 设计包,这是对项目运行命令所必需的...为了跨平台 应用,同时也便于编写Shell脚本,建议使用 .NET Core CLI ,不依赖于 Visual Studio 在 ASP.NET Core 中初始化数据库 这是另一种创建表结构,初始化表数据的方式...,而不是用CLI,这是在启动ASP.NET Core时执行。...中的 Razor Pages 和 Entity Framework Core - 第 1 个教程(共 8 个) | Microsoft Docs 创建数据库 Program.cs using ContosoUniversity.Data
EF Core与其他ORM比较 1、Entity Framework Core(EF Core)是微软官方的ORM框架。...4、性能: Dapper等≠性能高;EF Core≠性能差。 5、EF Core是官方推荐、推进的框架,尽量屏蔽底层数据库差异,.NET开发者必须熟悉,根据的项目情况再决定用哪个。...2、EF会对实体上的标注做校验,EF Core追求轻量化,不校验。 3、熟悉EF的话,掌握EFCore会很容易,很多用法都移植过来了。EF Core又增加了很多新东西。...().ToView("blogsView"); 2、排除属性映射: modelBuilder.Entity().Ignore(b => b....modelBuilder.Entity().HasKey(c => c.Number); 6、可以用HasDefaultValue()为属性设定默认值 modelBuilder.Entity
该文分以下几点: 创建Model和数据库 使用Model与数据库交互 查询和保存关联数据 EF Core支持情况 EF Core的数据库Providers: 此外还即将支持CosmosDB和 Oracle...Framework Core库: 首先Data项目肯定需要安装这个库, 而我要使用sql server, 参照官方文档, 直接在解决方案下执行这个命令: dotnet add ....这个快照文件解决了老版本Entity Framework的一个顽固的团队问题. 使用迁移文件创建脚本或直接生成数据库....如果使用asp.net core的话....对于asp.net core 2.0项目, 参考官方文档: https://docs.microsoft.com/en-us/aspnet/core/fundamentals/logging/?
使用EF Core Migrations可以使Entity & DbContext的配置与数据库保持一致,Migrations可以非常容易的将创建和更新数据库,当一个项目在开发过程中时,程序员能保证实体更新...Microsoft.EntityFrameworkCore.Tools 接下来我们看一下迁移命令 2 Add Migration 命令 Add Migration命令将创建迁移文件,你的DbContext和Entity...ProductVersion]) VALUES (N'20230410151721_migrations2', N'7.0.4'); GO COMMIT; GO PM> 总结 这节我们主要学习了Entity...Frame Core Migrations常用的相关命令 源代码地址: https://github.com/bingbing-gui/Asp.Net-Core-Skill/tree/master/EntityFrameworkCore...tabs=dotnet-core-cli https://www.yogihosting.com/migrations-entity-framework-core/
一.前言 Entity Framework(后面简称EF)作为微软家的ORM,自然而然从.NET Framework延续到了.NET Core。...以前我也嫌弃EF太重而不去使用它,但是EF Core(Entity Framework Core)已经做了很多性能优化,还有一些增加新特性,吸引了我去使用它。...EF Core同样是微软官方所推荐的。...默认的创建数据库策略已经和EF不用,请看后面的迁移操作 三.ASP.NET Core 使用 EF Core(Code First) 1.创建一个asp.net core 2.0 mvc项目 2.通过...的迁移操作 前面说过,EF Core默认的创建数据库策略已经和EF不用,需要我们通过迁移来创建数据库 这里不论是控制台还是ASP.NET Core操作都是一样的,这里以ASP.NET Core作为示例
protected override void OnModelCreating(ModelBuilder modelBuilder) 9 { 10 modelBuilder.Entity...在 ef core 2.0 中,我们将自定义的DbContext类型注册到DbContextPool服务中,可让该数据库上下文类型的实例重复使用。...>().ToTable("Products"); 5 modelBuilder.Entity().ToTable("Products"); 七.Owned types ...,在EF Core2.0中,这个特性回来了(EF Core 之前的 core版本不支持)。...2.0 introduces a new IPluralizer service that is used to singularize entity type names and pluralize
前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.. 看了下2.0的新特性基本算是完成了我之前发布的路线图的内容 很不错 下面就介绍一下新特性....使用表拆分识别关系(其中外键属性形成主键)必须在共享表的所有实体类型之间进行配置: modelBuilder.Entity() .HasOne(e => e.Details)....WithOne(e => e.Product) .HasForeignKey(e => e.Id); modelBuilder.Entity()...迁移不会对其进行创建 2.性能提升方面 2.1DbContext连接池 在ASP.NET Core程序中我们使用EF Core一般都是将自定义DbContext类型注册到依赖注入系统中,然后通过控制器中的构造函数参数获取该类型的实例...虽然EF Core通常可以根据查询表达式的散列表示自动编译和缓存查询,但这种机制可以通过绕过哈希计算和高速缓存查找来获得小的性能增益,从而允许应用程序使用已经通过调用委托编译了查询。
前言 今天下午在开发的时候发现EF Core实体模型中的导航属性为 null,经排查既不是没有加 virtual 关键字,也不是外键关系映射错误。 ?...解决方法 通过查询官网文档,发现,原因在于EF Core目前不支持延迟加载,所以每次查询,都会得到 null 的导航属性。目前只有使用 预先加载 或 显示加载 才能得到正确的导航属性。
微软在 Entity Framework Core 2+ 中引入了全局查询过滤器,简化了构建多租户应用程序和实体软删除的复杂度。这篇文章我将通过代码的形式对全局过滤查询进行详细的讲解。...{ protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity...p.IsDelete); modelBuilder.Entity().HasQueryFilter(p => !...在上下文中定义全局查询过滤的泛型方法: public void GlobalQuery (ModelBuilder builder) where T :BaseModel { builder.Entity
按下硬件、网络不提,我们单表从程序层面对系统的性能进行优化,翻来覆去无外乎三个方面 缓存 异步 sql 本片文章,我们针对.NET Core Web项目的EF Core框架进行性能优化。...正文 1、EF Core框架已经本地缓存机制memorycache,所以我们访问一个接口,二次访问的性能相比首次会提升一大截 2、尽可能的通过主键查询 3、在进行字符串模糊查询时,分为三种情况 //StartsWith...result= ProductContext.Product.Include(p=> p.productLogs).AsSplitQuery().ToList(); 原理 默认预先加载(懒加载)时,EF core...数据库查询进行笛卡尔积查询,实际查询了4次 拆分查询时,EF Core会生成两个sql语句: 1、单表查询主表product 2、主表product与副表productLogs进行inner join,...即不使用EF Core本身生成的sql var result= ProductContext.Product.FromSqlRaw("select * from product").ToList();
EFCore 2.1出来有一段时间了,里面的新功能还没怎么用,今天研究下如何使用EF Core 2.1添加种子数据。...这部分的官方文档地址是:https://docs.microsoft.com/en-us/ef/core/modeling/data-seeding 我们在开发时总是需要添加一些种子数据的,所以这个功能还是比较有用的...准备工作 我建立了一个ASP.NET Core项目,里面有几个Model,其中一个是省份Province,另一个是城市City: ? ? 里面还涉及到其它的Model,不过本文用不到,就不贴了。
前言 最近打算用.NET Core写一份开源的简易CMS系统,来练练手 所以又去深入研究了一下Entity Framework Core 发现其实有些细节园子里还是很少讲到. 特意整理了几个细节....正文 1.数据库迁移 先了解一下什么是"数据库迁移",它提供了一种方法,可以逐步将Code First的实体架构更改应用于数据库,以保持数据库与EF Core模型同步,同时保留数据库中的现有数据。...EF Core的数据迁移相对EF6来说改了不少也简化了一些.所以我们现在就来看看如何进行数据迁移 我们以官方代码来做为例子..先来创建一个简单的上下文.
如果你使用的是 Entity Framework Core 2.0 及以上版本来开发项目的话,那这个问题就好解决了。...在 Entity Framework Core 中,只要捕获到了数据变更记录,我们就可以将数据随时还原到变更前的状态,在这里数据库变更记录被称为审计数据。...要解答上述两个问题,那就跟着我一起来看看怎么利用 Entity Framework Core 来捕获审计数据。...in ChangeTracker.Entries()) { if (entity.Entity is Audit || entity.State == EntityState.Detached...AuditDb auditDb = new AuditDb(entity) { TableName = entity.Metadata.Name
前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.....本文主要是浅析一下Entity Framework Core的并发处理方式. 1.常见的并发处理策略 要了解如何处理并发,就要知道并发的一般处理策略 悲观并发策略 悲观并发策略,正如其名,它指的是对数据被外界...本篇就是讲解,如何在我们的Entity Framework Core中来使用和自定义我们的并发策略 2.Entity Framework Core并发令牌 要使用Entity Framework Core...中的并发策略,就需要使用我们的并发令牌(ConcurrencyCheck) 在Entity Framework Core中,并发的默认处理方式是无视并发冲突的,任何修改语句在条件符合的情况下,都可以修改成功...在高并发的情况下这种处理方式,肯定会给我们的数据库带来很多脏数据,所以,Entity Framework Core提供了并发令牌(ConcurrencyCheck)这个特性.
在Entity Framework 中采用IsConcurrencyToken配置后RowVersion即自动用于where子句中用于比较Row Version, 我们也需要使用这个特性实现并发控制,Ak.Ini...的博文http://www.cnblogs.com/akini/archive/2013/01/30/2882767.html ,我们按照这篇文章的方法在Entity framework core上面解决并发控制问题...OnModelCreating(ModelBuilder builder) { base.OnModelCreating(builder); builder.Entity
项目实际用到的命令字符串:Scaffold-DbContext "Data Source=YD-2622;Initial Catalog=MobileVideo...
DataAnnotation 特性由.NET 3.5中引进,给.NET中的类提供了一种添加验证的方式。但是在EF中它又可以对映射关系进行控制,相比较Fluent...
DbContext { protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity
领取专属 10元无门槛券
手把手带您无忧上云