Entity Framework - 使用相同的DbContext和不同的连接字符串

5
我目前正在尝试在我的应用程序中使用相同的DbContext(我有两个数据库,结构相同)。我不太确定我做错了什么,但这是我的当前代码-希望它应该很明显我在尝试做什么。我正在使用EF Database First(底部的错误似乎并不建议)。
我的上下文工厂代码:
public class HOLContextFactory
    {
        public static HOLDbEntities Create()
        {
            return new HOLDbEntities(); // Works
        }

        public static HOLDbQuoteEntities CreateQuote()
        {
            return new HOLDbQuoteEntities(); // Gives error
        }
    }

public partial class HOLDbQuoteEntities : HOLDbEntities
    {
        public HOLDbQuoteEntities()
            : base("HOLDbQuoteEntities") // This should send "HOLDbQuoteEntities" as the base connection string?! 
// Also tried "name=HOLDbQuoteEntities"
            {
            }
        }

Web.config连接字符串:

<add name="HOLDbEntities" connectionString="metadata=res://*/HOLDbContext.csdl|res://*/HOLDbContext.ssdl|res://*/HOLDbContext.msl;provider=System.Data.SqlClient;provider connection string=<connstringdetails>" providerName="System.Data.EntityClient" />

<add name="HOLDbQuoteEntities" connectionString="metadata=res://*/HOLDbContext.csdl|res://*/HOLDbContext.ssdl|res://*/HOLDbContext.msl;provider=System.Data.SqlClient;provider connection string=<connstringdetails>" providerName="System.Data.EntityClient" /> // using diff database - same structure

使用“HOLDbQuoteEntities”时出现的错误:
使用Database First和Model First开发生成的代码,如果在Code First模式下使用可能无法正常工作。要继续使用Database First或Model First,请确保实体框架连接字符串在执行应用程序的配置文件中指定。要使用从Database First或Model First生成的这些类与Code First配合使用,请使用属性或DbModelBuilder API添加任何其他配置,然后删除引发此异常的代码。
2个回答

4

Entity Framework 需要使用实际的实体对象:

public class HOLContextFactory
{
    public static HOLDbEntities Create()
    {
        // default connection string
        return new HOLDbEntities(); 
    }

    public static HOLDbEntities CreateQuote()
    {
        // specified connection string
        return new HOLDbEntities ("HOLDbQuoteEntities"); 
    }
}

public partial class HOLDbEntities
{
    public HOLDbEntities(string connectionString)
        : base(connectionString) 
        {
        }
    }
}

这实际上是我最终的做法。 - Chris Dixon

1

我在我的一个项目中也做过同样的事情。我使用 metadata=res://*/ 创建了实体上下文。

尝试这个:

<add name="HOLDbEntities" connectionString="metadata=res://*/;provider=System.Data.SqlClient;provider connection string=<connstringdetails>" providerName="System.Data.EntityClient" />

<add name="HOLDbQuoteEntities" connectionString="metadata=res://*/;provider=System.Data.SqlClient;provider connection string=<connstringdetails>" providerName="System.Data.EntityClient" /> 

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接