在 Entity Framework Code First (DbContext) 上使用不同的数据库进行调试和发布
Using different databases for Debug and Release on Entity Framework Code First (DbContext)
我已经使用 MSDN Tutorial 创建了应用程序数据库,但现在我正在努力尝试拥有 2 个单独的数据库,一个用于调试,另一个用于发布,因为它不添加连接字符串的任何 app.config 行...
当我在服务器资源管理器中打开数据库的属性时,我可以看到实际的连接字符串是 Data Source=(localdb)\MSSQLLocalDB;Initial Catalog=MediaManager.Model.Context;Integrated Security=True
,但在调试或发布模式下我无法区分它...
我该怎么做?
App.config
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<sectionGroup name="userSettings" type="System.Configuration.UserSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<section name="MediaManager.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
</sectionGroup>
<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<section name="MediaManager.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</sectionGroup>
<!-- 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>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
<userSettings>
<MediaManager.Properties.Settings>
...
</MediaManager.Properties.Settings>
</userSettings>
<system.net>
<defaultProxy useDefaultCredentials="true" />
</system.net>
<applicationSettings>
<MediaManager.Properties.Settings>
...
</MediaManager.Properties.Settings>
</applicationSettings>
<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>
</configuration>
Context.cs
using System.Data.Entity;
namespace MediaManager.Model
{
public class Context : DbContext, IContext
{
public virtual DbSet<Episodio> Episodio { get; set; }
public virtual DbSet<Serie> Serie { get; set; }
public virtual DbSet<SerieAlias> SerieAlias { get; set; }
public virtual DbSet<Feed> Feed { get; set; }
}
}
您应该能够简单地更新您的 Context
以传入连接字符串的名称,并在您的 web.config
.
中定义此连接字符串
例如:
public class Context : DbContext, IContext
{
public Context() : base("MyContext") { }
public virtual DbSet<Episodio> Episodio { get; set; }
public virtual DbSet<Serie> Serie { get; set; }
public virtual DbSet<SerieAlias> SerieAlias { get; set; }
public virtual DbSet<Feed> Feed { get; set; }
}
然后在 web.config
<configuration>
<connectionStrings>
<add name="MyContext" connectionString="..your connection string.." providerName="System.Data.SqlClient" />
</connectionStrings>
</configuration>
完成后,您可以使用 Web Configuration Transforms 自动更新 Release 构建与 Debug[ 的连接字符串=26=]构建。
我已经使用 MSDN Tutorial 创建了应用程序数据库,但现在我正在努力尝试拥有 2 个单独的数据库,一个用于调试,另一个用于发布,因为它不添加连接字符串的任何 app.config 行...
当我在服务器资源管理器中打开数据库的属性时,我可以看到实际的连接字符串是 Data Source=(localdb)\MSSQLLocalDB;Initial Catalog=MediaManager.Model.Context;Integrated Security=True
,但在调试或发布模式下我无法区分它...
我该怎么做?
App.config
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<sectionGroup name="userSettings" type="System.Configuration.UserSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<section name="MediaManager.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
</sectionGroup>
<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<section name="MediaManager.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</sectionGroup>
<!-- 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>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
<userSettings>
<MediaManager.Properties.Settings>
...
</MediaManager.Properties.Settings>
</userSettings>
<system.net>
<defaultProxy useDefaultCredentials="true" />
</system.net>
<applicationSettings>
<MediaManager.Properties.Settings>
...
</MediaManager.Properties.Settings>
</applicationSettings>
<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>
</configuration>
Context.cs
using System.Data.Entity;
namespace MediaManager.Model
{
public class Context : DbContext, IContext
{
public virtual DbSet<Episodio> Episodio { get; set; }
public virtual DbSet<Serie> Serie { get; set; }
public virtual DbSet<SerieAlias> SerieAlias { get; set; }
public virtual DbSet<Feed> Feed { get; set; }
}
}
您应该能够简单地更新您的 Context
以传入连接字符串的名称,并在您的 web.config
.
例如:
public class Context : DbContext, IContext
{
public Context() : base("MyContext") { }
public virtual DbSet<Episodio> Episodio { get; set; }
public virtual DbSet<Serie> Serie { get; set; }
public virtual DbSet<SerieAlias> SerieAlias { get; set; }
public virtual DbSet<Feed> Feed { get; set; }
}
然后在 web.config
<configuration>
<connectionStrings>
<add name="MyContext" connectionString="..your connection string.." providerName="System.Data.SqlClient" />
</connectionStrings>
</configuration>
完成后,您可以使用 Web Configuration Transforms 自动更新 Release 构建与 Debug[ 的连接字符串=26=]构建。