使用var匿名对象获取LINQ的InvalidCastException

时间:2011-12-20 23:38:04

标签: c# linq linq-to-xml linq-to-dataset

我在使用foreach构造中的var变量尝试循环查询对象时遇到错误。我正在将xml加载到数据集中,并出于明确原因对Linq执行数据集。请纠正我的错误。这是我的代码:

ds.ReadXml(fsReadXml);

DataTable myDataTable = ds.Tables[0];

var ordersQuery = myDataTable.AsEnumerable();

var subQuery = (from Geo03 in ordersQuery
                select new
                {
                    PARENTTYPE = Geo03.Field<String>("PARENTTYPE"),
                    PARENTINSTANCE = Geo03.Field<int>("PARENTINSTANCE"),
                    CHILDTYPE = Geo03.Field<String>("CHILDTYPE"), 
                    CHILDINSTANCE = Geo03.Field<String>("CHILDINSTANCE"),
                    CHILDPOS = Convert.ToInt32(Geo03.Field<int>("CHILDPOS"))
});
XDocument doc = null;
foreach (var cin in subQuery)
{


}

这是生成的错误:

System.InvalidCastException: Specified cast is not valid.
   at System.Data.DataRowExtensions.UnboxT`1.ValueField(Object value)
   at System.Data.DataRowExtensions.Field[T](DataRow row, String columnName)
   at SpectraWorkon.Program.<Main>b__0(DataRow Geo03) in c:\users\arun\documents\visual studio 2010\Projects\SpectraWorkon\SpectraWorkon\Program.cs:line 29
   at System.Linq.Enumerable.WhereSelectEnumerableIterator`2.MoveNext()
   at SpectraWorkon.Program.Main(String[] args) in c:\users\arun\documents\visual studio 2010\Projects\SpectraWorkon\SpectraWorkon\Program.cs:line 38

我收到了foreach (var cin in subQuery)行的错误,说它无法投射。

2 个答案:

答案 0 :(得分:5)

您在Field<int>的字段上调用int

答案 1 :(得分:2)

请记住,在您实际使用它之前不会执行linq查询(例如在foreach循环中,或者调用.ToList())。因此,在您的情况下,异常位于构建查询的部分。 InvaliCastException表示您填写的字段不是您期望的字段。因此,我建议您检查查询中Field<T>的类型。