我的连接字符串出了什么问题(无法通过ConfiguratioManager访问它)?

时间:2016-08-31 00:31:30

标签: connection-string azure-sql-database app-config

我正在尝试连接到Azure SQL,但收到错误The underlying provider failed on Open

我发现我已将连接字符串放入错误的app.config - 将其移动到可执行项目的app.config,但仍然是相同的结果

当我检查ConfigurationManager.ConnectionStrings["AzureDatabase"]时,它返回null。当我尝试连接时,它只使用默认的SQLExpress。

当我检查可执行应用程序的build文件夹时 - 有一个带有“AzureDatabase”的<app_name>.exe.config文件。我被困在哪里从这里搜索

这是我的DbContext类

[DbConfigurationType(typeof(AzureDbConfiguration))]
public class ProductDbContext : DbContext
{
    //Db sets

    static MyContext()
    {
        //I don't want to change database from code
        Database.SetInitializer<MyContext>(null);
    }

    public MyContext() : base("AzureDatabase") //this is my connectionstring
    {            
    }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        //some mappings
    }
}

这是AzureDbConfiguration

public class AzureDbConfiguration : DbConfiguration
{
    public AzureDbConfiguration()
    {
        SetExecutionStrategy("System.Data.SqlClient", () => new SqlAzureExecutionStrategy(2, TimeSpan.FromSeconds(10)));
    }
}

这是我的app.config文件

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
    <connectionStrings>
        <add name="AzureDatabase" 
             connectionString="Server=tcp:xxx.database.windows.net,1433;Initial Catalog=xxx;Persist Security Info=False;User ID=xxxx;Password=xxxxx;MultipleActiveResultSets=False;Encrypt=True;TrustServerCertificate=False;Connection Timeout=30;" providerName="System.Data.SqlClient"/>
            </connectionStrings>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
      <parameters>
        <parameter value="mssqllocaldb" />
      </parameters>
    </defaultConnectionFactory>
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />     
    </providers>
  </entityFramework>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
    </startup>
</configuration>

关于这里有什么问题的任何想法?

1 个答案:

答案 0 :(得分:0)

事实证明问题在于我试图使用类库中的app.config(我试图创建集成测试)

可能的解决方案之一是为类库创建单独的设置文件。你可以阅读它in this StackOverflow post