首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用实体框架app.config如何在开发、阶段和生产环境之间切换

使用实体框架app.config如何在开发、阶段和生产环境之间切换
EN

Stack Overflow用户
提问于 2015-04-30 01:08:23
回答 2查看 3K关注 0票数 4

我有一个使用DataModel.edmx访问开发人员数据库的windows应用程序,它工作得很好。为了访问stage环境数据库,我添加了另一个StageDataModel.edmx。因此,app.config中有两个连接字符串:如何根据环境在app.config中的数据库之间切换?

提前感谢!

EN

回答 2

Stack Overflow用户

发布于 2015-04-30 03:00:16

通常情况下应该是相反的-为每个环境创建一个EF edmx模型和两个(或更多)配置文件。

在我的工作中,我们有三个环境:

调试调试版本= Production

  • Stage =上线前(生产副本、最终测试)

  • 调试=新开发、开发团队测试

对于这三个环境,我们有三个数据库,它们(几乎)彼此相似。我们从DEV数据库创建我们的模型。与数据库通信的每个项目始终具有三个具有不同凭据的连接字符串。

为了实现这一点,您需要:

1)使用Visual Studio配置管理器创建不同的构建平台(在我的示例中,有三种构建配置-Dev//Release):

2)从app.settings文件中提取连接字符串配置。不要在app.settings文件中指定连接,而是使用configSource参数,如下所示( app.config如下所示):

代码语言:javascript
复制
  <?xml version="1.0" encoding="utf-8" ?>
  <configuration>
    <connectionStrings configSource="App.ConnectionStrings.Config" />
  </configuration>

3)现在为每个构建配置创建不同的文件,以每个构建配置命名(措辞必须准确!)并包含不同的服务器或数据库

  • App.ConnectionStrings.Debug.config
  • App.ConnectionStrings.Stage.config
  • App.ConnectionStrings.Release.config

在前面的示例中,Debug可能如下所示:

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8" ?>
<connectionStrings>
    <add name="Named.ConnectionString" 
            connectionString="metadata=res://*/Abstraction.DbDataContext.csdl|res://*/Abstraction.DbDataContext.ssdl|res://*/Abstraction.DbDataContext.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=sql.server.address;initial catalog=People;integrated security=False;user id=DbUser;password=DbPassword;multipleactiveresultsets=True;App=EntityFramework&quot;"
            providerName="System.Data.EntityClient" />
</connectionStrings>

4)现在在Visual Studio中打开你的项目设置,转到Build Events,在Post-Build event command line中告诉Visual Studio接受每个构建,以当前选择的构建平台命名的文件,并使用指定的(在app.config中)名称将其复制到输出目录:

代码语言:javascript
复制
copy $(ProjectDir)\App.ConnectionStrings.$(ConfigurationName).config $(TargetDir)App.ConnectionStrings.config

现在,当您构建和启动应用程序时,配置依赖于构建配置,因此您甚至可以调试连接到实时环境的应用程序(当当前选择的构建配置为Release时)。

有关如何使用外部配置文件和连接字符串的更多信息,可以在this MSDN article中找到。

一个好的Entity Framework quick start

票数 10
EN

Stack Overflow用户

发布于 2015-04-30 01:11:02

我认为您正在询问如何使用不同的app.config文件进行调试/发布。

只需将它们命名为app.Release.configapp.Debug.config,并在其中任何一个中设置调试或发布设置。

如果比这更复杂,你可以安装一个像SlowCheetah这样的工具来修改XML文件,你只需要设置不同的构建配置。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29950199

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档