我有一个将LINQ转换为DataTable的需求。
我从StackOverflow上偷来了以下扩展方法:
如何修复它?
我从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);
如何修复它?
values[i] = value ?? (object)DBNull.Value;
。 - Scott Chamberlain