AutoMapper是一個.NET的對象映射工具。
項目地址:https://github.com/AutoMapper/AutoMapper。
幫助文檔:https://github.com/AutoMapper/AutoMapper/wiki
主要用途
領域對象與DTO之間的轉換、數據庫查詢結果映射至實體對象。
這里主要說下使用 AutoMapper 將 IDataReader、DataSet、DataTable 轉為實體的方法。
依賴文件:AutoMapper.dll、AutoMapper.Net4.dll 兩個 dll 文件
AutoMapper.Net4.dll 這個文件可以下載代碼自己編譯,該文件是封裝了對 IDataReader 的支持
簡單說下 AutoMapper 使用
第一步:聲明映射約定
Mapper.CreateMap<IDataReader, menuModel>();//將 IDataReader 映射為 menuModel 實體
第二步:轉換實體
//IDataReader =>menuModel
using (IDataReader dr = .....) { var list = Mapper.Map<List<menuModel>>(dr); dr.Close(); }
以下是自己封裝的一個 AutoMapper 幫助類
使用方法:
第一步:將要轉換的模型在 靜態構造函數中 約定下
/// <summary> /// 注冊 Mapper 轉換規則約定 /// </summary> static void Configure() { Mapper.CreateMap<IDataReader, menuModel>();
...
Mapper.CreateMap<IDataReader, xxxxxModel>(); }
第二步:在項目中應用程序集,使用已經寫好的擴展方法
- using Utitity.AutoMapper
IDataReader dr = ...; var list1 = dr.GetEntity<List<menuModel>>(); DataSet ds = ...; var list2 = ds.GetEntity<List<menuModel>>(); DataTable dt = ...; var list3 = dt.GetEntity<List<menuModel>>();
MapperHelper 源碼
- using AutoMapper;
- using System.Data;
- namespace Utitity.AutoMapper
- {
- /// <summary>
- /// 實體映射幫助類
- /// </summary>
- public static class MapperHelper
- {
- #region 配置映射規則
- /// <summary>
- /// 確保映射配置只注冊一次
- /// </summary>
- static MapperHelper()
- {
- Configure();
- }
- /// <summary>
- /// 注冊 Mapper 轉換規則約定
- /// </summary>
- static void Configure()
- {
- Mapper.CreateMap<IDataReader, xxxxModel>();//只需要約定基礎類型,不要要寫成List<xxxxModel>這種形式
- }
- #endregion
- #region 實體映射擴展方法
- /// <summary>
- /// 將 IDataReader 轉為實體對象
- /// </summary>
- /// <typeparam name="T"></typeparam>
- /// <param name="dr"></param>
- /// <returns></returns>
- public static T GetEntity<T>(this IDataReader dr)
- {
- return Mapper.Map<T>(dr);
- }
- /// <summary>
- /// 將 DataSet 轉為實體對象
- /// </summary>
- /// <typeparam name="T"></typeparam>
- /// <param name="ds"></param>
- /// <returns></returns>
- public static T GetEntity<T>(this DataSet ds)
- {
- if (ds == null || ds.Tables.Count == 0 || ds.Tables[0].Rows.Count == 0)
- return default(T);
- var dr = ds.Tables[0].CreateDataReader();
- return Mapper.Map<T>(dr);
- }
- /// <summary>
- /// 將 DataTable 轉為實體對象
- /// </summary>
- /// <typeparam name="T"></typeparam>
- /// <param name="dt"></param>
- /// <returns></returns>
- public static T GetEntity<T>(this DataTable dt)
- {
- if (dt == null || dt.Rows.Count == 0)
- return default(T);
- var dr = dt.CreateDataReader();
- return Mapper.Map<T>(dr);
- }
- #endregion
- }