EF 已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭

在以下代码中,当第二次foreach时会抛出该异常,原因是:由于Entity在读取数据的时候使用的是DbDataReader进行读取,当作为IEnumuerable<T>对象MoveNext进行操作时,只是使用DbDataReader进行一次Read操作,因此当查询的结果未完全读取完的时候,数据库连接一直被占用,当再次进行查询操作时便回出现上面的异常。
解决办法有两个:
1.在链接字符串中加入 MultipleActiveResultSets=true,但需要注意的是该方案只适合Sql Server 2005以及以上版本
2.使用ToList()方法,将IQueryable转为List

using (var context = new MyDbContext())

{

var blogs = from blog in context.BlogPosts

where blog.Comments.Any()

select blog;

 

foreach (var blog in blogs)

{

Console.WriteLine("Blog Post: {0}", blog.Title);

foreach (var comment in blog.Comments)

{

Console.WriteLine("\t{0}", comment.Comments);

}

}

}

 3.推荐使用这个  释放资源 (亲测)

using(EFDbContext dbContext=new EFDbContext())
{

}
可解决

posted @ 2018-09-19 07:28  阳光下的行者  阅读(730)  评论(0编辑  收藏  举报