Linq to DataSet - 处理空值

时间:2010-01-30 19:38:49

标签: asp.net linq datatable

我需要将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<> 

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

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

如何解决?

2 个答案:

答案 0 :(得分: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 :(得分:1)

您可以检查null,然后将DBNull.Value存储为值。有一个MSDN article about null values,特别指出缺乏对Nullable&lt;&gt;的支持。数据集。

你在哪里

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

制作

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