zoukankan      html  css  js  c++  java
  • 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(" {0}", comment.Comments);

    }

    }

    }

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

    using(EFDbContext dbContext=new EFDbContext())
    {

    }
    可解决

    莫谈他人高薪,且看闲时谁在拼.
  • 相关阅读:
    网站宣传【免费】
    gridview行链接
    提前预告
    C#中var、int、object性能比较
    20部软件测试视频教程整合
    PO、VO、DTO、POJO
    云计算、虚拟化、容器
    Linux打包和压缩的区别
    Linux之Shell定时备份数据库
    luogu P1997 faebdc的烦恼 | 莫队
  • 原文地址:https://www.cnblogs.com/LiChen19951127/p/9672423.html
Copyright © 2011-2022 走看看