前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >DDD实战进阶第一波(十二):开发一般业务的大健康行业直销系统(订单上下文POCO模型)

DDD实战进阶第一波(十二):开发一般业务的大健康行业直销系统(订单上下文POCO模型)

作者头像
用户1910585
发布2018-07-04 15:10:37
5680
发布2018-07-04 15:10:37
举报

在本系列前面的文章中,我们主要讨论了产品上下文与经销商上下文相关的实现,大家对DDD的方法与架构已经有了初步的了解。

但是在这两个界限上下文中,业务逻辑很简单,也没有用到更多的值对象的内容。从这篇文章开始,我们来讲讲订单界限上下文实现的内容,

里面的业务逻辑相对复杂一些,而且有大量值对象的引入来进行逻辑的处理。

订单上下文的需求主要是生成相应的订单项,每个订单项中有相关的订单产品和购买数量并生成订单项总额、订单项总PV,同时订单项总额

和订单项总PV会累加到订单总额和订单总PV中,同时会根据订单总额扣减当前经销商的电子币,也会根据购买产品的PV,累加当前经销商的PV值。

1.订单界限上下文的领域模型:

从上图的领域模型中,大家可以看出订单是聚合根,订单明细是聚合的实体;订单聚合根总有总价、总PV、收获地址三个值对象,订单明细实体有

明细总价、明细总PV、产品信息三个值对象。

2.明细总价值对象:

代码语言:javascript
复制
    public partial class OrderItemTotalPrice
    {
        public decimal SubTotalPrice { get; set; }
    }

3.明细总PV值对象:

代码语言:javascript
复制
 public partial class OrderItemTotalPV
    {
        public decimal SubTotalPV { get; set; }
    }

4.产品信息值对象:

代码语言:javascript
复制
 public partial class ProductSKUs
    {
        public string ProductSPUName { get; set; }
        public decimal ProductPrice { get; set; }
        public decimal ProductPV { get; set; }
        public Guid ProductSKUId { get; set; }
    }

5.订单明细实体:

代码语言:javascript
复制
 public partial class OrderItem : IEntity
    {
        public string Code { get; set; }
        [Key]
        public Guid Id { get ; set ; }

        public OrderItemTotalPrice OrderItemTotalPrice { get; set; }
        public OrderItemTotalPV OrderItemTotalPV { get; set; }
        public ProductSKUs ProductSKUs { get; set; }

        public int Count { get; set; }

    }

订单明细实体引入了OrderItemTotalPrice、OrderItemTotalPV、ProductSKUs三个值对象,同时具有自己的Code与Count两个属性。

6.订单总价对象:

代码语言:javascript
复制
 public partial class OrderTotalPrice
    {
        public decimal TotalPrice { get; set; }
    }

7.订单总PV值对象:

代码语言:javascript
复制
 public partial class OrderTotalPV
    {
        public decimal TotalPV { get; set; }
    }

8.订单收货地址值对象:

代码语言:javascript
复制
 public partial class OrderStreet
    {
       //省
        public string Privince { get; set; }
       //市
        public string City { get; set; }
       //区(县)
        public string Zero { get; set; }
       //街道地址
        public string Street { get; set; }
    }

9.订单聚合根:

代码语言:javascript
复制
 public partial class Orders : IAggregationRoot
    {
        public string Code { get; set ; }
        [Key]
        public Guid Id { get ; set; }

        public OrderStreet OrderStreet { get; set; }
        public OrderTotalPV OrderTotalPV { get; set; }
        public OrderTotalPrice OrderTotalPrice { get; set; }
        public DateTime OrderDateTime { get; set; }
        public Guid OrderDealerId { get; set; }
        public List<OrderItem> OrderItems { get; set; }
        public string Telephone { get; set; }
    }

订单聚合根引入了OrderStreet、OrderTotalPV、OrderTotalPrice三个值对象;Code、DateTime(下单时间)、Telephone(联系电话)、OrderItems(订单项实体集)等几个属性。

10.生成数据库表:

根据前面文章的说明,我们可以依据上述POCO模型生成对应的数据库表,要注意的是,OrderItems可以自动识别为Orders的关联表,其他几个值对象我们要考虑是否是生成

单独的表还是作为相关实体或聚合根的表的列存在,一般情况下,我们是将这些值对象作为相关聚合根或实体表的列存在的。EF Core无法自动处理这些值对象如何存储到数据库中,

我们需要手工指定:

代码语言:javascript
复制
 public class OrderEFCoreContext:DbContext,IOrderContext
    {
        public DbSet<Orders> Order { get; set; }
        public DbSet<OrderItem> OrderItem { get; set; }
        protected override void OnConfiguring(DbContextOptionsBuilder optionBuilder)
        {           

            optionBuilder.UseSqlServer("数据库连接字符串");
           
        }
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.Entity<Orders>().OwnsOne(p => p.OrderStreet);
            modelBuilder.Entity<Orders>().OwnsOne(p => p.OrderTotalPrice);
            modelBuilder.Entity<Orders>().OwnsOne(p => p.OrderTotalPV);

            modelBuilder.Entity<OrderItem>().OwnsOne(p => p.OrderItemTotalPrice);
            modelBuilder.Entity<OrderItem>().OwnsOne(p => p.OrderItemTotalPV);
            modelBuilder.Entity<OrderItem>().OwnsOne(p => p.ProductSKUs);
        }

从上面代码可以看出,在OnModelCreating时,可以指定6个值对象包含在对应的聚合根和实体相关的表中。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-05-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档