如何施展
System.Data.Linq.Table<T> 至 System.Data.DataTable
DemoDBDataContext context = new DemoDBDataContext();
DataSet ds = new DataSet();
var query = context.Customers;
ds.Tables[0] = query;
Run Code Online (Sandbox Code Playgroud)
怎么做?分配
ds.Tables[0] = query;
Run Code Online (Sandbox Code Playgroud)
它抛出
属性或索引器
System.Data.DataTableCollection.this[int]无法分配给它是只读的.
BFr*_*ree 10
您无法将System.Data.Linq.Table强制转换为DataTable,但是您可以轻松地在IEnumerable上编写扩展方法以将其转换为DataTable:
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)
资料来源:http://www.chinhdo.com/20090402/convert-list-to-datatable/
| 归档时间: |
|
| 查看次数: |
7064 次 |
| 最近记录: |