2016-02-26 79 views
0

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

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

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 

我不知道为什么错误说“身份证”,因为这实际上嵌套的循环中的错误,我在看的DLineList。所以我没有看Dhead表的ID,直到从DLine删除所有记录。

有什么建议吗?

+0

哪种类型是'db'?它有一个'.ExecuteNonQuery()'函数吗?由于删除,更新,插入处理与选择不同。 –

+0

不,它有'.ExecuteQuery'和'.ExecuteQuery(Of)' –

+0

我重复自己:哪种类型是db? –

回答

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

其中这两个说法是根本原因,因为你所要求的一个强类型(SQL服务器解析)的结果集,该消息告诉我们,这两个类中的一个无法找到ID字段在数据库中填充该值。将ID字段添加到这些类中的一个或两个,并且应该设置。

+1

感谢它的工作现在 –