我使用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
答案 0 :(得分:3)
据我所知,MultipleActiveResultSets
在MySql上不可用,因此您无法将其添加到连接字符串(它适用于MS SQL)。
出现此问题的原因很可能是延迟加载。您正在迭代某些查询的结果,同时您在循环内访问未加载的导航属性。这需要执行额外的查询,并且该查询需要新的数据读取器(第一个仍未关闭,因为您只是迭代其结果集)。
解决方案:
ToList
或者AsEnumerable
Include
答案 1 :(得分:3)
为每个DataReader
使用不同的打开和关闭SQL连接名称。这将解决问题。
正在为多个DataReader
使用相同的打开和关闭数据库连接,这是VB.NET中SQL Server不支持的。