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#程序設計有所幫助。
上一篇:WPF實現(xiàn)時鐘特效
欄 目:C#教程
下一篇:C#實現(xiàn)Winform鼠標拖動窗口大小時設定窗口最小尺寸的方法
本文標題:C#實現(xiàn)DataTable映射成Model的方法(附源碼)
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/6821.html
您可能感興趣的文章
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻 器左下角滾動新聞效果的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已安裝軟件變化的方法
- 01-10C#實現(xiàn)多線程下載文件的方法
- 01-10C#實現(xiàn)Winform中打開網(wǎng)頁頁面的方法
- 01-10C#實現(xiàn)遠程關閉計算機或重啟計算機的方法
- 01-10C#自定義簽名章實現(xiàn)方法
- 01-10C#文件斷點續(xù)傳實現(xiàn)方法
- 01-10winform實現(xiàn)創(chuàng)建最前端窗體的方法


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
- 01-10關于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻 器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
隨機閱讀
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實例總結
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法