EFCore搭建环境

我们先用modlefrist的方法

概念:Migration(咩个卫生)数据库迁移
面向对象的ORM开发中,数据库不是程序员手动创建的,而是由Migration工具生成的。关系数据库只是盛放模型数据的一个媒介而已,理想状态下,程序员不用关心数据库的操作。
根据对象的定义变化,自动更新数据库中的表以及表结构的操作,叫做Migration(迁移)。
迁移可以分为多步(项目进化),也可以回滚。
 

1、经典步骤:建实体类;

   public  class Book
    {
        public int Id { get; set; }

        public string  bookname  { get; set; }

        public string CreatName { get; set; }
        public DateTime DateTime { get; set; }

    }

2.建一个配置实体类(可以不建后面会说)

 public   class BookConfig :IEntityTypeConfiguration<Book>
    {
        public void Configure(EntityTypeBuilder<Book> builder)
        {

            builder.ToTable("T_Books");//要创建的表名
        } 

    }


3.建DbContext;生成数据库;

 public   class MyDbContext :DbContext
    {
        //实体的类对应一个表
        public DbSet<Book> Books { get; set; }

        //在 OnConfiguring方法中写好连接字符串
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            base.OnConfiguring(optionsBuilder);
            optionsBuilder.UseSqlServer("server=.;Database=Vip; user id=sa; Password=123456");
        
        }
        //从指定的程序集里加载所有的IEntityTypeConfiguration(也就是那个配置实体类)加载配置
        protected override void OnModelCreating (ModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
            modelBuilder.ApplyConfigurationsFromAssembly(this.GetType().Assembly);

        }

    }

4.安装EFcore依赖

在程序包管理控制台输入以下安装命令

Install-Package Microsoft.EntityFrameworkCore.SqlServer

为了使用生成数据库的工具,要安装

Microsoft.EntityFrameworkCore.Tools ,否则执行Add-Migration等命令会出现错误

或者去NuGei包管理器下载
 

5.执行Migration命令

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


2、代码需要执行后才会应用对数据库的操作。“程序包管理器控制台”中执行Update-database

3、查看一下数据库,表建好了。

附加: 如果要添加一个表的其他列就直接在实体类里添加属性

然后执行Add-Migration xxxx ; xxxx是生成在migration文件夹里的生成数据库的代码!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值