从web.config获取连接字符串以在EF POCO中使用?

时间:2012-11-28 16:05:38

标签: c# asp.net asp.net-mvc entity-framework web-config

我注意到当我使用EF创建模型优先数据库时,它忽略了web.config连接字符串并在后台执行它自己的操作。然后我找到了一种在构造函数中设置我自己的连接字符串的方法。

public class MainDataContext : DbContext
{
    public MainDataContext()
    {
        this.Database.Connection.ConnectionString = "MY CONNECTION STRING THAT IS ACTUALLY USED";
    }
}

问题:如何强制/设置它以使用web.config中的连接字符串?

我被告知,如果您将连接字符串命名为您的数据上下文,它将起作用,但它不适合我。我确定如果我将其命名为DefaultConnectionString,它就无效。

<add name="MainDataContext" providerName="System.Data.SqlClient"
     connectionString="Server=(LocalDB)\\v11.0;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|ProjectDB.mdf;" />

尝试从控制台执行update-database -v -f时出错。

1 个答案:

答案 0 :(得分:1)

您可以尝试这样的事情:

public MainDataContext() :
        base(typeof(MainDataContext).Name)
    {
    }

您确定Web.config中的连接字符串声明是否正确?像这样:

<?xml version="1.0"?>
<configuration>
<connectionStrings>
    <add name="MyDatabase" connectionString="server=localhost;User Id=user;password=password;Persist Security Info=True;database=mydatabase" providerName="MySql.Data.MySqlClient" />
</connectionStrings>
</configuration>