记一次利用AutoMapper优化项目中数据层到业务层的数据传递过程。
目前项目中获取到DataSet数据后用下面这种方式复制数据。
List<AgreementDoc> list = new List<AgreementDoc>();
].Rows)
{
AgreementDoc docItem = new AgreementDoc() {
ContactID = row["ContactID"].ToString(),
AgreementAccepted = row["AgreementAccepted"].ToString(),
AgreementSource = row["AgreementSource"].ToString(),
AgreementStatus = row["AgreementStatus"].ToString(),
AlternateFirstName = row["AlternateFirstName"].ToString(),
AlternateLastName = row["AlternateLastName"].ToString(),
City = row["City"].ToString(),
RecruiterID = row["RecruiterID"].ToString(),
ConsultantID = row["ConsultantID"].ToString(),
ConsultantStatus = row["ConsultantStatus"].ToString(),
ConsultantSuffix = row["ConsultantSuffix"].ToString(),
Director = row["Director"].ToString(),
EligibleToLogin = row["EligibleToLogin"].ToString(),
EmailAddress = row["EmailAddress"].ToString(),
FirstName = row["FirstName"].ToString(),
GovernmentIssuedId = row["GovernmentIssuedId"].ToString(),
Inserted = row["Inserted"].ToString(),
IsReceived = row["IsReceived"].ToString(),
LastName = row["LastName"].ToString(),
MiddleName = row["MiddleName"].ToString(),
PhoneNumber = row["PhoneNumber"].ToString(),
Reason = row["Reason"].ToString(),
RecruiterContactID = row["RecruiterContactID"].ToString(),
RecruiterIndicator = row["RecruiterIndicator"].ToString(),
RecruiterName = row["RecruiterName"].ToString(),
RegistrationProvince = row["RegistrationProvince"].ToString(),
ReleaseAuthorizationIndicator = row["ReleaseAuthorizationIndicator"].ToString(),
ResidenceID = row["ResidenceID"].ToString(),
StartDate = row["StartDate"].ToString(),
StreetAddress = row["StreetAddress"].ToString(),
UnitID = row["UnitID"].ToString(),
UnitSuffix = row["UnitSuffix"].ToString(),
RecuriterFirstName = row["RecuriterFirstName"].ToString(),
RecuriterLastName = row["RecuriterLastName"].ToString(),
RecuriterMiddleName = row["RecuriterMiddleName"].ToString()
};
list.Add(docItem);
}
探索反射解决方案:
对于目标实体中字段与数据库中字段数据类型不一样时,果断抛出异常。—失败告终....
探索AutoMapper中dynamicMap映射IDataReader到实体时同样会抛出异常,其实它的原理就是反射—失败告终...
探索AutoMapper针对列名属性单一映射方法ForMember();—成功优化。
对于某些需要转化格式的数据做特别处理。
优化后的code:
AutoMapper.Mapper.CreateMap<IDataReader, AgreementDoc>().ForMember(des => des.ContactID, opt =>
{
opt.MapFrom(src => (src.GetInt64(src.GetOrdinal("ContactID")).ToString()));
}).ForMember(des => des.StartDate, opt =>
{
opt.MapFrom(src => (src.GetDateTime(src.GetOrdinal("StartDate")).ToString()));
});
List<AgreementDoc> list = AutoMapper.Mapper.Map<IDataReader,List<AgreementDoc>>(ds.CreateDataReader());
记一次利用AutoMapper优化项目中数据层到业务层的数据传递过程。的更多相关文章
- AutoMapper在项目中的应用
一.先说说DTO DTO是个什么东东? DTO(Data Transfer Object)就是数据传输对象,说白了就是一个对象,只不过里边全是数据而已. 为什么要用DTO? 1.DTO更注重数据,对领 ...
- JavaEE中表现层、持久层、业务层的职责分析(转载)
表现层.持久层.业务层 注:本文转载于:http://www.blogjava.net/jiabao/archive/2007/04/08/109189.html 为了实现web层(struts)和持 ...
- Web API项目中使用Area对业务进行分类管理
在之前开发的很多Web API项目中,为了方便以及快速开发,往往把整个Web API的控制器放在基目录的Controllers目录中,但随着业务越来越复杂,这样Controllers目录中的文件就增加 ...
- BI项目中的ETL设计详解(数据抽取、清洗与转换 )(转载)
原文:http://www.cnblogs.com/reportmis/p/5939732.html ETL是BI项目最重要的一个环节,通常情况下ETL会花掉整个项目的1/3的时间,ETL设计的好坏直 ...
- Django项目中如何建表?怎样导入数据?
http://django-chinese-docs.readthedocs.org/en/latest/topics/db/models.html 通常在项目中的models.py文件中建表的 Th ...
- 项目中使用emoji表情包与表情的解析过程详情
菜鸡一只,刚开始写博客文笔不好,有问题欢迎相互讨论.闲话不多说. 用到了三个插件 Emoji Picker 第一步 这个emoji表情包插件是我找到比较好 的一个,input框中是不能放入图片的,效果 ...
- 一个项目中说系统分为表现层、控制层、逻辑层、DAO层和最终数据库五层架构-转
表现层就是看到的东西,比如你现在看到的当前页面控制层就将你的请求从页面传到后台代码逻辑层就是处理你的请求的代码DAO层就是将数据存到数据库中的代码数据库就是数据库了,存东西用的 ,DAO层就是将访问数 ...
- 项目中常用方法总结(将将DataTable数据集映射到实体对象)【转】
本篇把项目中用到的一些通用方法总结出来, 这些方法因为经常需要在项目中用到,所以把它们归纳在一起, 形成一个.dll 文件是一个理想的选择. 这样也便于日后缩短开发周期. 一. 把一个DataGrid ...
- ionic1项目中 ion-slide轮播用ng-repeat遍历数据后自动循环出问题
<ion-slide-box>属性中循环播放:dose-continue=‘true’,但是在项目遇到这样一个问题,从后台获取数据后将数据ng-repeat到<ion-slide&g ...
随机推荐
- Linux学习---vi/vim命令
Vim是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用. 所以本文直接用Vim编辑器 基本上 vi/vim 共分为三种模式,分别是命令模式( ...
- 关于mysql查询区分大小写
使用查询语句时,携带collate utf8_bin 在SQL语句中使用collate 使用collate子句,能够为一个比较覆盖任何默认校对规则.collate可以用于多种SQL语句中,比如wher ...
- Block Token 原理分析
介绍 文件权限检查由NameNode执行,而不是DataNode执行. 默认情况下,任何客户端都可以访问只有其块ID的任何块. 为了解决这个问题,Hadoop引入了块访问令牌的概念. 块访问令牌由Na ...
- DirectFB 之 字体显示(2)
框架 示例代码 /********************************************** * Author: younger.liucn@hotmail.com * File n ...
- 基于header的一些常用指令详解
header常用指令 header分为三部分: 第一部分为HTTP协议的版本(HTTP-Version): 第二部分为状态代码(Status): 第三部分为原因短语(Reason-Phrase) ...
- PHP 序列化与反序列化函数
序列化与反序列化 把复杂的数据类型压缩到一个字符串中 serialize() 把变量和它们的值编码成文本形式 unserialize() 恢复原先变量 1.创建一个$arr数组用于储存用户基本信息 ...
- CF798 C. Mike and gcd problem
/* CF798 C. Mike and gcd problem http://codeforces.com/contest/798/problem/C 数论 贪心 题意:如果一个数列的gcd值大于1 ...
- 前端框架对比之vue与regular(一)
每次一写到Regular总是忍不住先介绍一下,Regualr是网易杭州研究所的一位叫郑海波的大神写的一款前端框架,目前 这款框架推广的不深,加上其和angular过于相似的框架名,导致接受力并不大,其 ...
- ACE框架 同步原语设计
ACE框架常用的同步机制设计成统一的原语接口.同步原语使用系统平台(操作系统,多线程库)提供的同步原语,并为系统平台不提供的同步原语提供模拟实现.ACE框架使用了外观模式和适配器分两层,将同步原语统一 ...
- 文件查找---find
文件查找(find) 1 find 简单的说,就是实时查找指定的内容或条件.特点:最新.最快.最准确. 用法:find [查找路径] [查找条件] [找到后进行的动作] eg. find /e ...