我的编程空间,编程开发者的网络收藏夹
学习永远不晚

.NET中实现对象数据映射示例详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

.NET中实现对象数据映射示例详解

前言

对象数据映射即将一个对象的数据根据特定规则批量映射到另一个对象中,减少手工操作和降低人为出错率。如将 DTO 对象和 Entity 实体相互转换映射。

示例

在我们平常表单提交中,我们通常会定义一个DTO让用户填写一些必须的信息而并不是将数据库所有的字段罗列让用户填写,在过去我们需要如何操作:

// 数据库User表
public class User 
{
    public int UserId { get; set; } // 用户编号
    public string UserName { get; set; } // 用户名称
    public int Age { get; set; } // 年龄
    public DateTime? CreateAt { get; set; } // 创建时间
    public int CreateBy { get; set; } // 创建人
    public DateTime Birthday { get; set; } // 生日
}

如上数据库表设计,我们用户编号、创建时间、创建人、包括年龄都是系统计算或者系统生成的,可能提供给用户填写的数据只有名称和生日:

public class UserRequestDto 
{
    public string UserName { get; set; }
    public DateTime Birthday { get; set; }
}

在以前我们应该这样处理

public async Task Create(UserRequestDto request) 
{
    // 实例化一个User实体,并且将用户填写内容一个一个赋值
    User user = new User();
    user.UserName = request.UserName;
    user.Birthday = request.Birthday;
    user.CreateAt = DateTime.Now;
    ....
    // 创建用户
    await context.User.InsertAsync(user);
}

问题: 如果很多地方需要这样的赋值操作,那么将有非常多的代码冗余,而且如果字段过多非常容易出错,操作效率极低。

有了如上问题,我们实现自动映射的需求就出现了,在C#中有比较优秀的对象映射工具 MapsterAutoMapper,据说 Mapster 使用简单且性能高。

Mapster 使用

Mapster 是一个使用简单,功能强大,性能极佳的对象映射框架。与 AutoMapper 相比在速度和内存占用方面表现更加优秀,可以在只使用1/3内存的情况下获得4倍的性能提升。

MethodMeanStdDevErrorGen 0Gen 1Gen 2Allocated
'Mapster 6.0.0'108.59 ms1.198 ms1.811 ms31000.0000--124.36 MB
'Mapster 6.0.0 (Roslyn)'38.45 ms0.494 ms0.830 ms31142.8571--124.36 MB
'Mapster 6.0.0 (FEC)'37.03 ms0.281 ms0.472 ms29642.8571--118.26 MB
'Mapster 6.0.0 (Codegen)'34.16 ms0.209 ms0.316 ms31133.3333--124.36 MB
'ExpressMapper 1.9.1'205.78 ms5.357 ms8.098 ms59000.0000--236.51 MB
'AutoMapper 10.0.0'420.97 ms23.266 ms35.174 ms87000.0000--350.95 MB

如上为官方提供的性能测试表格,当然还是根据个人喜好选择,具体测试结果也仅供参考,大家也可以自行研究选择。

安装Nuget包

  • 映射到一个新的对象
// 一行代码搞定,就是这么神奇
User user =  request.Adapt<User>();

  • 在EFCore中使用 (Mapster 提供了对 IQueryable 的映射扩展)

在EFCore中查询所需要的格式我们通常使用Select实现

context.User.Select(x => new UserDto 
{
    UserName = x.UserName,
    Age = x.Age
    ...
    ...
})

使用 ProjectToType 映射到目标类型

var result = context.User.ProjectToType&lt;UserDto&gt;().ToList();
  • 自定义映射

在某些特殊情况下当我们源属性类型和目标属性名称不对应的时候我们可以进行自定义映射关系

// 在数据映射时,将出生日期通过计算方法映射给返回的Age
TypeAdapterConfig<User, UserDto>
    .NewConfig()
    .Ignore("Id")//指定忽略某些字段
    .Map(dest => dest.Age,
         class="lazy" data-src => CalcAge(class="lazy" data-src.Birthday));
  • 在某些情况下,如果需要在 依赖注入(DI)使用,Mapster提供了IMapperandMapper
public void ConfigureServices(IServiceCollection services)
{
    var config = new TypeAdapterConfig();
    services.AddSingleton(config);//使用单例注册
    services.AddScoped<IMapper, ServiceMapper>();//注册服务
}
// Service进行依赖注入
private readonly IMapper _mapper;
public UserService(IMapper mapper) {
    _mapper = mapper;
}
public void Create(UserRequestDto request) {
    // 使用服务
    var user = _mapper.Map<User>(request);
}
  • 数据类型转化
decimal i = 123.Adapt<decimal>();// int转换成decimal
var e = "Read, Write, Delete".Adapt<Enum>(); // 枚举

