博客园现代化建设——AutoMapper

数据库
上篇随笔写的是我们在新版博客后台开发中用上了新式武器——Entity Framework,该武器火力猛,威力大,但使用中发现在某些场景下显得不够灵活,后来不得不引进轻量级常规武器——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<BlogEntry>().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<BlogEntry>(reader);  
  9.     }  
  10. }  

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

【编辑推荐】

  1. 博客园现代化建设——Entity Framework
责任编辑:艾婧 来源: 博客园
相关推荐

2011-03-30 13:14:05

Entity Fram

2018-02-01 16:34:54

2019-09-23 17:34:05

存储

2015-10-29 14:35:21

移动设备现代化

2022-07-11 05:34:19

云原生应用程序

2023-05-03 21:47:22

2024-01-23 15:21:14

2021-09-08 14:43:17

网络数字化转型Equinix

2023-12-07 08:00:00

数字化转型数字化

2020-06-05 14:16:05

医药

2013-03-19 18:04:06

51CTO

2020-05-08 14:47:53

网络现代化网络IT

2015-09-15 11:06:33

第一届税务行业信息化研华为

2021-04-13 16:13:38

大数据教育科学

2023-06-25 09:04:12

数字企业架构EA

2023-02-08 11:07:56

数字时代数字运营模式

2021-07-09 05:25:48

CIO遗留系统现代化用户体验

2022-11-01 07:14:32

裸金属云云服务云原生
点赞
收藏

51CTO技术栈公众号