DDD实战3 领域层的设计

1.新建一个解决方案文件夹 取名Product

2.在Product解决方案文件夹下面创建一个.net core 类库项目 取名Product.Domain,引用项目DDD.Base项目

3.在类库下面新建一个文件夹 取名POCOModels,在这个文件夹下面新建两个partial的类 分别取名ProductSPU和ProductSKU

4.新建一个IProductContext的接口

/// <summary>
    /// 上下文接口,之所以创建这个接口是因为,在本例子中会使用EFCore的上下文接口,但是以后也可能用别的接口
    /// </summary>
    public interface IProductContext
    {
    }

5新建一个ProductEFCoreContext的类,在这个类中创建两个属性DbSet<ProductSPU> ProductSPU 和 DbSet<ProductSKU> ProductSKU

   因为当前项目引用的DDD.Base项目安装了EntityFrameWorkCore.SqlServer 所以当前项目默认带了DbSet

//注意这里继承了DbContext
    public class ProductEFCoreContext:DbContext,IProductContext
    {
        public DbSet<ProductSKU> ProductSKU { get; set; }
        public DbSet<ProductSPU> ProductSPU { get; set; }

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlServer("Server=localhost;DataBase=DDD1DB;User Id=sa;Password=0");
        }
    }
    //干完上面这个就要就对应的项目生成数据库脚本
    //dotnet ef migrations add InitialCreate
    //然后
    //dotnet ef database update

6.生成数据库,记住要安装两个包EntityFrameWorkCore.SqlServer 和 EntityFrameWorkCore.SqlServer.Tools。此外还要修改一下csproj文件。此处安装EntityFrameWorkCore.SqlServer 我觉得有点像是一个BUG

7.创建一个Models文件夹 在其中新建ProductSPU和ProductSKU 的另外两个Partial 注意命名空间要修改一致。在这两个类中分别创建两个创建当前类的方法。

8.关从上下文生成数据库要注意的 是:生成数据库使用的两行命令,不是在nuget控制台中执行的,而应该是进入类库项目所在文件夹 然后cmd出控制台,在控制台中国使用两行命令生成数据库(先生成迁移脚本,再执行迁移脚本)

9.因为重装系统,安装了新的vs,进行步骤8的时候 有报错如下:

面对这个问题的解决方法是 将csproj里面的信息做如下修改:

执行成功 如下:

 再执行脚本 成功如下:

原文地址:https://www.cnblogs.com/wholeworld/p/8776617.html