博客园现代化建设——AutoMapper

上篇随笔写的是我们在新版博客后台开发中用上了新式武器——Entity Framework,该武器火力猛,威力大,但使用中发现在某些场景下显得不够灵活,后来不得不引进轻量级常规武器——AutoMapper

成都创新互联公司专注于察雅企业网站建设,成都响应式网站建设公司,成都做商城网站。察雅网站建设公司,为察雅等地区提供建站服务。全流程按需搭建网站,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务

我们遇到的场景是一个复杂的实体类,有很多属性,数据库操作是一个跨数据库查询,查询的字段远远少于实体类的属性。

对于跨数据库查询,我们没有找到通过LINQ to Entities实现的方法,于是就用DbSet.SqlQuery调用存储过程进行查询,代码如下:

 
 
 
  1. using (BlogDbContext context = new BlogDbContext())  
  2. {  
  3.     string sql = string.Format("EXEC [blog_Entry_Get] @BlogID={0},@EntryID={1}", blogId, entryId);  
  4.     BlogEntry entry = context.BlogEntries.SqlQuery(sql).Single();  
  5. }  

虽然不能使用LINQ进行查询,但我们不想在这里抛弃这个新式武器,不能发射导弹,可以用一下机关枪嘛。于是,如上面的代码所示,用SqlQuery进行查询,用Entity Framework完成查询结果与实体类的数据映射。

结果发现,Entity Framework是依赖于实体类的属性进行映射的。如果把Entity Framework比作机关枪,那实体类的属性就是子弹,每颗子弹只能攻击唯一对应的目标,在射击过程中,只要有一颗子弹攻击的目标不存在,机枪就会卡壳(子弹决定目标?)。也就是Entity Framework会在IDataReader中查找每个实体类属性对应的值,而我们的应用场景却是“查询的字段远远少于实体类的属性”,这时,Entity Framework成为了一堆废铁(这个说法不妥,可以通过modelBuilder.Entity().Ignor忽略不需要映射的字段,但是,如果不同的查询返回的字段不同,这个方法就不管用了)。

为什么不由目标决定子弹?出现什么目标,用什么子弹,既节省子弹,又不会卡壳。也就是根据查询结果给对应的实体类属性赋值。难道这个新式武器也有设计缺陷,没有考虑到这样的应用场景?还是我们不会使用?

翻来覆去地摆弄它,还是没搞定,只能换武器...

数据库查询换成了旧式武器Enterprise Library,并引进了新的轻量级常规武器AutoMapper进行查询结果与实体类的映射(而且是开源的)。

“轻量级”果然名不虚转,简单易用,针对性强,我们用它轻松解决了问题,代码如下:

 
 
 
  1. SqlCommand command = (SqlCommand)_sqldb.GetStoredProcCommand("[blog_Entry_Get]");  
  2. command.Parameters.AddWithValue("@BlogID", blogId);  
  3. command.Parameters.AddWithValue("@EntryID", entryId);  
  4. using (IDataReader reader = _sqldb.ExecuteReader(command))  
  5. {  
  6.     if (reader.Read())  
  7.     {  
  8.         BlogEntry entry = AutoMapper.Mapper.DynamicMap(reader);  
  9.     }  
  10. }  

原文链接:http://www.cnblogs.com/dudu/archive/2011/03/28/entity_framework_automapper.html

文章题目:博客园现代化建设——AutoMapper
标题链接:http://www.shufengxianlan.com/qtweb/news27/52677.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联