已经有一个与此Connection关联的开放DataReader

时间:2012-07-02 07:03:24

标签: mysql asp.net-mvc-3 entity-framework

我使用EF + MySql,数据库包含两个foriegnkey,当我运行我的项目时,它说:已经有一个与此Connection关联的开放DataReader必须先关闭,然后我将MultipleActiveResultSets = true添加到连接字符串在web.config中,我再试一次,它告诉我:初始化字符串的格式不符合规范,我怎么做 解决这个问题?代码有限foriegnkey和错误的初始化代码列表如下:

#region EDM 关系源元数据

[assembly: EdmRelationshipAttribute("blogModel", "cid", "cls", System.Data.Metadata.Edm.RelationshipMultiplicity.One, typeof(blog.Models.cls), "news", System.Data.Metadata.Edm.RelationshipMultiplicity.Many, typeof(blog.Models.news), true)]
[assembly: EdmRelationshipAttribute("blogModel", "uid", "users", System.Data.Metadata.Edm.RelationshipMultiplicity.One, typeof(blog.Models.users), "news", System.Data.Metadata.Edm.RelationshipMultiplicity.Many, typeof(blog.Models.news), true)]

#endregion

#region 导航属性

    /// <summary>
    /// 没有元数据文档可用。
    /// </summary>
    [XmlIgnoreAttribute()]
    [SoapIgnoreAttribute()]
    [DataMemberAttribute()]
    [EdmRelationshipNavigationPropertyAttribute("blogModel", "cid", "cls")]
    public cls cls
    {
        get
        {
            return ((IEntityWithRelationships)this).RelationshipManager.GetRelatedReference<cls>("blogModel.cid", "cls").Value;
        }
        set
        {
            ((IEntityWithRelationships)this).RelationshipManager.GetRelatedReference<cls>("blogModel.cid", "cls").Value = value;
        }
    }
    /// <summary>
    /// 没有元数据文档可用。
    /// </summary>
    [BrowsableAttribute(false)]
    [DataMemberAttribute()]
    public EntityReference<cls> clsReference
    {
        get
        {
            return ((IEntityWithRelationships)this).RelationshipManager.GetRelatedReference<cls>("blogModel.cid", "cls");
        }
        set
        {
            if ((value != null))
            {
                ((IEntityWithRelationships)this).RelationshipManager.InitializeRelatedReference<cls>("blogModel.cid", "cls", value);
            }
        }
    }

    /// <summary>
    /// 没有元数据文档可用。
    /// </summary>
    [XmlIgnoreAttribute()]
    [SoapIgnoreAttribute()]
    [DataMemberAttribute()]
    [EdmRelationshipNavigationPropertyAttribute("blogModel", "uid", "users")]
    public users users
    {
        get
        {
            return ((IEntityWithRelationships)this).RelationshipManager.GetRelatedReference<users>("blogModel.uid", "users").Value;
        }
        set
        {
            ((IEntityWithRelationships)this).RelationshipManager.GetRelatedReference<users>("blogModel.uid", "users").Value = value;
        }
    }
    /// <summary>
    /// 没有元数据文档可用。
    /// </summary>
    [BrowsableAttribute(false)]
    [DataMemberAttribute()]
    public EntityReference<users> usersReference
    {
        get
        {
            return ((IEntityWithRelationships)this).RelationshipManager.GetRelatedReference<users>("blogModel.uid", "users");
        }
        set
        {
            if ((value != null))
            {
                ((IEntityWithRelationships)this).RelationshipManager.InitializeRelatedReference<users>("blogModel.uid", "users", value);
            }
        }
    }

    #endregion


public partial class blogEntities : ObjectContext
{
    #region 构造函数

    /// <summary>
    /// 请使用应用程序配置文件的“blogEntities”部分中的连接字符串初始化新 blogEntities 对象。
    /// </summary>
    public blogEntities() : base("name=blogEntities", "blogEntities")
    {
        this.ContextOptions.LazyLoadingEnabled = true;
        OnContextCreated();
    }

    /// <summary>
    /// 初始化新的 blogEntities 对象。
    /// </summary>
    public blogEntities(string connectionString) : base(connectionString, "blogEntities")
    {
        this.ContextOptions.LazyLoadingEnabled = true;
        OnContextCreated();
    }

    /// <summary>
    /// 初始化新的 blogEntities 对象。
    /// </summary>
    public blogEntities(EntityConnection connection) : base(connection, "blogEntities")
    {
        this.ContextOptions.LazyLoadingEnabled = true;
        OnContextCreated();
    }

    #endregion

2 个答案:

答案 0 :(得分:3)

据我所知,MultipleActiveResultSets在MySql上不可用,因此您无法将其添加到连接字符串(它适用于MS SQL)。

出现此问题的原因很可能是延迟加载。您正在迭代某些查询的结果,同时您在循环内访问未加载的导航属性。这需要执行额外的查询,并且该查询需要新的数据读取器(第一个仍未关闭,因为您只是迭代其结果集)。

解决方案:

  • 使用ToList或者AsEnumerable
  • 对要迭代的查询的整个结果集进行材料化处理
  • 或者您希望在循环内使用Include
  • 来加载导航属性

答案 1 :(得分:3)

为每个DataReader使用不同的打开和关闭SQL连接名称。这将解决问题。

正在为多个DataReader使用相同的打开和关闭数据库连接,这是VB.NET中SQL Server不支持的。