C#實現(xiàn)DataTable映射成Model的方法(附源碼)
本文實例講述了C#實現(xiàn)DataTable映射成Model的方法。分享給大家供大家參考,具體如下:
這是數(shù)據(jù)庫開發(fā)中經(jīng)常遇到的問題,當(dāng)然,這可以用現(xiàn)成的ORM框架來解決,但有些時候,如果DataSet/DataTable是第三方接口返回的,ORM就不方便了,還得自己處理。
反射自然必不可少的,另外考慮到DataTable中的ColumnName通常與Model的PropertyName并不嚴(yán)格對應(yīng),可以用Attribute來記錄這種映射關(guān)系。
步驟1:先創(chuàng)建一個DataFieldAttribute類
using System; namespace Jimmy.ORM { [AttributeUsage(AttributeTargets.Property)] public sealed class DataFieldAttribute:Attribute { /// <summary> /// 表對應(yīng)的字段名 /// </summary> public string ColumnName { set; get; } public DataFieldAttribute(string columnName) { ColumnName = columnName; } } }
步驟2:在Model/Entity的Class成員上,應(yīng)用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轉(zhuǎn)換成Entity/Entity列表 /// </summary> public static class DataConvert<T> where T : DataEntityBase, new() { /// <summary> /// 將DataRow行轉(zhuǎn)換成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轉(zhuǎn)換成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, "手機(jī)"); dt.Rows.Add("00002", 2, "服裝"); var products = DataConvert<ProductEntity>.ToList(dt); foreach (var entity in products) { Console.WriteLine(entity); } Console.Read(); } } }
完整實例代碼代碼點擊此處本站下載。
希望本文所述對大家C#程序設(shè)計有所幫助。
- C# DataTable常見用法匯總
- C#讀取Excel到DataTable的方法示例
- C#實現(xiàn)Json轉(zhuǎn)DataTable并導(dǎo)出Excel的方法示例
- C#中DataTable 轉(zhuǎn)實體實例詳解
- 詳解C#把DataTable中數(shù)據(jù)一次插入數(shù)據(jù)庫的方法
- C#實現(xiàn)利用泛型將DataSet轉(zhuǎn)為Model的方法
- C# MVC模式中應(yīng)該怎樣區(qū)分應(yīng)用程序邏輯(Controller層)和業(yè)務(wù)邏輯(Model層)?
- C# DataTable與Model互轉(zhuǎn)的示例代碼
相關(guān)文章
C#中利用Lotus notes公共郵箱發(fā)送郵件的方法
這篇文章主要給大家介紹了關(guān)于C#中利用Lotus notes公共郵箱發(fā)送郵件的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2018-02-02C#生成設(shè)置范圍內(nèi)的Double類型隨機(jī)數(shù)的方法
這篇文章主要介紹了C#生成設(shè)置范圍內(nèi)的Double類型隨機(jī)數(shù)的方法,對于C#的初學(xué)者有很好的借鑒價值,需要的朋友可以參考下2014-08-08C#實現(xiàn)微信公眾號群發(fā)消息(解決一天只能發(fā)一次的限制)實例分享
經(jīng)過幾天研究網(wǎng)上的代碼和謝燦大神的幫忙,今天終于用C#實現(xiàn)了微信公眾號群發(fā)消息,現(xiàn)在分享一下2013-09-09DevExpress之餅狀圖突出(Explode)設(shè)置實例
這篇文章主要介紹了DevExpress之餅狀圖突出(Explode)設(shè)置方法,以實例形式展示了餅狀圖突出設(shè)置的具體實現(xiàn)過程,非常具有實用價值,需要的朋友可以參考下2014-10-10C#使用String和StringBuilder運行速度測試及各自常用方法簡介
今天小編就為大家分享一篇關(guān)于C#使用String和StringBuilder運行速度測試及各自常用方法簡介,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10C#百萬數(shù)據(jù)查詢出現(xiàn)超時問題的解決方法
這篇文章主要介紹了C#百萬數(shù)據(jù)查詢出現(xiàn)超時問題的解決方法,是非常實用的技巧,需要的朋友可以參考下2014-09-09C#/VB.NET?實現(xiàn)彩色PDF轉(zhuǎn)為灰度PDF
本文以C#代碼為例介紹如何實現(xiàn)將彩色PDF文件轉(zhuǎn)為灰度(黑白)的PDF文件,即將PDF文檔里面的彩色圖片或者文字等通過調(diào)用方法轉(zhuǎn)為文檔頁面為灰色調(diào)、無彩色效果的文檔??靵砀S小編一起學(xué)習(xí)吧2021-11-11