Linq执行查询InvalidOperationException

时间:2016-02-26 12:37:39

标签: mysql wpf vb.net linq

我试图删除几个表中的一些行,当我尝试执行此操作时,我得到一个InvalidOperationException:结果中不存在所需的列'id'。

在调用此函数之前,我尝试查找和删除的值已添加到列表中。

    For Each dh In DHeadList
        For Each dl In DLineList
            Dim dlparam() = {dh.DHeadID}
            Dim dlQuery As String = "DELETE From dbo.DLine WHERE DHeadId={0}"
            db.ExecuteQuery(Of DLine)(dlQuery, dlparam)
        Next
        Dim dhparam() = {dh.DHeadID}
        Dim dhQuery As String = "DELETE FROM dbo.DHead WHERE id ={0}"
        db.ExecuteQuery(Of DHead)(dhQuery, dhparam)
    Next

我不知道为什么错误说'id',因为这实际上是嵌套for循环中的错误,我正在查看 DLineList 。因此,在删除 DLine 的所有记录之前,我不会查看 Dhead 表的ID。

有什么建议吗?

1 个答案:

答案 0 :(得分:0)

db.ExecuteQuery(Of DHead)(dhQuery, dhparam) 
db.ExecuteQuery(Of DLine)(dlQuery, dlparam)

这两个语句中的一个是根本原因,因为你要求一个强类型(sql server parsed)结果集,该消息告诉我们在这两个类之一中它找不到ID字段。填充值的数据库。将ID字段添加到其中一个或两个类中,您应该进行设置。