我注意到当我使用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
时出错。
答案 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>