首页
学习
活动
专区
圈层
工具
发布

EntityFramework Core 学习扫盲

还记得我们第一步中MyContext定义的OnModelCreating方法吗,Fluent Api就是在那里面使用的 增加以下代码至OnModelCreating方法。...包含和排除实体类型 将实体在Context中映射到数据库有多种方式: 使用DbSet定义属性。 在OnModelCreating方法中使用Fluent Api配置。...列名称和类型映射 Property方法对应数据库中的Column。 默认情况下,我们不需要更改任何实体中包含的属性名,EF CORE会自动地根据属性名称映射到数据库中的列名。...Fluent API [HasKey] Fluent Api方式中的HasKey方法可以将属性映射为主键,对于复合主键(多个属性组合而成的主键标识)也可以很容易地进行表示。...在Fluent Api中,有两种方法可以指定备用键,一种是当开发者将实体中的属性作为另一个实体的外键目标,另一种是手动指定。EF CORE的默认约束是前者。

10.5K90

.NET 云原生架构师训练营(模块二 基础巩固 EF Core 基础与配置)--学习笔记

2.4.3 EF Core -- 基础与配置 连接字符串 异步编程 日志 DbContext池 类和配置表 属性和列配置 并发token 索引 Entity Framework Core:https:/...异步操作对于在丰富的客户端应用程序中保持响应式 UI 非常重要,并且还可以增加 web 应用程序中的吞吐量,在这些应用程序中,它们可释放线程以处理 web 应用程序中的其他请求 var blog = new...tabs=data-annotations 通过 Fluent API 的方式添加自增列 LighterDbContext modelBuilder.Entity()....tabs=data-annotations 配置为并发标记的属性用于实现乐观并发控制。...此属性也被视为并发标记,这确保了在你查询行后,如果正在更新的行发生了更改,则会出现异常。

