C#實現(xiàn)DataTable映射成Model的方法(附源碼)
本文實例講述了C#實現(xiàn)DataTable映射成Model的方法。分享給大家供大家參考,具體如下:
這是數(shù)據(jù)庫開發(fā)中經(jīng)常遇到的問題,當然,這可以用現(xiàn)成的ORM框架來解決,但有些時候,如果DataSet/DataTable是第三方接口返回的,ORM就不方便了,還得自己處理。
反射自然必不可少的,另外考慮到DataTable中的ColumnName通常與Model的PropertyName并不嚴格對應,可以用Attribute來記錄這種映射關系。
步驟1:先創(chuàng)建一個DataFieldAttribute類
using System;
namespace Jimmy.ORM
{
[AttributeUsage(AttributeTargets.Property)]
public sealed class DataFieldAttribute:Attribute
{
/// <summary>
/// 表對應的字段名
/// </summary>
public string ColumnName { set; get; }
public DataFieldAttribute(string columnName)
{
ColumnName = columnName;
}
}
}
步驟2:在Model/Entity的Class成員上,應用DataField特性,參見下面的代碼:
using System;
namespace Jimmy.ORM.Entity
{
[Serializable]
public class ProductEntity : DataEntityBase
{
[DataField("PRODUCT_NO")]
public string ProductNo { set; get; }
[DataField("PRODUCT_ID")]
public int ProductId { set; get; }
[DataField("PRODUCT_NAME")]
public string ProductName { set; get; }
public override string ToString()
{
return string.Format("ProductNo:{1}{0}ProductId:{2}{0}ProductName:{3}", Environment.NewLine, ProductNo,
ProductId, ProductName);
}
}
}
步驟3:該反射出場了,為了方便起見,封裝了一個DataConvert類
using System;
using System.Collections.Generic;
using System.Data;
using System.Reflection;
namespace Jimmy.ORM
{
/// <summary>
/// 將DataRow/DataTable轉換成Entity/Entity列表
/// </summary>
public static class DataConvert<T> where T : DataEntityBase, new()
{
/// <summary>
/// 將DataRow行轉換成Entity
/// </summary>
/// <param name="dr"></param>
/// <returns></returns>
public static T ToEntity(DataRow dr)
{
T entity = new T();
Type info = typeof(T);
var members = info.GetMembers();
foreach (var mi in members)
{
if (mi.MemberType == MemberTypes.Property)
{
//讀取屬性上的DataField特性
object[] attributes = mi.GetCustomAttributes(typeof(DataFieldAttribute), true);
foreach (var attr in attributes)
{
var dataFieldAttr = attr as DataFieldAttribute;
if (dataFieldAttr != null)
{
var propInfo = info.GetProperty(mi.Name);
if (dr.Table.Columns.Contains(dataFieldAttr.ColumnName))
{
//根據(jù)ColumnName,將dr中的相對字段賦值給Entity屬性
propInfo.SetValue(entity,
Convert.ChangeType(dr[dataFieldAttr.ColumnName], propInfo.PropertyType),
null);
}
}
}
}
}
return entity;
}
/// <summary>
/// 將DataTable轉換成Entity列表
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public static List<T> ToList(DataTable dt)
{
List<T> list = new List<T>(dt.Rows.Count);
foreach (DataRow dr in dt.Rows)
{
list.Add(ToEntity(dr));
}
return list;
}
}
}
步驟4:測試
using System;
using System.Data;
using Jimmy.ORM.Entity;
namespace Jimmy.ORM.Test
{
class Program
{
static void Main()
{
DataTable dt = new DataTable();
dt.Columns.Add("PRODUCT_NO");
dt.Columns.Add("PRODUCT_ID");
dt.Columns.Add("PRODUCT_NAME");
dt.Rows.Add("00001", 1, "手機");
dt.Rows.Add("00002", 2, "服裝");
var products = DataConvert<ProductEntity>.ToList(dt);
foreach (var entity in products)
{
Console.WriteLine(entity);
}
Console.Read();
}
}
}
完整實例代碼代碼點擊此處本站下載。
希望本文所述對大家C#程序設計有所幫助。
相關文章
C#中利用Lotus notes公共郵箱發(fā)送郵件的方法
這篇文章主要給大家介紹了關于C#中利用Lotus notes公共郵箱發(fā)送郵件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定參考學習價值,需要的朋友們下面來一起看看吧。2018-02-02
C#生成設置范圍內(nèi)的Double類型隨機數(shù)的方法
這篇文章主要介紹了C#生成設置范圍內(nèi)的Double類型隨機數(shù)的方法,對于C#的初學者有很好的借鑒價值,需要的朋友可以參考下2014-08-08
C#實現(xiàn)微信公眾號群發(fā)消息(解決一天只能發(fā)一次的限制)實例分享
經(jīng)過幾天研究網(wǎng)上的代碼和謝燦大神的幫忙,今天終于用C#實現(xiàn)了微信公眾號群發(fā)消息,現(xiàn)在分享一下2013-09-09
C#使用String和StringBuilder運行速度測試及各自常用方法簡介
今天小編就為大家分享一篇關于C#使用String和StringBuilder運行速度測試及各自常用方法簡介,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10
C#百萬數(shù)據(jù)查詢出現(xiàn)超時問題的解決方法
這篇文章主要介紹了C#百萬數(shù)據(jù)查詢出現(xiàn)超時問題的解決方法,是非常實用的技巧,需要的朋友可以參考下2014-09-09
C#/VB.NET?實現(xiàn)彩色PDF轉為灰度PDF
本文以C#代碼為例介紹如何實現(xiàn)將彩色PDF文件轉為灰度(黑白)的PDF文件,即將PDF文檔里面的彩色圖片或者文字等通過調(diào)用方法轉為文檔頁面為灰色調(diào)、無彩色效果的文檔??靵砀S小編一起學習吧2021-11-11

