zoukankan      html  css  js  c++  java
  • 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里面的信息做如下修改:

    执行成功 如下:

     再执行脚本 成功如下:

  • 相关阅读:
    从web图片裁剪出发:了解H5中的Blob
    玩一把JS的链式调用
    JavaScript中你所不知道的Object(二)--Function篇
    JavaScript中你所不知道的Object(一)
    从Object和Function说说JS的原型链
    angular之scope.$watch
    CSS3动画效果之animation
    CSS3动画效果之transition
    CSS3弹性盒模型 display:box
    WPF 时间编辑控件的实现(TimeEditer)
  • 原文地址:https://www.cnblogs.com/wholeworld/p/8776617.html
Copyright © 2011-2022 走看看