C#实现DataTable映射成Model的方法(附源码)
作者:Jimmy.Yang 发布时间:2023-03-12 06:10:56
标签:C#,DataTable,映射,Model
本文实例讲述了C#实现DataTable映射成Model的方法。分享给大家供大家参考,具体如下:
这是数据库开发中经常遇到的问题,当然,这可以用现成的ORM框架来解决,但有些时候,如果DataSet/DataTable是第三方接口返回的,ORM就不方便了,还得自己处理。
反射自然必不可少的,另外考虑到DataTable中的ColumnName通常与Model的PropertyName并不严格对应,可以用Attribute来记录这种映射关系。
步骤1:先创建一个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))
{
//根据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#程序设计有所帮助。


猜你喜欢
- 在上一篇实现了简单的画板功能, 这篇实现橡皮擦功能,首先分析一下应该如何实现,在Andriod有个图像混合(Xfermode)概念,利用这个
- 1. 最小生成树连通图中的每一棵生成树 , 都是原图的极大无环子图 , 即: 从中删去任何一条边 , 生成树就不再连通;反之 , 在其中引入
- 1 什么是条件变量condition_variable是一个类,常和mutex搭配使用。condition_variable类是一个同步原语
- 前言:回顾之前的微信公众号配置和消息处理的内容,我们已经掌握了如何配置服务器与微信公众号建立连接,也掌握了通过消息管理的方式,对用户的信息进
- springBoot框架的特点就是舍去了繁琐的配置。使开发者可以把更多的精力放在业务逻辑的开发上。springBoot搭建分三步。1.创建一
- 最近在搞一个购物车的功能,里面有一个批量删除的操作,采用的是ExpandableListView以及BaseExpandableListAd
- 目录示例原理DefaultBeanDefinitionDocumentReaderparseDefaultElementimportBean
- Android 打开相册选择单张图片实现代码
- 一:什么是协变与逆变协变指能够使用比原始指定的派生类型的派生程度更大(更具体的)的类型,逆变指能够使用比原始指定的派生类型的派生程度更小(不
- 方法一: IDictionaryEnumerator enumerator = thProduct.GetEn
- 一、概念1.1、什么是服务治理Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务治理服务治理就是提供
- 1、StatefulWidget的背后flutter开发过程中,我们经常会用到两个组件StatelessWidget和StatefulWid
- 先记录下jdk8之前的一些帮助方法判断time是否在now的n天之内/** * 判断time是否在now的n天之内
- 线程池execute与submit区别在使用线程池的时候,看到execute()与submit()方法。都可以使用线程池执行一个任务,但是两
- Java时间格式转换大全import java.text.*;import java.util.Calendar;public class
- 一、编辑框EditText编辑框用于接收键盘输入的文字,由文本视图派生而来,除了TextView已有的各种属性和方法,EditText还支持
- SpringBoot Data JPA实现 一对多、多对一关联表查询开发环境IDEA 2017.1Java1.8SpringBoot 2.0
- 1 需求Mybatis-plus使用@TableLogic注解进行逻辑删除数据后,在某些场景下,又需要查询该数据时,又不想写SQ
- 本文实例为大家分享了java实现鲜花销售系统的具体代码,供大家参考,具体内容如下一、练习目标1.体会数组的作用2.找到分层开发的感觉3.收获
- logback输出日志屏蔽quartz的debug等级日志在一个spring的老项目中,使用了logback来作为日志管理,logback.