通常,在.NET应用程序中,您将数据库连接字符串存储在app.config中。
对于单个.exe,只有一个.exe.config。我们正在使用Entity Framework,它默认使用与DbContext名称匹配的.config设置。只要您遵循将单个数据库实例与单个数据库进行通信的常见模式,这一切都可以正常工作。
但是我们的问题要求我们有多个应用程序实例,每个实例都有自己独特的数据库连接。
可能的解决方案:
有什么想法吗?
我确定以前有人处理过这个问题。是否有一种处理问题的常用方法?
答案 0 :(得分:2)
您还可以考虑创建配置文件的副本,并使用以下代码根据命令行参数加载相应的配置文件:
AppDomain.CurrentDomain.SetData ("APP_CONFIG_FILE", "path to config file")
答案 1 :(得分:0)
您可以在某些C#应用程序中尝试这样的操作来更改每个应用程序的连接字符串。
var config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
var connectionStringSection = (ConnectionStringsSection)config.GetSection("connectionStrings");
connectionStringSection.ConnectionStrings["database"].ConnectionString = string.Format("Data Source={0}", userCon);
config.Save();
ConfigurationManager.RefreshSection("connectionStrings");