• 简单使用AutoMapper实现DTO转换


      DTO(Data Transfer Object)数据传输对象,只是传输数据,完成与领域对象之间的转换,并不包含领域业务处理。
      当领域模型设计人员只关注核心业务,满足于领域模型的精巧,而不关心具体实现的时候,DTO就会大量出现。

      系统复杂化后,DTO可能是多个Domain Model组合实现。

      为什么要使用DTO?
      1、隔离Domain Model,使改动领域模型而不影响UI,保持领域模型的安全,不暴露业务逻辑。
      2、在分布式模式下,不同的场景使用相同的数据结构有不同的需求。

      简单示例:

      Order.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace AppExample
    {
        public class Order
        {
            public int OrderID { get; set; }
    
            public string OrderNumber { get; set; }
    
            public DateTime OrderDate { get; set; }
        }
    }

      OrderDTO.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace AppExample
    {
        public class OrderDTO
        {
            public int OrderID { get; set; }
    
            public string OrderNumber { get; set; }
    
            public DateTime OrderDate { get; set; }
    
            public int OrderYear { get; set; }
        }
    }

      Program.cs

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace AppExample
    {
        class Program
        {
            static void Main(string[] args)
            {
                Order order = new Order
                {
                    OrderID = 1,
                    OrderNumber = "201406040001",
                    OrderDate = DateTime.Now
                };
    
                AutoMapper.Mapper.Initialize(cfg =>
                {
                    cfg.CreateMap<Order, OrderDTO>()
                        .ForMember(dest => dest.OrderYear, opt => opt.MapFrom(src => src.OrderDate.Year));
                });
    
                OrderDTO orderDTO = AutoMapper.Mapper.Map<Order, OrderDTO>(order);
    
                Console.WriteLine("{0}-{1}-{2}-{3}", orderDTO.OrderID, orderDTO.OrderNumber, orderDTO.OrderDate, orderDTO.OrderYear);
            }
        }
    }
  • 相关阅读:
    mysql下载与安装
    Observable Flowable Test
    Linux 技巧:让进程在后台可靠运行的几种方法
    CallBack
    Linux内存分析
    Linux安装svn
    百度地图api
    安装Mysql官方的sakila数据库
    yii2 展示静态页面
    yii2 手动安装第三方扩展
  • 原文地址:https://www.cnblogs.com/libingql/p/3768581.html
Copyright © 2020-2023  润新知