我有一个产生匿名类型的Linq查询。但是,现在我想使用这个匿名类型的参数,它似乎不起作用。
For Each obj As Object in Query
Dim row As DataRow = obj.parameter
...
Next obj
现在编译器在表达式obj.parameter上抛出一个错误:“Option Strict On禁止后期绑定”。如果我理解正确,编译器不知道匿名类型的参数。我尝试了基于Google搜索结果的Option Infer On(并删除了As Object),但它没有帮助。这似乎有道理,因为它似乎总是向我扩展转换。
无论如何要解决这个问题,还是应该创建一个自定义类型?
答案 0 :(得分:4)
声明匿名类型的代码(即LINQ查询的Select
部分)必须与使用它的代码在同一方法中,并且Query
变量的声明必须具有推断类型。在将匿名类型转换为Object
之后,您无法访问该属性,因为没有可以将其强制转换的命名类型。
因此,请确保您的LINQ查询(或者至少是Select
成为新匿名类型的部分)使用相同的方法。例如。
Dim Query = From prod In products
Select prod.Name, prod.Price
For Each obj in Query
Dim name = obj.Name
...
Next obj