gpt4 book ai didi

c# - 使用 Entity Framework app.config 如何在 Dev、Stage 和 Production 环境之间切换

转载 作者:可可西里 更新时间:2023-11-01 14:41:14 29 4
gpt4 key购买 nike

我有一个使用 DataModel.edmx 访问 Dev 数据库的 Windows 应用程序,它工作正常。为了访问舞台环境数据库,我添加了另一个 StageDataModel.edmx。所以app.config中有两个连接字符串: 和如何根据环境在 app.config 中切换数据库?

提前致谢!

最佳答案

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

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

  • 发布 = 生产
  • 阶段 = 上线前(生产副本、最终测试)
  • 调试 = 新开发,开发团队测试

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

为了实现这一目标,您需要:

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

enter image description here

2) 从app.settings 文件中提取 连接字符串配置。不要在 app.settings 文件中指定连接,而是像这样使用 configSource 参数(app.config 看起来像这样):

  <?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 可能如下所示:

<?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>

enter image description here

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

copy $(ProjectDir)\App.ConnectionStrings.$(ConfigurationName).config $(TargetDir)App.ConnectionStrings.config

enter image description here

现在,当您构建并启动您的应用程序时,配置依赖于构建配置,因此您甚至可以调试连接到 LIVE 环境的应用程序(当当前选择的构建配置是发布).

有关如何使用外部配置文件和连接字符串的更多信息,请参阅 this MSDN article .

很好Entity Framework quick start .

关于c# - 使用 Entity Framework app.config 如何在 Dev、Stage 和 Production 环境之间切换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29950199/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com