总结

使用 Mapster 能让我们在处理尤其是 Entity 与 DTO 之间数据相互映射,如果手动映射会导致效率差,代码冗余, Mapster的优势还是非常明显的,当然也不是说 AutoMapper 就非常拉跨,大家根据自己的需求选择即可。

以上就是.NET中实现对象数据映射示例详解的详细内容,更多关于.NET对象数据映射的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

.NET中实现对象数据映射示例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

.NET中实现对象数据映射示例详解

这篇文章主要为大家介绍了.NET中实现对象数据映射示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

PHP 对象关系映射与数据库抽象层中对象-关系映射的最佳实践

php 对象关系映射 (orm) 最佳实践包括命名一致性、适当映射、注释、避免硬编码、利用查询生成器和监视数据库架构更改。实操案例中,doctrine orm 框架可用于连接 mysql 数据库并查询数据,需要配置数据库连接并使用查询生成器
PHP 对象关系映射与数据库抽象层中对象-关系映射的最佳实践
2024-05-06

PHP 对象关系映射与数据库抽象层中多数据库支持的实践

使用 php 进行多数据库支持,可以使用 orm(对象关系映射)和 dal(数据库抽象层)工具。orm 示例:doctrine 允许通过配置连接参数支持多个数据库,例如 mysql 和 postgresql。dal 示例:propel 可以
PHP 对象关系映射与数据库抽象层中多数据库支持的实践
2024-05-07

Python面向对象实现数据分析的实例详解

这篇文章主要通过几个实例为大家详细介绍了Python面向对象实现数据分析的方法,文中的示例代码讲解详细,对我们学习Python有一定帮助,需要的可以参考一下
2023-01-03

PHP 对象关系映射与数据库抽象层中的数据分页和排序最佳实践

在大型 php 应用程序中,数据分页和排序至关重要。最佳实践包括使用 orm 和 dal 中的 limit 子句和偏移量实现分页,使用 order by 子句和排序器类实现排序。1. 分页:使用 limit 子句限制行数,用 offset
PHP 对象关系映射与数据库抽象层中的数据分页和排序最佳实践
2024-05-06

PHP 对象关系映射与数据库抽象层在现代 Web 开发中的演变

php 中 orm 与 dal 的演变:orm 将数据库表映射为 php 对象,简化了操作,但可能影响性能和灵活性。dal 提供数据库操作的抽象,增强了可移植性,但会增加接口复杂度和降低效率。orm 例如 laravel eloquent
PHP 对象关系映射与数据库抽象层在现代 Web 开发中的演变
2024-05-06

Blob对象实现文件上传下载示例详解

这篇文章主要为大家介绍了Blob对象实现文件上传下载示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-04

PHP 对象关系映射与数据库抽象层中的常见陷阱和解决方案

PHP 对象关系映射与数据库抽象层中的常见陷阱和解决方案陷阱 1:延迟加载的问题当使用延迟加载策略时,在访问实体的属性或方法之前,需要先加载整个实体。这可能会导致意想不到的性能问题,尤其是在处理大型数据集时。解决方案:谨慎使用延迟加载
PHP 对象关系映射与数据库抽象层中的常见陷阱和解决方案
2024-05-06

MySQL实现数据更新的示例详解

目录一、方法分类二、具体用法(1)根据条件更新值(2)按照不同条件(批量)更新不同值三、实例(1)根据条件更新值(2)按照不同条件更新不同值一般在更新时会遇到以下场景:1.所有字段全部更新;2.根据条件更新字段中的某部分内容;3.根据
2023-02-08

使用JDBC实现数据访问对象层(DAO)代码示例

JAVA是面向对象的语言,开发者在操作数据的时候,通常更习惯面对一个特定类型的对象,如一个用户就是一个User类的对象。DAO层需要做的,就是为上层提供充分的对象支持,让上层再也看不到具体的数据,而是一个个活生生的对象。增加,删除,查询和修
2023-05-31

MySQL实现数据插入操作的示例详解

目录一、方法分类二、具体方法三、实例(1)常规插入(2)从另一个表导入(3)插入时数据重复四、注意事项(1)不写字段名,需要填充自增ID(2)按字段名填充,可以不录入id其余注意事项使用mysql插入数据时,可以根据需求场景选择合适的插入语
2023-02-21

数据结构TypeScript之邻接表实现示例详解

这篇文章主要为大家介绍了数据结构TypeScript之邻接表实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-30

Golang实现数据结构Stack(堆栈)的示例详解

在计算机科学中,stack(栈)是一种基本的数据结构,它是一种线性结构,具有后进先出(LastInFirstOut)的特点。本文将通过Golang实现堆栈,需要的可以参考一下
2023-05-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录