我有一个c#生成的数据集。
如何更改连接字符串,以便可以将数据集与另一个(结构相同但填充不同)数据库一起使用?
这必须在运行时发生,因为我在编译时不知道服务器或数据库名称。我正在使用c# 3.5。
我有一个c#生成的数据集。
如何更改连接字符串,以便可以将数据集与另一个(结构相同但填充不同)数据库一起使用?
这必须在运行时发生,因为我在编译时不知道服务器或数据库名称。我正在使用c# 3.5。
我认为没有简单的方法,您不能以编程方式更改整个 Connection-String,DataSet
因为它是为每个TableAdapter
.
您需要创建部分类TableAdapter
来更改连接字符串,因为Connection
属性是internal
(如果您的 DAL 在不同的程序集中)。不要更改designer.cs
文件,因为它会在设计器的下一次更改后自动重新创建。要创建它,只需右键单击 DataSet 并选择“显示代码”。
例如(假设TableAdapter
被命名ProductTableAdapter
):
namespace WindowsFormsApplication1.DataSet1TableAdapters
{
public partial class ProductTableAdapter
{
public string ConnectionString {
get { return Connection.ConnectionString; }
set { Connection.ConnectionString = value; }
}
}
}
现在您可以轻松更改它:
var productTableAdapter = new DataSet1TableAdapters.ProductTableAdapter();
productTableAdapter.ConnectionString = someOtherConnectionString;
这是我的示例DataSet
和创建的文件的屏幕截图DataSet1.cs
:
在您的settings.designer.cs验证程序中输入 mvs 2008或编辑此
public string NamOfappConnectionString{
get {
return ((string)(this["NamOfappConnectionString"]));
}
//add this line
set {
this["NamOfappConnectionString"]=value;
}
}
//atr untime use this
string myconnexion = "Data Source=" + txt_data_source.Text + ";Initial Catalog=" + txt_initial_catalog.Text + ";Persist Security Info=True;";
ConfigurationManager.AppSettings.Set("NamOfappConnectionString", myconnexion);
//保存到设置
Properties.Settings.Default.NamOfappConnectionString= myconnexion;
Application.Restart();