小编Dhi*_*ina的帖子

Linq to DataSet - 处理空值

我需要将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;
  } 
Run Code Online (Sandbox Code Playgroud)

当表包含空值时,它会抛出异常.(即)

DataSet does not support System.Nullable<> 
Run Code Online (Sandbox Code Playgroud)

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

tb.Columns.Add(prop.Name, prop.PropertyType);
Run Code Online (Sandbox Code Playgroud)

怎么解决?

linq asp.net datatable

5
推荐指数
1
解决办法
2370
查看次数

标签 统计

asp.net ×1

datatable ×1

linq ×1