【问题标题】:Get connection string from web.config to use in EF POCO?从 web.config 获取连接字符串以在 EF POCO 中使用?
【发布时间】:2012-11-16 13:20:01
【问题描述】:

我注意到,当我使用 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 时发生错误。

【问题讨论】:

  • 您使用的是哪个版本的 EF?
  • @MMK 5.0? VS2012(MVC4)自带的那个
  • 尝试类似 public MainDataContext() :base(ConfigurationManager.ConnectionStrings["MainDataContext"]) { }
  • @MMK 我得到这个错误人cannot convert from 'System.Configuration.ConnectionStringSettings' to 'System.Data.Entity.Infrastructure.DbCompiledModel :|
  • 试试这个:public MainDataContext() :base("MainDataContext") { }

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


【解决方案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>

【讨论】:

  • 还是一样的。当我在构造函数中添加this.Database.Connection.ConnectionString = "Server=(LocalDB)\\v11.0;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|ProjectDB.mdf;"; 时,它可以工作。
  • 是的,100% 肯定。我的连接字符串看起来有点不同(请参阅操作帖子),但我所做的只是编辑了 DefaultConnectionString 的名称并编辑了连接字符串本身。
  • 只是为了检查:您的自定义 dbcontext 是否在库中声明并且连接字符串是否在库的 app.config 文件中?因为如果是,您必须将连接字符串配置复制到将使用您的数据库的应用程序的 web.config/app.config 中。我知道你提到了 web.config,但问题似乎是在错误文件中声明的那种配置。
  • stackoverflow.com/questions/8693492/…。在您的上下文构造函数中检查连接字符串是否可访问: string connectionString = ConfigurationManager.ConnectionStrings["CString"].ConnectionString;像@MMK 建议的那样,但添加一个“.ConnectionString”
  • 问题是我在我的字符串 ((LocalDB)\\v11.0) 中转义了转义键,但是当它从 web.config 获取它时,它转义了我的转义字符串并转向(LocalDB)\\\\v11.0。您的解决方案工作得很好。谢谢。
猜你喜欢
  • 1970-01-01
  • 2016-01-20
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-09-02
  • 2015-03-20
  • 2020-01-13
  • 1970-01-01
相关资源
最近更新 更多