我有一个名为 MyItems 的实体表,该表中的每个项目都有另一个表的外键。我想简单地遍历我的项目并访问每个项目的外键对象的字符串“名称”属性,如下所示:
foreach (var myItem in (from q in context.MyItems select q))
{
string testName = myItem.ForeignItem.Name
}
当我这样做时,ForeignItem 为空,并且当我尝试访问 ForeignItem 时收到 InvalidOperationException:
已经有一个与此命令关联的打开的 DataReader,必须先关闭它。
但是- 如果我改为这样调用 ToList() :
(from q in context.MyItems select q).ToList()
我的外键对象填充得很好。我意识到 ToList() 会很昂贵,因为将立即检索整个表。我怀疑延迟加载在幕后出了点问题,但我正在理解它应该在不调用ToList()
.
我忽略了什么吗?
编辑:我在想也许是使用var
导致问题,所以我尝试使用
foreach (MyItem myItem in (from q in context.MyItems select q))
{
// loop contents
}
相反 - 相同的结果。的属性myItem
被填充,但外键对象保持为空。
编辑#2:我在整个应用程序中只使用一个对象上下文和一个 Linq-to-Entities 语句,所以我无法解释另一个 DataReader 在哪里运行。我还应该注意,这个错误发生在循环中的第一个对象上,所以它不是因为检索到前一个项目。