我试图删除两个表中的一些行,当我尝试执行该操作时,会得到一个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 DLine表的id。
有什么建议吗?
发布于 2016-02-26 16:02:29
db.ExecuteQuery(Of DHead)(dhQuery, dhparam)
db.ExecuteQuery(Of DLine)(dlQuery, dlparam)这两条语句中有一条是根本原因,因为您请求的是强类型(已解析的sql服务器)结果集,因此消息告诉我们,在这两个类中的一个类中,它找不到数据库中的ID字段来填充值。将ID字段添加到其中一个或两个类中,您应该被设置。
https://stackoverflow.com/questions/35651967
复制相似问题