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

EntityFramework Core 学习扫盲

虽然我们目前还没有添加任何约束,但是EF Core会自动地根据Id/XXId的命名方式生成自增主键,而且如果没有在实体上增加[Table]Attribute的话,表的命名也是根据属性命名而定。...假如导航属性中存在对其他实体的引用,那么即便不把被引用实体配置为显式引用,被引用实体也可以隐式地映射到数据库中。 如以下代码所示。...Blog实体包含对Post实体的引用,而独立的AuditEntry则可以在OnModelCreating方法中进行配置。...通过以下两种配置方式,在运行了迁移命令后,BlogMetadata实体是不会映射到数据库中的。 1....在Fluent Api中,有两种方法可以指定备用键,一种是当开发者将实体中的属性作为另一个实体的外键目标,另一种是手动指定。EF CORE的默认约束是前者。

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

    ASP.NET MVC5高级编程——(3)MVC模式的模型

    首先数据库中主外键的定义: 主键 外键 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 作用: 用来保证数据完整性 用来和其他表建立联系用的...5 什么是实体框架,什么是代码优先和数据上下文? 新建的ASP.NET MVC5项目会自动包含对实体框架(EF)的引用。...这个MvcMusicStoreDB是继承了DbContext,其作用概括来说:对模型类的修改会反映到数据库中,反之亦然,对数据库的修改也会反映到模型类中。EF实体框架会使用数据迁移来帮我们完成。...4.执行基架代码 4.1用实体框架创建数据库--local-DB虚拟数据空间 EF框架的代码优先方法会尽可能地使用约定而非配置(即MVC中的约定优于配置)。...如果删除了这个表,就需要我们自己来维护数据库模式的修改。 4.2使用数据库初始化器--每次插入初始数据-方便项目测试 保持数据库和模型变化同步的一个简单方法是允许实体框架重新创建一个现有的数据库。

    4.8K40

    EF Core关系配置

    获取指定字段 var a1 = dbContext.Articles.Select(x => new {x.Id, x.Title}).First(); 只获取外键id 1、在实体类中显式声明一个外键属性...实体的状态: 已添加(Added):DbContext正在跟踪此实体,但数据库中尚不存在该实体。...已删除(Deleted):DbContext正在跟踪此实体,并存在于数据库中,但在下次调用 SaveChanges 时要从数据库中删除对应数据。...) 更新到数据库; “已删除”的实体,SaveChanges() 从数据库删除; 查看实体的状态: 使用DbContext的Entry()方法来获得实体在EF Core中的跟踪信息对象EntityEntry...DbContext会根据跟踪的实体的状态,在SaveChanges()的时候,根据实体状态的不同,生成Update、Delete、Insert等SQL语句,来把内存中实体的变化更新到数据库中。

    13110

    张高兴的 Entity Framework Core 即学即用:(一)创建第一个 EF Core 应用

    Scaffold-DbContext 顾名思义译为“数据库上下文脚手架”,通过此命令生成实体类和数据库上下文。...安装完成后,打开 Visual Studio 中的 工具 - NuGet 包管理器 - 程序包管理器控制台 执行以下命令: 切换到项目 : 运行实体类生成命令 ,该命令的详细参数请参考 :  提示...当主键是自增键时,还需要设置 DatabaseGenerated() Attribute。...在设置导航属性之前,首先需要理清楚医院和医生存在着怎样的数量关系,医生是医院的附属,一家医院下面会有多名医生,因此医院和医生之间是一对多的关系。为了方便理解,下面只保留主键、外键和导航属性。...为了在程序中访问数据库 pandemic,使数据库表与创建的 C# 实体类建立映射,需要创建一个数据库上下文类 PandemicContext.cs,该类派生自 Microsoft.EntityFrameworkCore.DbContext

    2.5K10

    02-EF Core笔记之保存数据

    Core中,除了独立的模型外,还有与模型关联的数据,这部分数据通过独立模型添加到模型中,在SaveChanges时将会持久化到数据库中。...,只需将Post对象中的Blog引用设置为null即可,此时EF Core将判断是否为必须关系,如果为必须关系,则从数据库中删除Post对象,如果为非必须关系,则将数据库中对应的外键设置为null。...级联删除 级联删除是数据库的概念,意思是当主体被删除时,所有依赖该主体的项(通过外键关联)也会被自动删除。...在关系数据库上,EF Core 会对任何 UPDATE 或 DELETE 语句的 WHERE 子句中的并发令牌值进行检查。 执行这些语句后,EF Core 会读取受影响的行数。...,随后再由客户端提交到服务器端,此时实体所在的DbContext已发生变化,如何判断对实体进行更新或添加就成了一个问题。

    1.8K40

    C# 数据操作系列 - 5. EF Core 入门

    0.前言 上一章简单介绍了一下ORM框架,并手写了一个类似ORM的工具类。这一章将介绍一个在C#世界里大名鼎鼎的ORM框架——Entity Framework的Core版。...在直接使用通过EF获取的元素时,EF会自动跟踪哪些字段发生了变化,当手动调用保存的时候,EF就会把数据回传给数据库。...可以延迟加载需要的数据,外键引用属性、查询结果等 丰富的映射关系,支持一对一,一对多,多对多,甚至继承、单表多实例等 可以使用Linq 进行查询 非Core版的可以通过数据库表生成实体类,两种都可以通过实体类生成表...接下来,添加 EF的SQLite包: 在非Visual Studio环境下,安装一个三方库可以使用: dotnet add package Microsoft.EntityFrameworkCore.Sqlite...如果是使用的已有数据的数据库,则不需要进行下面的步骤,否则建议执行以下步骤,以便可以由EF Core提供的工具生成数据库: 在 NuGet的控制台界面,输入以下命令: Install-Package Microsoft.EntityFrameworkCore.Tools

    2.6K10

    EF简介

    ,不管你添加什么样的数据库实体,都会自动继承Dbcontext这个类,所以Dbcontext:这个类就是实现关系型数据库和面线对象交互的通用数据接口。...两个引用....dbContext.SaveChanges();//告诉上下文把所有标记了的实体映射回数据库,也就是把所有标记为modified都生成update语句到数据库里面去执行 注意上面这段代码,上面的添加操作能正常完成...而里面的值就是我们刚才所添加的值,说明在我们执行完数据库添加操作之后,数据库里面的数据马上将我们所添加的数据马上映射给了当前的实体对象,所以当我们在下面指定需要修改的记录的主键时,如果修改和添加共用同一个对象...3、当我们在操作完数据库对应的表示表实体后,执行dbContext.SaveChanges()后,编译器报一个实体或多个实体验证失败!

    1.4K80

    开源EFCore 对比实体与实际数据库结构的工具-GZY.EFCoreCompare

    读取代码中的 DbContext 及其 EntityType 实体定义。 对比两者的字段、表、主键、索引等内容。 检测并生成对应的报表 发现 数据库中有但代码中没有的表(可能需要删除)。...发现 代码中有但数据库中缺失的表或字段(可能需要添加)。 发现 数据类型、索引、约束等的差异(可能需要修改)。 帮助团队进行数据库变更管理 在开发过程中,避免数据库和代码模型不同步。...可用于 自动化 CI/CD 流水线,在部署前发现问题。 可用于 部署/更新后判断数据库是否标准,在部署后发现客户或线上的问题。...读取代码中的 DbContext 解析代码中的 DbContext 及其实体。 比对两者的差异 找出 表、字段、类型、索引、主键、外键 等方面的不同。...集成图形化UI到项目中,进行持久化比对 在Web(MVC Raroz)或WebApi项目中通过Nuget引用GZY.EFCoreCompare.UI与对应的数据库驱动,例如:GZY.EFCoreCompare.MySql

    5610

    【愚公系列】2023年02月 .NETC#知识点-使用控制台手搭webapi框架

    文章目录 前言 一、使用控制台手搭webapi框架 1.配置文件 2.控制台配置 二、EFCore框架DBSet配置详解 1.实体统一配置 2.实体继承统一接口 3.获取程序集所有类 4.批量注入模型类到...EF中 三、EFCore框架表配置详解 1.配置基类, 2.实体表统一配置 3.DBContext中应用配置 四、仓储配置 1.仓储基类 2.仓储实现类 五、Autofac配置 1.注入DBContext...它可以用于处理数据,访问数据库,处理图像和视频,以及进行其他高级功能。...三、EFCore框架表配置详解 1.配置基类, 创建一个配置基类,继承自IEntityTypeConfiguration,做一些通用的配置,比如设置主键,软删除等。...(x => x.Books) .HasForeignKey(r => r.UserId).IsRequired(false);//导航属性,本质就是创建外键,虽然查询很方便,生产中不建议使用

    1.5K10

    EF 约定介绍

    知道哪些类型包含在当前模型中,因此,我们需要自定义一个ZdyNameDbContext,并继承DbContext,并在自定义DbContext中暴露需要暴露的类型,这样在Code First开发模式中,...) Convention EF中,两个实体间的关系是通过导航属性的方式来实现,每一个对象都能拥有一个它所参与的关系的导航属性,导航属性提供了一种方式在两端来操作这个关系来获取我们需要的数据,可以返回任何一方的引用对象...除了导航属性规定实体间的关系外,外键属性来式规定实体间方式的一种手段.Code First能够推断以下的命名属性为外键(优先级从上到下): (1)、导航属性名+关联实体的主键名 (2)、关联实体实体名+...关联实体的主键名 (3)、关联实体的主键名 注: (1)、当外键关系被检测到,Code First会根据外键的可空性来推断关系的具体形式;如果外键属性是可空的,那么关系会被设置为可选的,否则,关系就是必选的.... (2)、当关联实体的外键属性被设置为不为空,Code First会设置级联删除,反之不会。

    1.6K100

    Entity Framework Core 2.0 入门

    因为: 在遍历开始的时候, 数据库连接打开, 并且会一直保持打开的状态, 直到遍历结束. 所以如果这个遍历很耗时, 那么可能会发生一些问题. 最好的办法还是首先执行ToList, 然后再遍历....删除数据. DbContext只能删除它追踪的model....非常简单, 从log可以看到, 删除动作只用到了主键: 如果是删除的离线model, 那么Remove方法首先会让Dbcontext追踪这个model, 然后设置状态为Deleted....插入关联数据有几种情况: 1.直接把要添加的Model的导航属性附上值就可以了, 这里的Department不需要写外键....这时, 因为该数据是被context追踪的, 所以只需在它的导航属性添加新记录, 然后保存即可. 3.离线数据添加导航属性. 这时候就必须使用外键了. 预加载关联数据 Eager Loading.

    3.2K80

    .NET EF Core(Entity Framework Core)

    程序包管理器控制台”中执行命令:Add-Migration InitialCreate,会自动在项目的Migrations文件夹中中生成操作数据库的C#代码。...3、代码需要执行后才会应用对数据库的操作。...“程序包管理器控制台”中执行Update-database 4、查看一下数据库,表建好了 反向工程 1、根据数据库表来反向生成实体类 2、Scaffold-DbContext 'Server=....OutputDir”参数的形式来在同一个项目中为不同的数据库生成不同的迁移脚本 小结: 1、使用迁移脚本,可以对当前连接的数据库执行编号更高的迁移,这个操作叫做“向上迁移”(Up),也可以执行把数据库回退到旧的迁移...(); 2、删除也是先把要修改的数据查询出来,然后再调用DbSet或者DbContext的Remove方法把对象删除,然后再执行SaveChangesAsync()保存修改。

    47312

    Entity Framework Core 2.0 新特性

    此特性允许使用Linq查询表达式直接定义在实体类型的元数据模型上。这样的过滤器会自动应用到任何LINQ查询所涉及的那些实体类型,包括间接引用的实体类型(对象引用,导航属性)。...局限性: 过滤器只能在层次结构的根实体类型上定义 过滤器不允许使用导航属性进行过滤(可以根据反馈添加此功能。)...在 ef core 2.0 中,我们将自定义的DbContext类型注册到DbContextPool服务中,可让该数据库上下文类型的实例重复使用。...的实例时,首先会检查是否在DbContextPool存在该类型的实例,当一次请求结束后,任何状态的DbContext实例都会被重置,且将自身加入到DbContextPool中。   ...要使用表拆分,必须在共享表的所有实体类型之间配置标识关系(外键属性构成主键) 示例代码: 1 modelBuilder.Entity() 2 .HasOne(e => e.Details

    1.9K50

    Entity Framework Core 2.0 入门

    因为: 在遍历开始的时候, 数据库连接打开, 并且会一直保持打开的状态, 直到遍历结束. 所以如果这个遍历很耗时, 那么可能会发生一些问题. 最好的办法还是首先执行ToList, 然后再遍历....删除数据. DbContext只能删除它追踪的model....非常简单, 从log可以看到, 删除动作只用到了主键: 如果是删除的离线model, 那么Remove方法首先会让Dbcontext追踪这个model, 然后设置状态为Deleted....插入关联数据有几种情况: 1.直接把要添加的Model的导航属性附上值就可以了, 这里的Department不需要写外键....这时, 因为该数据是被context追踪的, 所以只需在它的导航属性添加新记录, 然后保存即可. 3.离线数据添加导航属性. 这时候就必须使用外键了. 预加载关联数据 Eager Loading.

    3.5K140

    C# 数据操作系列 - 8. EF Core的增删改查

    而删除,如果在配置导航属性时,没有设置级联删除,删除当前元素,如果另一端的外键是可空类型的,并不会删除导航属性另一端的元素只会设置外键指向为NULL,如果另一端外键是不可空的,那么就会同时删除。...: 行为名称 对内存中的依赖项/子项的影响 对数据库中的依赖项/子项的影响 Cascade 删除实体 删除实体 ClientSetNull(默认) 外键属性设置为 null None SetNull 外键属性设置为...null 外键属性设置为 null Restrict None None 而对于不可为NULL的外键来说,枚举DeleteBehavior的值起以下作用: 行为名称 对内存中的依赖项/子项的影响 对数据库中的依赖项...如果使用的Linq表达式,则没关系,EF Core在遇到这种情况的时候,会把数据库里所有数据都加载到上下文中,再执行后续的查询等操作。...待EF Core篇完成后,将带领一起去探索 Nhibernate和Dapper,SqlSugar这三个ORM框架。

    3.2K20

    .NET ORM 的 “SOD蜜”--零基础入门篇

    一、准备工作 1.1,添加SOD包引用 首先建立一个控制台项目(支持.NET2.0的项目),并使用程序包管理器添加PDF.NET SOD的程序引用: PM> Install-Package PDF.NET.SOD...UserID的自增列,每当插入实体类后,可以通过该自增列对应的属性获取到新插入的自增ID的值。...可以看到,SOD实体类还是比较简单的,它没有使用特性来申明数据库信息,这意味着你可以在运行时修改实体类影射的主键,自增字段,表名称等数据库元数据,并且不需要反射,这些特性构成了SOD框架简单而强大的基础...1.4,添加查询对象的数据上下文 在项目中添加一个 LocalDbContext.cs 文件,文件中添加如下代码,以便检查表 Tb_User 是否存在,如果不存在,则自动创建一个: /// 删除数据 首先删除之前的测试数据,可以采用OQL进行批量数据删除: int count = 0; //删除 测试数据--------------------------------------

    1.2K70

    非典那年记忆

    课程内容主要步骤记录:  【】所包含的是对应项目名 1、生成项目 abp new   ,并编译全部 2、修改连接字符串: 【DbMigrator】修改连接字符串,并执行这个项目,就实现数据库的创建和写入种子数据...它是整个解决方案共用的类型 5、在DBContext中注册实体类 【EFCore】中,DbContext中添加DbSet  books;                             ...DbContextModelCreatingExtensions 中添加表名,表属性,外键关系的配置 ?...类中注入 Repository  和 GuidGenerator类型的两个对象,  借助它们来添加种子数据——三本书的信息Book 8、执行【DbMigrator】,更新数据库 不明白为什么第...17、添加国际化的内容 【Domain.shared】中添加对应的键的显示内容!

    96420

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

    数据模型控制: 开发者可以通过代码完全控制数据模型,包括添加、修改或删除实体和属性。...创建DbContext类。 配置实体模型。 打开数据库连接。 以下是一个简单的示例,演示了如何使用EF Core连接到数据库: 首先,确保已经安装了适当的数据库提供程序包。...下面是如何使用 EF Core 数据迁移的步骤: 添加迁移:使用 Add-Migration 命令添加新的迁移记录。这个命令会创建一个新的迁移类,并将其添加到迁移历史记录中。...# 在包管理器控制台中执行以下命令 Add-Migration "MyMigrationName" 应用迁移:使用 Update-Database 命令将新的迁移应用到数据库中。...确保在使用不同数据库的情况下,为每个 DbContext 配置正确的连接字符串。此外,不同的数据库可能需要不同的迁移和配置设置。在执行迁移时,你需要针对每个数据库单独运行迁移命令。

    62300
    领券