1.3K11
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    .NET 云原生架构师训练营(模块二 基础巩固 EF Core 基础与配置)--学习笔记

    2.4.3 EF Core -- 基础与配置 连接字符串 异步编程 日志 DbContext池 类和配置表 属性和列配置 并发token 索引 Entity Framework Core:https:/...异步操作对于在丰富的客户端应用程序中保持响应式 UI 非常重要,并且还可以增加 web 应用程序中的吞吐量,在这些应用程序中,它们可释放线程以处理 web 应用程序中的其他请求 var blog = new...tabs=data-annotations 通过 Fluent API 的方式添加自增列 LighterDbContext modelBuilder.Entity()....tabs=data-annotations 配置为并发标记的属性用于实现乐观并发控制。...此属性也被视为并发标记,这确保了在你查询行后,如果正在更新的行发生了更改,则会出现异常。

    1.4K20

    EntityFramework Core 自动绑定模型映射

    笔者最近在和同事共同开发项目时,需要从他们提供的包含数据库实体类型的类库中读取实体信息绑定到自己的项目中(但是都在同一个解决方案里),所以很直接的一种方式就是把项目中所有的实体都以 public DbSet...从这个想法出发,其实我们很自然地就可以想到 Context 中的 OnModelCreating 方法,在传统的 EF 6中,它也是作为实体模型属性映射的方法容器存在。...如果大家看过笔者之前的那篇《EntityFramework Core 学习扫盲》,就会知道 Fluent Api 的使用都是在这个方法中的。...方法中加入以下代码 modelBuilder.Configurations.Add(new BlogConfiguration()); 就是这样一个好用的东西,却没有随着 EF 的迁移而保留下来,在...EF Core 中,我们已经看不到它的身影了,残念ですね。

    1.5K40

    EntityFramework Core 自动绑定模型映射

    笔者最近在和同事共同开发项目时,需要从他们提供的包含数据库实体类型的类库中读取实体信息绑定到自己的项目中(但是都在同一个解决方案里),所以很直接的一种方式就是把项目中所有的实体都以 public DbSet...从这个想法出发,其实我们很自然地就可以想到 Context 中的 OnModelCreating 方法,在传统的 EF 6中,它也是作为实体模型属性映射的方法容器存在。...如果大家看过笔者之前的那篇《EntityFramework Core 学习扫盲》,就会知道 Fluent Api 的使用都是在这个方法中的。...方法中加入以下代码 modelBuilder.Configurations.Add(new BlogConfiguration()); 就是这样一个好用的东西,却没有随着 EF 的迁移而保留下来,在...EF Core 中,我们已经看不到它的身影了,残念ですね。

    1.4K60

    C# 数据操作系列 - 6 EF Core 配置映射关系

    对于其他属性,EF会自动按照同名的形式映射到数据表中。 对于外键,如果在类里添加了引用类型,而这个引用类型也在EF的上下文中,EF会把这种属性称为导航属性。...[InverseProperty("Author")] 用在集合类型的属性上,表示该集合属性是与源类哪一个导航属性相关。...[Column] 表示列,用来设置一些列的基本参数,比如类型、名称 [Required] 表示该列在插入数据库时不能为空 使用注解进行相关配置相当简单,但是这样不可避免的需要修改模型类而且需要引入额外的命名空间...2.2 Fluent 方式 当我们使用这种方式的时候,会面临一个问题:是新建一个配置类呢,还是在 EF上下文的OnModelCreating方法里统一配置呢?...所以通过分析API,我们可以得到这两种写法。 那么,这两种的取舍呢? 在项目比较小,数据类很少的时候,可以直接在OnModelCreating里写。

    3.5K21

    EF Core3.1 CodeFirst动态自动添加表和字段的描述信息

    (PS:真心希望达梦数据库能开放EF Core相关的源码,这样我们也好提交点贡献,国产数据库还是不能太过敝帚自珍阿..) ?...正文 1.通过扩展生成器,来实现动态自动添加描述信息 我们知道在SQL Server中,可以通过Fluent API来添加针对表或者字段的描述,如下: builder.Property(prop.Name...类名翻译过来,喔唷,这不就是迁移SQL生成器么 那么我们就需要去实现他啦.首先,我们找到达梦实现他的子类:DmMigrationsSqlGenerator 通过反编译,我们发现,果然他并没实现对于Comment...属性的代码,那么我们就需要自行扩展 我们添加MyDmigrationsSqlGenerator类继承DmMigrationsSqlGenerator 添加扩展代码如下: 1 using Microsoft.EntityFrameworkCore.Metadata...执行迁移语句Script-Migration~ 我们会发现,描述已经自动生成啦~ 结束语 其实不管是.NET 5.0 还是EF Core 在开源化的今天,我们只要愿意去多翻翻源码,会发现自己可以扩展的东西还有很多

    2K50

    Entity Framework 约定

    我们定义完模型,还需要让EF上下文你知道应该映射那些模型,此时我们需要通过 DbSet 属性来暴露模型的。...如果我们定义的模型由继承层次,只需要为基类定义一个DbSet属性即可(如果派生类与基类在同一个程序集,派生类将会被自动包含),代码如下: public class Department { public...,这时我们可以通过Fluent API 来忽略指定的模型映射到数据库中,代码写在EF上下文中: protected override void OnModelCreating(DbModelBuilder...EF中定义关系要使用到导航属性,通过导航属性可以定义多个模型之间的关系。大部分情况下我们会将导航属性和外键属性结合在一起使用。...,在模型创建之后用于操作对模型的存储,***自定义类约定***都必须在 OnModelCreating 方法中显式配置,例如我们要将模型中类型为DateTime的属性映射为datetime2,可进行如下配置

    1.7K10

    从头编写 asp.net core 2.0 web api 基础框架 (4) EF配置

    他们俩可以在数据库中映射成一个表;或者在没有继承的情况下,数据库中的一个表可能和多个类有映射关系。...fluent api有很多方法,具体请查看文档:https://docs.microsoft.com/en-us/ef/core/modeling/ 然后,我们就会发现一个严重的问题。...如果项目里面有很多entity,那么所有的fluent api配置都需要写在OnModelCreating这个方法里,那太多了。...然后把系统环境变量中的连接字符串删了把,并且把项目属性Debug中改成Development,这时候需要重启VS,因为一般环境变量是在软件启动的时候附加到其内存的,软件没关的情况下如果把系统环境变量给删了...,在软件的内存中应该还是能找到该环境变量,所以软件得重启才能获取最新的环境变量们。

    2.6K70

    生成数据库

    他们俩可以在数据库中映射成一个表;或者在没有继承的情况下,数据库中的一个表可能和多个类有映射关系。...如果项目里面有很多entity,那么所有的fluent api配置都需要写在OnModelCreating这个方法里,那太多了。...生产环境: 在项目的属性--Debug里面,我们看到了环境变量: 而这个环境变量,我们可以在程序中读取出来,所以可以在这里添加连接字符串: 注意它的key,要和appSettings.json里面的整体结构一致...然后把系统环境变量中的连接字符串删了把,并且把项目属性Debug中改成Development,这时候需要重启VS,因为一般环境变量是在软件启动的时候附加到其内存的,软件没关的情况下如果把系统环境变量给删了...,在软件的内存中应该还是能找到该环境变量,所以软件得重启才能获取最新的环境变量们。

    1.4K20

    01-EF Core笔记之创建模型

    如果你想改变默认值,很简单,EF Core提供了Fluent API或Data Annotations两种方式允许我们定制数据模型。...注意:如果CLR中属性不能为null,则无论如何配置都将为必填。 也就是说,如果能为null,则默认都是可空字段,因此在配置时,只需要配置是否为必填即可。...Fluent API进行配置: //包含类型 modelBuilder.Entity(); //包含属性,又叫做阴影属性,它会被映射到数据库中 modelBuilder.Entity...() .Property("LastUpdated"); 阴影属性 阴影属性指的是在实体中未定义的属性,而在EF Core中模型中为该实体类型定义的属性,这些类型只能通过变更跟踪器进行维护...使用有参构造函数需要注意: 参数名应与属性的名字、类型相匹配 如果参数中不具有所有字段,则在调用构造函数完成后,对未包含字段进行赋值 使用懒加载时,构造函数需要能够被代理类访问到,因此需要构造函数为public

    3.9K20

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

    它提供了 Code First 开发方法,允许开发人员通过代码来定义模型、配置映射关系和创建数据库。此外,EF Core 还支持数据迁移,使得在开发过程中数据库模式的变更更加容易管理和部署。...Code First 的主要特点包括: 基于代码的设计: 开发者使用 .NET 类和属性来定义数据库模型,这些类和属性代表了数据库中的表和列。...Code First 通常与以下两种模式结合使用: 实体框架模型(Entity Framework Model): 开发者创建实体类,这些类通过 Fluent API 或数据注释与数据库表进行映射。...MyDbContext 类配置了使用 SQL Server 数据库提供程序,并定义了一个名为 Blogs 的 DbSet 属性,用于表示数据库中的 Blog 实体。...如果你需要在同一个 DbContext 实例中访问多个数据库,你可以通过在 DbContext 类中添加多个 DbSet 属性来实现这一点。每个 DbSet 属性对应一个数据库中的表。

    2.9K00

    Entity Framework 4.1 Code-First 学习笔记

    OrderDetail类没有派生自任何基类,也没有附加EF特性,在将它们添加到上下文(上下文需要派生自DbContext)中时,会自动生成相应的数据表。...Fluent API 来修改模型 为我们的模型增加标签 通过构建器来覆盖默认约定,我们需要重写 DbContext 的一个方法 OnModelCreating: protectedoverridevoid...这就是为什么需要标记你的子实体集合属性为 virtual 的原因。...整个的层次被展开到一张表中,基类中没有的属性被自动标记为可空。...还有一个额外的区分列,用来保存数据是属于哪一个类,当 EF 读取一行的时候,区分列被 EF 用来知道应该创建实例的类型,因为现在所有的类都被映射到了一张表中。

    2.3K10

    Entity Framework 系统约定配置

    在EF中是以一种约定的方式进行表、列同实体类进行映射的,与此同时为了提高最大的灵活性EF中可以通过Fluent API和Data Annotations两种方式对映射进行灵活配置。...3.使用导航属性约束两个表之间的关系,在从表数据类中除了导航属性,推荐定义一个外键属性在从表数据类中(如果不指定将默认生成一个“类名>+类的主键名>”的外键列;此外在主表中推荐定义一个集合从表属性用户导航...;如果不存在外键属性则外键关系注册为可选的,否则注册为必选项并且此时将设置级联删除关系;如果在从表类中有多个导航属性对应同一个数据类那么需要使用fluent API或者Data Annotations进行手动配置...4.当EF按照上述规则在数据类中没有找到主键属性时(或者通过fluent API、Data Annotations没有定义)将认为此类为“复杂类型”。   ...一般情况下我们是不需要移除默认约定的,我们更多的时候是要修改丰富这些约定,达到对生成规则的更多细节控制。在EF提供了两种方式进行映射配置:Data Annotations和Fluent API。

    1.2K20

    Entity Framework Fluent API

    前言 使用DataAnnotation非常简单,但对于EntityFramework中的特性,就要在实体类中引入EntityFramework程序集,但实体类最好能是保持与架构无关性的POCO类,才能更具通用性...从功能上而言Data Annotations是Fluent API的一个子集, Data Annotations可以实现的功能Fluent API都能实现。...: 设置属性需要在数据库操作上下文的 protected override void OnModelCreating(DbModelBuilder modelBuilder)...以下API的DataAnnotation特性是在EntityFramework中定义,如果也使用DataAnnotation方式来设置映射,就会给实体类增加额外的第三方程序集的依赖。...可通过指定配置操作来自定义列和表。如果指定了空的配置操作,则约定将生成列名。如果在对象模型中公开了外键属性,则使用 HasForeignKey 方法。并非所有关系都支持在对象模型中公开外键属性。

    1.3K10

    EF 约定介绍

    当前环境为EF Code First开发模式中 一、EF默认约定 1、常用约定 (1)、当没有显示指定实体主键的时候,EF会默认将长得最像Id的属性(且类型为GUID)设为主键 (2)、设计实体时,当一个实体包含一个集合属性...,EF自动生成中间表,不需要新增实体来表示. (5)、表名默认复数化 2、类型发现约定(Type Discovery) 使用EF开发,往往是以定义一些模型类开始,定义完这些模型类之后,需要让DbContext...知道哪些类型包含在当前模型中,因此,我们需要自定义一个ZdyNameDbContext,并继承DbContext,并在自定义DbContext中暴露需要暴露的类型,这样在Code First开发模式中,...) Convention EF中,两个实体间的关系是通过导航属性的方式来实现,每一个对象都能拥有一个它所参与的关系的导航属性,导航属性提供了一种方式在两端来操作这个关系来获取我们需要的数据,可以返回任何一方的引用对象...5、复杂类型约定(Complex Types Conventions) 如果Code First无法从类型中推测出主键,也没有通过Data Annotations或者Fluent Api进行注册的主键,

    2.4K100

    如何处理EF Core的多对多关系?

    多对多关系不像其他关系那么简单,在这篇文章中,我将向您展示如何创建多对多关系以及如何在 EF Core 中使用它们。 模型 多对多的简单而实用的例子可能是某种数字电子商务商店。...手动配置关系,或使用“[NotMapped]”属性或使用“OnModelCreating”中的“EntityTypeBuilder.Ignore”忽略此属性。】...我们需要做的第一件事是手动创建另一个“中间”类(表),它将建立Cart和Item的多对多关系,让我们创建这个类: public class CartItem { public int CartId...【实体类型“CartItem”需要定义一个主键。】 对,CartItem没有主键, 由于它是多对多关系,因此它应该具有复合主键。复合主键类似于常规主键,但它由两个属性(列)而不是一个属性组成。...从数据库中获取数据相当简单,注意使用Include关联检索相关数据。

    4.2K20

    C#进阶-Entity Framework 5 原理与使用详解

    其主要工作流程如下:数据模型定义:开发者通过定义实体类来描述数据库结构。数据库上下文管理:EF5提供了DbContext类,用于管理数据库连接和操作。...DbContext是EF的核心类,用于与数据库进行交互。查询与操作:EF5通过LINQ(Language Integrated Query)执行查询,并自动将结果映射到对象模型中。...自动迁移与同步:EF5支持数据库自动迁移功能,使数据库结构可以随着模型的变化自动更新。...以下是如何定义SchoolContext类和Student实体类的示例代码。1. 定义数据库上下文和实体类SchoolContext类继承自DbContext,它代表了与数据库的交互上下文。...OnModelCreating方法用于配置实体与数据库表之间的映射关系。2. 查询数据EF5使用LINQ进行数据查询,查询结果自动映射到对象模型中。

    1.3K54
    领券