Linq to DataSet - 处理空值

5
我有一个将LINQ转换为DataTable的需求。
我从StackOverflow上偷来了以下扩展方法:
public static DataTable ToDataTable<T>(this IEnumerable<T> items)
        {
            var tb = new DataTable(typeof(T).Name);
            PropertyInfo[] props = 
            typeof(T).GetProperties(BindingFlags.Public
                                  | BindingFlags.Instance);

            foreach (var prop in props)
            {
                tb.Columns.Add(prop.Name, prop.PropertyType);
            }

            foreach (var item in items)
            {
                var values = new object[props.Length];
                for (var i = 0; i < props.Length; i++)
                {
                    values[i] = props[i].GetValue(item, null);
                }

                tb.Rows.Add(values);
            }
            return tb;
  } 

当表格中包含空值时,会抛出异常。(即)

DataSet does not support System.Nullable<> 

Comission(十进制类型)列包含空值

位于

tb.Columns.Add(prop.Name, prop.PropertyType);

如何修复它?
2个回答

5

这是一个升级版本:

public static DataTable ToDataTable<T>(this IEnumerable<T> items) { 
    DataTable table = new DataTable(typeof(T).Name);
    PropertyInfo[] props = typeof(T).GetProperties(BindingFlags.Public | BindingFlags.Instance); 

    foreach (var prop in props) {
        Type propType = prop.PropertyType;

        // Is it a nullable type? Get the underlying type
        if (propType.IsGenericType && propType.GetGenericTypeDefinition().Equals(typeof(Nullable<>)))
            propType = new NullableConverter(propType).UnderlyingType; 

        table.Columns.Add(prop.Name, propType);
    } 

    foreach (var item in items) { 
        var values = new object[props.Length]; 
        for (var i = 0; i < props.Length; i++)
            values[i] = props[i].GetValue(item, null);  

        table.Rows.Add(values); 
    }

    return table;
}

编辑:我稍微修改了我的代码,测试过了,它可以工作!:)


1

你可以检查是否为 null,然后将 DBNull.Value 存储为值。有一篇关于 null 值的 MSDN 文章,特别指出了数据集不支持 Nullable<>。

在这里:

values[i] = props[i].GetValue(item, null);

做它

var value = props[i].GetValue(item, null);
values[i] = value ?? ((object)DBNull.Value);

2
你也可以使用可空运算符 ??,这样代码就会变成 values[i] = value ?? (object)DBNull.Value; - Scott Chamberlain

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接