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里面的信息做如下修改:
执行成功 如下:
再执行脚本 成功如下: