我正在尝试在DataTable的Columns属性上执行简单的LINQ查询:
from c in myDataTable.Columns.AsQueryable()
select c.ColumnName
Run Code Online (Sandbox Code Playgroud)
但是,我得到的是:
无法找到源类型"System.Linq.IQueryable"的查询模式的实现.找不到"选择".考虑明确指定范围变量'c'的类型.
如何让DataColumnCollection与LINQ一起玩得很好?
我有一个代码
foreach (DataColumn dataTableCol in this.dataTable.Columns)
{
bool columnFound = false;
foreach (GRTColumnView uiColumn in descriptor.UIColumns)
{
if (dataTableCol.ColumnName.Equals(uiColumn.Name))
{
columnFound = true;
break;
}
}
if (!columnFound)
{
if (this.dataTable.Columns.Contains(dataTableCol.ColumnName))
this.dataTable.Columns.Remove(dataTableCol.ColumnName);
}
}
Run Code Online (Sandbox Code Playgroud)
如果在另一个集合中找不到某些“东西”,我想从集合中删除它们。
当我运行上面的程序时,我得到
由于集合被修改,迭代可能无法执行
“集合已修改” - 因为删除一定已被命中
那要通过什么方法才能达到这样的效果呢?
我能想到的是记下所有要删除的“东西”,然后
foreach( aThing in all_things_to_remove)
remove_from_collection(aThing)
Run Code Online (Sandbox Code Playgroud)
但上面对我来说似乎不是一个好方法,因为我必须进行另一个循环并且正在使用额外的内存