C#:DataTable映射成Model
时间:2022-04-23
本文章向大家介绍C#:DataTable映射成Model,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
这是数据库开发中经常遇到的问题,当然,这可以用现成的ORM框架来解决,但有些时候,如果DataSet/DataTable是第三方接口返回的,ORM就不方便了,还得自己处理。
反射自然必不可少的,另外考虑到DataTable中的ColumnName通常与Model的PropertyName并不严格对应,可以用Attribute来记录这种映射关系。
步骤1:先创建一个DataFieldAttribute类
1 using System;
2
3 namespace Jimmy.ORM
4 {
5 [AttributeUsage(AttributeTargets.Property)]
6 public sealed class DataFieldAttribute:Attribute
7 {
8 /// <summary>
9 /// 表对应的字段名
10 /// </summary>
11 public string ColumnName { set; get; }
12
13 public DataFieldAttribute(string columnName)
14 {
15 ColumnName = columnName;
16 }
17 }
18 }
步骤2:在Model/Entity的Class成员上,应用DataField特性,参见下面的代码:
1 using System;
2
3 namespace Jimmy.ORM.Entity
4 {
5 [Serializable]
6 public class ProductEntity : DataEntityBase
7 {
8
9 [DataField("PRODUCT_NO")]
10 public string ProductNo { set; get; }
11
12 [DataField("PRODUCT_ID")]
13 public int ProductId { set; get; }
14
15 [DataField("PRODUCT_NAME")]
16 public string ProductName { set; get; }
17
18 public override string ToString()
19 {
20 return string.Format("ProductNo:{1}{0}ProductId:{2}{0}ProductName:{3}", Environment.NewLine, ProductNo,
21 ProductId, ProductName);
22 }
23 }
24 }
步骤3:该反射出场了,为了方便起见,封装了一个DataConvert类
1 using System;
2 using System.Collections.Generic;
3 using System.Data;
4 using System.Reflection;
5
6 namespace Jimmy.ORM
7 {
8 /// <summary>
9 /// 将DataRow/DataTable转换成Entity/Entity列表
10 /// </summary>
11 public static class DataConvert<T> where T : DataEntityBase, new()
12 {
13 /// <summary>
14 /// 将DataRow行转换成Entity
15 /// </summary>
16 /// <param name="dr"></param>
17 /// <returns></returns>
18 public static T ToEntity(DataRow dr)
19 {
20 T entity = new T();
21 Type info = typeof(T);
22 var members = info.GetMembers();
23 foreach (var mi in members)
24 {
25 if (mi.MemberType == MemberTypes.Property)
26 {
27 //读取属性上的DataField特性
28 object[] attributes = mi.GetCustomAttributes(typeof(DataFieldAttribute), true);
29 foreach (var attr in attributes)
30 {
31 var dataFieldAttr = attr as DataFieldAttribute;
32 if (dataFieldAttr != null)
33 {
34 var propInfo = info.GetProperty(mi.Name);
35 if (dr.Table.Columns.Contains(dataFieldAttr.ColumnName))
36 {
37 //根据ColumnName,将dr中的相对字段赋值给Entity属性
38 propInfo.SetValue(entity,
39 Convert.ChangeType(dr[dataFieldAttr.ColumnName], propInfo.PropertyType),
40 null);
41 }
42
43 }
44 }
45 }
46 }
47 return entity;
48 }
49
50 /// <summary>
51 /// 将DataTable转换成Entity列表
52 /// </summary>
53 /// <param name="dt"></param>
54 /// <returns></returns>
55 public static List<T> ToList(DataTable dt)
56 {
57 List<T> list = new List<T>(dt.Rows.Count);
58 foreach (DataRow dr in dt.Rows)
59 {
60 list.Add(ToEntity(dr));
61 }
62 return list;
63 }
64 }
65 }
步骤4:测试
1 using System;
2 using System.Data;
3 using Jimmy.ORM.Entity;
4
5 namespace Jimmy.ORM.Test
6 {
7 class Program
8 {
9 static void Main()
10 {
11 DataTable dt = new DataTable();
12 dt.Columns.Add("PRODUCT_NO");
13 dt.Columns.Add("PRODUCT_ID");
14 dt.Columns.Add("PRODUCT_NAME");
15
16 dt.Rows.Add("00001", 1, "手机");
17 dt.Rows.Add("00002", 2, "服装");
18
19 var products = DataConvert<ProductEntity>.ToList(dt);
20
21 foreach (var entity in products)
22 {
23 Console.WriteLine(entity);
24 }
25
26 Console.Read();
27 }
28 }
29 }
示例代码下载:http://files.cnblogs.com/yjmyzz/DataConvertor.zip
- Hive 时间转换函数使用心得
- Flume-Hbase-Sink针对不同版本flume与HBase的适配研究与经验总结
- 利用Flume 汇入数据到HBase:Flume-hbase-sink 使用方法详解
- 浅谈保证软件工程质量的一些心得体会
- 基于ELK的nginx-qps监控解决方案
- 2017年年度最烂密码排名
- 字符串方法汇总(三)
- 周鸿祎:“大安全”网络时代 需要AI大数据的技术支持
- 爆料:对扫码支付下手后,据说央行接下来要提高备付金,目标比例42%
- 回顾2017年5大科技突破,“时间晶体”充满想象!
- 1宽币=883?山本宽称要发行自己的数字货币
- 十种深度学习算法要点及代码解析
- 王健林旗下万达网科被曝大裁员 总裁出面说话了
- lodash源码分析之缓存方式的选择
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法