zoukankan      html  css  js  c++  java
  • (四).NET Core中使用OOM框架,AutoMapper的使用介绍

    (一)什么是OOM:

    OOM顾名思义,Object-Object-Mapping实体间相互转换,AutoMapper其意义在于帮助你无需手动的转换简单而又麻烦的实体间关系。

    (二)AutoMapper是什么:

    AutoMapper是基于对象到对象约定的映射工具,常用于(但并不仅限制于)把复杂的对象模型转为DTO,一般用于ViewModel模式和跨 服务范畴。

    (三)在.NET Core项目中如何使用它:

    1.通过Nuget安装AutoMapper到项目:Install-Package AutoMapper

    2.定义好Model类和DTO类:

    //Model类
    public class ProjectEntity
    {
        public int ID { get; set; }
    
        public string ProjectName { get; set; }
    
        public string ProjectImg { get; set; }
    
        public string ProjectCreateDate { get; set; }
    
        public List<ProjectTaskEntity> Tasks { get; set; }
    
    }
    //DTO类
    public class ProjectDto
    {
        public int ProjectID { get; set; }
    
        public string ProjectName { get; set; }
    
        public string ProjectImg { get; set; }
    
        public string ProjectCreateDate { get; set; }
    
        public List<ProjectTaskDto> Tasks { get; set; }
    }

    3.配置映射关系,在ConfigureServices方法中加入映射关系:

    //配置为双向映射
    CreateMap<ProjectTaskDto, ProjectTaskEntity>()
    .ReverseMap();

    4.如果Model类中的部分字段与DTO的字段不一致时,如何映射呢?

    CreateMap<ProjectDto, ProjectEntity>()
    .ReverseMap()
    .ForMember(des => des.Date, opt => opt.MapFrom(src => src.CreateTime.ToString("yyyy-MM-dd hh:mm:ss")));

    5.执行映射转换:

    //获取实体对象
    ProjectEntity _projectEntity = GetProjectsByDB(projectid);
    //将实体对象映射到DTO
    ProjectDto _projectDto = _mapper.Map<ProjectDto>(_projectEntity);

    6.如果是集合该如何转换呢?

    var ProjectEntitys = AutoMapper.Mapper.Map<List< ProjectEntity>, List< ProjectDto >>( _projectEntitys);
  • 相关阅读:
    应用程序池溢出问题
    弹窗上传图片
    第三方监测
    服务器架设方案
    python随笔录入月份的值,输出对应的季节
    用python计算直角三角形斜边长
    返回(统计)一个列表中出现次数最多的元素
    使用random函数实现randint函数的功能
    Spring
    ng build prod basehref /javaweb/angular/
  • 原文地址:https://www.cnblogs.com/NBIDataVis/p/11791874.html
Copyright © 2011-2022 走看看