在以下代码中,当第二次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);
                    }
                }
            }

 

相关文章:

  • 2022-01-04
  • 2022-12-23
  • 2022-12-23
  • 2021-12-27
  • 2022-12-23
  • 2021-09-08
  • 2021-08-20
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-08-29
  • 2021-12-03
  • 2021-10-17
相关资源
相似解决方案