6

我的 C# 应用程序使用DataSetTableAdapters. 它们是从 VS2008 GUI 工具生成的。

例子:

右键项目->添加新项目->数据集

此方法自动将连接字符串添加到app.config.

但这是连接字符串的硬线方法。我想以一种简单的方式更改连接字符串。但是当我使用数据集时,连接字符串会从应用程序属性中获取。这种情况有什么解决办法吗?

在此处输入图像描述

这是我在Settings.Designer.cs文件中存储的连接字符串

    namespace WindowsFormsApplication2.Properties {


    [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
    [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "9.0.0.0")]
    internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase {

        private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings())));

        public static Settings Default {
            get {
                return defaultInstance;
            }
        }

        [global::System.Configuration.ApplicationScopedSettingAttribute()]
        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
        [global::System.Configuration.SpecialSettingAttribute(global::System.Configuration.SpecialSetting.ConnectionString)]
        [global::System.Configuration.DefaultSettingValueAttribute("Data Source=SLCERT\\SQLEMK;Initial Catalog=TestDataBase;Integrated Security=True")]
        public string TestDataBaseConnectionString {
            get {
                return ((string)(this["TestDataBaseConnectionString"])); // this is the connection string get from the dataset's
            }
        }
    }
}

app.config 包含

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
    </configSections>
    <connectionStrings>
        <add name="WindowsFormsApplication2.Properties.Settings.TestDataBaseConnectionString"
            connectionString="Data Source=SLCERT\SQLEMK;Initial Catalog=TestDataBase;Integrated Security=True"
            providerName="System.Data.SqlClient" />
    </connectionStrings>
</configuration>
4

3 回答 3

6

我相信您会问这个问题,这样您就不必在本地测试和生产/测试服务器之间手动切换。

您可能想查看如何:在部署 Web 应用程序项目时转换 Web.config

它是关于 web.config 而不是 app.config 但它是相同的想法。

附言。仅适用于 VS 2010 及更高版本

于 2013-03-25T08:24:35.820 回答
4

除了 JP Hellemons 提供的进行配置转换的建议之外,您还可以做其他事情,因为只有 .NET 4.0 (本机)支持。您可以将任意数量的连接字符串添加到<connectionStrings/>配置文件的部分,因此添加“DebugConnectionString”和“ReleaseConnectionString”或类似内容。

现在,为了在每次更改环境时无需干预即可使用这些,您可以使用跟踪常量。在 Visual Studio 中的本地说,您正在使用DEBUG常量集进行编译,并且在部署发布时它不存在,那么您可以执行以下操作:

#if DEBUG 
    return ConfigurationManager.ConnectionStrings["DebugConnectionString"];
#else
    return ConfigurationManager.ConnectionStrings["ReleaseConnectionString"];
#endif
于 2013-03-25T08:29:55.413 回答
2

在 app.config 中

<configuration>
<configSections>
</configSections>
<connectionStrings>
    <add name="DBCS" connectionString="Data Source=|DataDirectory|\Database.sdf;password=Password" 
        providerName="Microsoft.SqlServerCe.Client.3.5" /> 
</connectionStrings>

并像这样访问它

static string CS = ConfigurationManager.ConnectionStrings["DBCS"].ConnectionString.ToString();

包括

System.Configuration;

命名空间

于 2013-03-25T08:34:05.630 回答