C# List与DataTable的相互转化

本文介绍了如何通过反射方法解决在使用List转DataTable时遇到的DATASET不支持System.Nullable异常的问题,特别关注了实体类中包含可空类型的属性情况。

List与Data的转化比较简单,网上也很多。但是大多都有一个Bug:当实体类有可空类型的属性时,转化会出异常(DATASET不支持System.Nullable异常

下面的方法可以避免出现这个问题。


 

①List转DataTable

#region  反射List To DataTable
/// <summary>  
/// 将集合类转换成DataTable  
/// </summary>  
/// <param name="list">集合</param>  
/// <returns></returns>  
public static DataTable ListToDataTable(IList list)
{
    DataTable result = new DataTable();
    if (list.Count > 0)
    {
        PropertyInfo[] propertys = list[0].GetType().GetProperties();

        foreach (PropertyInfo pi in propertys)
        {
            Type colType = pi.PropertyType;
            if ((colType.IsGenericType) && (colType.GetGenericTypeDefinition() == typeof(Nullable<>)))
            {
                colType = colType.GetGenericArguments()[0];
            }
            result.Columns.Add(new DataColumn(pi.Name, colType));
        }

        for (int i = 0; i < list.Count; i++)
        {
            ArrayList tempList = new ArrayList();
            foreach (PropertyInfo pi in propertys)
            {
                object obj = pi.GetValue(list[i], null);
                tempList.Add(obj);
            }
            object[] array = tempList.ToArray();
            result.LoadDataRow(array, true);
        }
    }
    return result;
} 

 

 

 

 

转载于:https://www.cnblogs.com/TiestoRay/p/3371834.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值