我正在使用在此站点上找到的通用 DataTable 到 List 转换方法:
private List<T> ConvertToList<T>(DataTable dt)
{
var columnNames = dt.Columns.Cast<DataColumn>()
.Select(c => c.ColumnName)
.ToList();
var properties = typeof(T).GetProperties();
return dt.AsEnumerable().Select(row =>
{
var objT = Activator.CreateInstance<T>();
foreach (var pro in properties)
{
if (columnNames.Contains(pro.Name))
{
pro.SetValue(objT, row[pro.Name], null);
}
}
return objT;
}).ToList();
}
它工作得很好,除非我在 pro.SetValue 中为整数字段命中空值。它失败的原因是,如果第二个参数为 null,pro.SetValue 将为一个类型设置默认值,如下所示:pro.SetValue(objT, null,null)。但我的 row[IdColumn] 返回空对象 {} 而不是 null。我得到的错误是:
“System.DBNull”类型的对象无法转换为“System.Nullable`1[System.Int32]”类型。
使用时int?
和
'System.DBNull' 类型的对象无法转换为 [System.Int32]' 类型。
使用时int
如何处理这种情况?