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

CSharpEntityFramework与CodeFirst实践

接下来,我们需要使用继承EF的DbContext来构建数据库上下文类,我们直接使用VS自带生成工具即可生成对应的数据库上下文模型: 点击完成后我们就得到了如下的一个配置类 public class...此迁移文件的设计器代码包含当前 Code First 模型的快照。在下一次搭建迁移基架时,将使用此快照计算对模型的更改。...此迁移文件的设计器代码包含当前 Code First 模型的快照。在下一次搭建迁移基架时,将使用此快照计算对模型的更改。...在下一次搭建迁移基架时,将使用此快照计算对模型的更改。如果对要包含在此迁移中的模型进行其他更改,则您可通过再次运行“Add-Migration AddNewProp”重新搭建基架。...其实我们首先知道,在进行Update-database的时候,EF框架会执行Up方法,同时,AddColumn、DropColumn很显然是DbMigration这个类中的方法,我们找一找看有没有重命名的方法呢

28310

从EFCore上下文的使用到深入剖析DI的生命周期最后实现自动属性注入

) : base(dbContext) { } } 从上面的代码可以看到,任何要继承BaseController的类都要写一个“多余”的构造函数,如果参数再多几个,这将是无法忍受的(就算只有一个参数我也忍受不了...DbContext从哪来 1、 直接开溜new 回归原始,既然要创建实例,没有比直接new一个更好的办法了,在Framework中没有DI的时候也差不多都这么干。...如果要手动new一个上下文,那岂不是每次都要自己传?不行,这太痛苦了。那有没有办法不传这个参数?肯定也是有的。...那原生DI有没有实现这个功能呢,我满心欢喜上G站搜Issue,看到这样一个回复(https://github.com/aspnet/Extensions/issues/2406): ?...于是想有没有办法在控制器被激活的时候做一些操作?没考虑引入AOP框架,感觉为了这一个功能引入AOP有点重。

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

    ASP.Net Core的Code Fist代码先行操作方法

    Asp.Net  core的Code Fist(代码先行)主要有以下几步: 1.创建实体类 2.创建数据库上下文 3.填加连接字符串 4.依赖注入 5.添加基架工具并执行初始迁移 6搭建模型的基本架构(...更具模型生成网页Page) 首先需要在创建出实体类,此处以微软官方文档中的Movice实体类为例。...options.UseSqlServer(Configuration.GetConnectionString("MovieContext"))); services.AddMvc(); } 此时生成项目如果没有任何错误就可以进行命令行操作了...Add-Migration 命令生成用于创建初始数据库架构的代码。 此架构以(Models/MovieContext.cs 文件中的)DbContext 中指定的模型为基础。...Update-Database用于将以上操作保存到数据库中(生成数据库) 搭建“电影”模型的基架 打开项目目录(包含 Program.cs、Startup.cs 和 .csproj 文件的目录)中的命令窗口

    882170

    EF 数据库连接约定(Connection String Conventions in Code First)

    一个典型的EF应用大多数情况下是一个DbContext的派生类(derived class)来控制,通常可以使用该派生类调用DbContext的构造函数,来控制以下的东西: (1)、上下文如何连接到数据库...(给定连接字符串) (2)、上下文是通过Code First语法计算模型还是使用EF 设计器 (3)、额外的高级选项 下面是DbContext构造器的常用的用途: 一、DbContext无参构造函数 如果当前...EF应用中没有做任何的配置.且在你自定义的数据库上下文类中没有调用DbContext带参的构造函数,那么当前应用对应的数据库上下文类,将会调用DbContext的默认无参的构造函数(EF默认规定的数据库连接...二、DbContext带string参数的构造函数 1、如果没有在数据库上下文进行其他额外的配置,然后调用DbContext中的带参的构造函数,传入你想要使用的数据库连接字符串,然后Code First...注:默认情况下,当前的连接字符串使用的是System.Data.SqlClilent作为provider,这里可以被改变通过做一个IConnectionFactory的不同的实现来替换context.Database.DefaultConnectionFactory

    1.5K90

    Entity Framework Core 总结

    dotnet add package Microsoft.EntityFrameworkCore.Design # migrations 命令为迁移搭建基架,以便为模型创建一组初始表 dotnet ef...如果没有数据库,则它将创建数据库和架构。 EnsureCreated 启用以下工作流来处理数据模型更改: 删除数据库。 任何现有数据丢失。 更改数据模型。...EnsureCreated 创建具有新架构的数据库。 在无需保存数据的情况下,当架构快速发展时,此工作流在早期开发过程中表现良好。 如果需要保存已输入数据库的数据,情况就有所不同了。...() 时,只有第一个有效?...A: 是的,因为 EnsureCreated() 保证数据库被创建(存在),当第一个执行后,就会有数据库、表, 所以,当后面的 EnsureCreated() 执行时,由于已经存在数据库,所以不做任何操作

    1.2K30

    Entity Framework 4.1 Code-First 学习笔记

    CodeFirst提供了一种先从代码开始工作,并根据代码直接生成数据库的工作方式。Entity Framework 4.1在你的实体不派生自任何基类、不添加任何特性的时候正常的附加数据库。...,也没有附加EF特性,在将它们添加到上下文(上下文需要派生自DbContext)中时,会自动生成相应的数据表。...Fluent API 来修改模型 为我们的模型增加标签 通过构建器来覆盖默认约定,我们需要重写 DbContext 的一个方法 OnModelCreating: protectedoverridevoid...------------------------   默认情况下,EF4.1 将类映射到表,这是约定,但是有时候,我们需要模型比表的粒度更细一些。...因此,我们可以通过从一个返回任何结果的简单查询开始,然后在其上应用 LINQ来得到有效的查询,而不需要在使用方查询整个表。

    1.6K10

    Entity Framework Core必须牢记的三条引用三条命令

    引用2:Install-PackageMicrosoft.EntityFrameworkCore.Tools 我们将使用一些实体框架核心工具来创建一个数据库从EF核心模型,所以我们通过添加这条引用来填加那些我们需要的工具包...命令一:Add-Migration InitialCreate 该命令用于为迁移搭建框架,每次模型变更后需要运行此指令,其中InitialCreate为本次变更的名字,每次必须不一样。...命令二:Update-Database 配合上一条命令使用,是实体模型的变更迁移应用到数据库中。只运行上一条命令是只生成了代码,并没有把变更更新到数据库中的,而该指令,可以理解为将变更应用到数据库。...命令三:Scaffold-DbContext"Server=(localdb)\mssqllocaldb;Database=Blogging;Trusted_ Connection=True;"Microsoft.EntityFrameworkCore.SqlServer...-OutputDir Models 该命令用于通过现有数据库生成数据模型和DBContext.其中双引号内的内容为数据库连接字符串。

    82880

    【半译】在ASP.NET Core中创建内部使用作用域服务的Quartz.NET宿主服务

    您可以使用相同的方法来管理EF Core的工作单元模式和其他面向切面的模型。 这篇文章是上篇文章引申出来的,因此,如果您还没有阅读的话,建议您先阅读上篇文章。...权宜之计 我在上一篇文章中展示的解决方案是将IServiceProvider注入到您的IJob的文档中,手动创建一个范围,并从中检索必要的服务。...如果不是这种情况,您可能会受益于创建一个可以为您管理这些工作的帮助类。...如果您不熟悉DI范围界定问题,则可能很难理解它们,因此任何对您不利的事情在我看来都是一个好主意: [DisallowConcurrentExecution] public class EmailReminderJob...中不需要做做任何特殊处理工作。

    1.9K10

    .NET Core开发实战(第26课:工程结构概览:定义应用分层及依赖关系)--学习笔记

    Web API,这一层就是定义前后端交互的接口 应用层使用了 CQRS 的设计模式,就是命令与查询职责分离,把命令放在一个目录,把查询放在一个目录,同样的这里还有两个事件处理的目录,一个是领域模型,领域事件的处理...再看一下各层之间的依赖关系 Shared 层实际上是不依赖任何层次的,它存储了共享的代码,被各个工程共享 GeekTime.Core,GeekTime.Domain.Abstractions 是不依赖任何工程的...领域模型需要继承模型的基类,并且实现一个聚合根的接口,表示它是一个聚合根 public class Order : Entity, IAggregateRoot 领域事件需要实现一个领域事件的接口...总结一下 领域模型层专注于业务的设计,它不依赖于其他各层,它是相对独立的 基础设施的仓储层仅仅负责领域模型的存取,它不负责任何的业务逻辑代码的承载 推荐使用 CQRS 的模式来设计应用程序,使应用程序的代码结构更加的合理...,在团队和项目膨胀的情况下,工程的可维护性不至于急剧的下降 Web API 是面向前端交互的接口,避免依赖领域模型 共享代码建议设计为共享包,使用私有的 NuGet 仓库来分发和管理

    52410

    EF简介

    ORM: 广义上:ORM指的是面向对象的模型和关系型数据库的数据库之间的相互转换; 狭义上:ORM可以被认为是,基于关系型数据库的数据存储,实现一个虚拟的面向对象的数据接口。 ?...之后里面是没有代码的,但是在ef4.0的时候是有的,那个时候里面存放的是数据库上下文和数据库对应的表实体,如果你需要使这个(对应ef模块名.Designer.cs文件)文件里面的文件重现,你只需要找到对应的数据库模型...,右键模型,点击属性-代码生成策略-改为默认值,就可以了,但是这会与(对应ef模块名.tt文件)文件里面的模型产生冲突. 4、系统会自动添加EntityFramework和System.Data.Entity...3、当我们在操作完数据库对应的表示表实体后,执行dbContext.SaveChanges()后,编译器报一个实体或多个实体验证失败!...这个错误的时候,大多数情况下,是我们添加的字段的数据长度超过我们数据库定义的字段的长度,或者是我们添加的字段的数据类型和数据库的字段类型不一样导致。

    1.4K80

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

    我们想分享一些我们一直在研究的有趣功能,如果没有 Microsoft .NET 数据和实体框架团队的支持和合作,这些功能是不可能实现的。...为了展示这一点,我们将向我们的模型类添加一个名为 adapted_from_book 的新可空布尔属性。...此架构的一个优点是,我们可以重用已为 DbContext 创建的 MongoClient,以利用 MongoDB 开发人员数据平台公开的其他功能。...这意味着默认情况下,SaveChanges 和 SaveChangesAsync 是事务性的。这将使生产级工作负载中的操作在发生任何故障时自动回滚,并确保所有操作都以乐观并发的方式完成。...如果您想关闭事务,您可以在调用任何 SaveChanges 操作之前的初始化阶段进行关闭。

    7310

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

    通过将复杂的 SQL 查询转换为简单的 C# 代码,EF Core 消除了处理数据的许多麻烦。但问题是 — 许多开发人员没有充分利用 EF Core 提供的强大功能。...此功能对于实施软删除、多租户或需要持续筛选的任何方案特别有用 public classAppDbContext:DbContext { protectedoverridevoidOnModelCreating...Shadow Properties:跟踪审计数据而不会弄乱您的模型 问题:需要跟踪额外信息,例如上次修改项目的时间,但又不想使实体类混乱?...它们非常适合像 or 这样的审计数据,您可能在数据库中需要这些数据,但不想成为主域模型的一部分。...LastModifiedCreatedBy 下面是一个示例: public classAppDbContext:DbContext { protectedoverridevoidOnModelCreating

    12410

    AsNoTracking

    EF默认情况下对数据的访问都是启用模型跟踪。 Entity Framework在第一次对象加载到内存中时进行一次快照,添加快照发生在返回一次查询或添加一个对象到DbSet中时。...实现扫描对比的方法是调用DbContext.ChangeTracker的DetectChanges方法。   ...Entity Framework Code First的DbContext.DetectChanges在检测实例对象的变动时,大部分情况不会有性能的问题。...但当有大量的实例对象在内存中,或DbContext有大量的操作时,自动的DetectChanges行为可能会一定程度的影响性能。...使用AsNoTracking方法查询返回无变动跟踪的Province的DbSet, 由于是无变动跟踪,所以对返回的Province集中数据的任何修改, 在SaveChanges()时,都不会提交到数据库中

    49320

    EF 约定介绍

    当前环境为EF Code First开发模式中 一、EF默认约定 1、常用约定 (1)、当没有显示指定实体主键的时候,EF会默认将长得最像Id的属性(且类型为GUID)设为主键 (2)、设计实体时,当一个实体包含一个集合属性...,该集合属性里面的元素是另一个实体时,则默认未一对多关系,即使没有显示的指定一对多的关系,EF会默认的设置主外键(主从)关系 (3)、一对一的实体关系,需要手动设置主从关系 (4)、多对多无载荷关系实体...,EF自动生成中间表,不需要新增实体来表示. (5)、表名默认复数化 2、类型发现约定(Type Discovery) 使用EF开发,往往是以定义一些模型类开始,定义完这些模型类之后,需要让DbContext...知道哪些类型包含在当前模型中,因此,我们需要自定义一个ZdyNameDbContext,并继承DbContext,并在自定义DbContext中暴露需要暴露的类型,这样在Code First开发模式中,...) Convention EF中,两个实体间的关系是通过导航属性的方式来实现,每一个对象都能拥有一个它所参与的关系的导航属性,导航属性提供了一种方式在两端来操作这个关系来获取我们需要的数据,可以返回任何一方的引用对象

    1.6K100

    Entity Framework Core 2.0 新特性

    包含定义导航的实体是所有者。当查询所有者时,默认情况下将包含所有类型。 按照惯例,将为所属类型创建一个影子主键,并通过使用表分割将其映射到与所有者相同的表。...)的查询过滤器 此功能允许在元数据模型(一般在OnModelCreating)中直接在实体类型上定义LINQ查询条件(通常传递给LINQ Where查询运算符的布尔表达式)。...这些过滤器自动应用于涉及这些实体类型的任何LINQ查询,包括间接引用的实体类型,例如通过使用Include或直接导航属性引用。...这意味着为每个请求创建一个新的DbContext实例。 所以在版本2.0中,我们引入了一种在依赖注入中注册自定义DbContext类型的新方式,它透明地引入了一个可重用的DbContext实例池。...一旦请求处理完成,实例上的任何状态都将重置,并且实例本身返回到池中。 这在思想概念上类似于ADO.NET中连接池的运作方式,并且能节省DbContext实例初始化成本。

    3.9K90

    .NET EF Core(Entity Framework Core)

    3、EF Core是 模型驱动 (Model-Driven)的开发思想,Dapper是 数据库驱动(DataBase-Driven)的开发思想的。没有优劣,只有比较。...EF Core不支持模型优先,推荐使用代码优先,遗留系统可以使用Scaffold-DbContext来生成代码实现类似DBFirst的效果,但是推荐用Code First 。...关系数据库只是盛放模型数据的一个媒介而已,理想状态下,程序员不用关心数据库的操作。 根据对象的定义变化,自动更新数据库中的表以及表结构的操作,叫做Migration(迁移)。...2、再次运行反向工程工具,对文件所做的任何更改都将丢失。 3、不建议把反向工具当成了日常开发工具使用,不建议DBFirst。...总结:如果有一个确定的字段要被进行并发控制,那么使用IsConcurrencyToken()把这个字段设置为并发令牌即可;如果无法确定一个唯一的并发令牌列,那么就可以引入一个额外的属性设置为并发令牌,并且在每次更新数据的时候

    47212

    Entity Framework Core 2.0 新特性

    一.模型级查询过滤器(Model-level query filters)   ef core2.0包含了一个新特性,我们叫他模型级查询过滤器(Model-level query filters)。...此特性允许使用Linq查询表达式直接定义在实体类型的元数据模型上。这样的过滤器会自动应用到任何LINQ查询所涉及的那些实体类型,包括间接引用的实体类型(对象引用,导航属性)。...这个特性的一些常见应用是: 软删除-定义一个 IsDeleted 属性 多租户-定义一个 TenantId 属性 示例代码: 1 public class BloggingContext : DbContext...DbContext的实例时,首先会检查是否在DbContextPool存在该类型的实例,当一次请求结束后,任何状态的DbContext实例都会被重置,且将自身加入到DbContextPool中。   ...需要在 DbContext 中定义一个静态方法,并且使用 DbFunctionAttribute 特性。

    1.9K50

    Entity Framework Core-Migrations

    使用EF Core Migrations可以使Entity & DbContext的配置与数据库保持一致,Migrations可以非常容易的将创建和更新数据库,当一个项目在开发过程中时,程序员能保证实体更新...对象,Down方法移除他们 _.Designer.cs:migration元数据文件包含DB关联的信息 ModelSnapshot.cs:当前模型的快照,用于确定在创建下一次迁移时发生了什么变化 3 Update...Migration 命令 Update Migration 命令将最新的迁移更新到数据库,如果数据库不存在,他将创建一个新的数据库,如果存在,会根据给予的迁移文件进行更新数据库 我们能运行下面2个命令的任何一个来更新数据库...Remove Migration 命令来移除最新的migration,我们移除之后的migration如果没有提交到数据库,针对这个我们能执行下面两个命令其中的任何一个: PM> dotnet ef migrations...ef database drop 或者 PM> Drop-Database 8 生成SQL 脚本 我们也能生成SQL 数据库的SQL脚本,执行下面2个命令中的任何一个来完成这个工作: PM> dotnet

    37840
    领券