EF core 的一些理解

  • ORM框架
  1. 概念:ORM是对象关系映射模型为了解决面向对象与关系数据库互不匹配的现象技术。Orm框架是连接数据库的桥梁。
  2. 几种ORM:EF core,Dapper,SQLSugar,FreeSql等
  3. EF core与其他ORM的比较:
  1. EF core 是微软官方的ORM框架。

优点:功能强大,官方支持,生产效率高,力求屏蔽底层数据库差异;缺点:复杂,上手门槛高。

  1. Dapper:优点:简单,N分钟即可上手,行为可预期性强;缺点:生产效率低,需要处理底层数据库差异。
  2. EF Core 是模型驱动开发的思想,Dapper是数据库驱动的开发思想。
  1. EF core 而EF 比较

EF 有DB First,ModelFirst,Code First,EF Core不支持模型优先,推荐使用代码优先,遗留系统可以使用Scaffold-DbContext来生成代码实现类似DBFirst的效果,但是推荐使用Code First。

EF会对实体上的标注做校验,EF Core追求轻量化,不校验。

熟悉EF的话,比较容易操作EF Core,EF Core增加了很多的新东西。

EF 不在做新特性增加。

  • 用什么数据库

EF core是对于底层ADO.NET Core的封装,因此ADO.NET Core支持的数据不一定被EF Core支持。

EF core支持所有主流的数据库,包括MS SQL Server,MySQL,PostgreSQL,SQlite等,可以实现Provider支持其他数据库。

对于SQLServer支持是最好的,MySQL,Postgresql也行。

  • EF core环境的搭建
  1. 先建实体类

  1. 创建实现IEntityTypeConfiguration接口的实体配置类,配置实体类和数据库表的对应关系。

  1. 创建一个继承DbContext的类

UseSqlServer(数据库的连接字符串图中是连接一个叫demol的数据库)我这里使用的是SQL server数据库;

  1. 再在“程序包管理器控制台”中执行如下命令Add-Migration InitialCreate会自动在项目的Migrations文件夹中生成操作数据库的C#代码。(先添加Microsoft.EntityFrameworkCore.Tools依赖包)

Microsoft.EntityFrameworkCore.Tools可以执行的命令。

注意框架包的版本,我用的是.NET5的框架。

然后在视图--其他窗口—程序包管理器控制台,找到程序包管理器控制台输入Update-database。(就可以在数据库中的demol找到表了);

Migrations文件:面对对象的ORM开发中,数据库不是程序员手动创建的,而是由Migrations工具生成。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EF Core 触发器是在保存数据到数据库之前或之后执行的自定义逻辑。它们可以用于在数据更改发生时执行额外的操作,例如验证、日志记录或更新相关数据。 在 EF Core 中,可以使用 NuGet 软件包 EntityFrameworkCore.Triggered 来实现触发器功能。该软件包提供了一组接口和类,用于定义和注册触发器,并在适当的时机执行它们。 以下是一个示例,演示如何使用 EF Core 触发器: 1. 首先,安装 EntityFrameworkCore.Triggered NuGet 软件包: ```shell dotnet add package EntityFrameworkCore.Triggered ``` 2. 创建一个触发器类,实现 IBeforeSaveTrigger 或 IAfterSaveTrigger 接口,并实现相应的方法。例如,以下是一个在保存之前执行的触发器: ```csharp using EntityFrameworkCore.Triggered; public class MyBeforeSaveTrigger : IBeforeSaveTrigger<MyEntity> { public Task BeforeSave(ITriggerContext<MyEntity> context, CancellationToken cancellationToken) { // 在保存之前执行的逻辑 return Task.CompletedTask; } } ``` 3. 在 DbContext 中注册触发器。例如,以下是一个 DbContext 类的示例: ```csharp using EntityFrameworkCore.Triggered; public class MyDbContext : DbContext { protected override void OnModelCreating(ModelBuilder modelBuilder) { // 注册触发器 modelBuilder.Entity<MyEntity>() .HasBeforeSaveTrigger<MyBeforeSaveTrigger>(); } } ``` 通过以上步骤,你可以定义和注册 EF Core 触发器,并在保存数据到数据库之前或之后执行自定义逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值