DataTable与实体对象互转

/// <summary>
/// 将DataTable转为实体对象
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="sourceDT"></param>
/// <returns></returns>
public static List<T> GetEntityFromDataTable<T>(DataTable sourceDT) where T : class
{
    List<T> list = new List<T>();
    // 获取需要转换的目标类型
    Type type = typeof(T);
    foreach (DataRow dRow in sourceDT.Rows)
    {
        // 实体化目标类型对象
        object obj = System.Activator.CreateInstance(type);
        foreach (var prop in type.GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance))
        {
            if (prop.GetSetMethod() != null)// 有些属性没有setter
            {
                // 给目标类型对象的各个属性值赋值
                prop.SetValue(obj, dRow[prop.Name], null);
            }
        }

        list.Add(obj as T);
    }
    return list;
}


/// <summary>
/// 将实体列表转为DataTable
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="list"></param>
/// <returns></returns>
private DataTable GetDataTableFromEntity<T>(List<T> list)
{
    DataTable dt = new DataTable();
    System.Reflection.PropertyInfo[] properties = typeof(ReturnMessages).GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance);
    foreach (System.Reflection.PropertyInfo pro in properties)
    {
        // 添加列
        dt.Columns.Add(pro.Name, pro.PropertyType);
    }

    foreach (T item in list)
    {
        DataRow dr = dt.NewRow();
        foreach (System.Reflection.PropertyInfo pro in properties)
        {
            dr[pro.Name] = item.GetType().GetProperty(pro.Name).GetValue(item, null);
        }

        dt.Rows.Add(dr);
    }
    dt.AcceptChanges();
    return dt;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值