我想将站点的数据模块分成一个程序集(单个 dll 文件),在处理 Web 应用程序时获取存储和传递站点的ConnectionString的最佳方法是什么。在数据程序集中,我创建了一个名为 ConnectionManager 的静态类。它有一个名为DatabaseConnectionName的属性 ,我想传递并存储位于 Web.Config 文件中的连接名称。在这个策略中,我决定在网站的加载时间在 Global.asax 文件中获取名称并建立连接,并在我之前提到的属性 (DatabaseConnectionName) 中进行连接。但是,这只是我使用的策略,我不知道做这项工作的常见模式是什么。
部分代码: ======================================= [ -------- ---- Global.asax ------------ ]
the code in the site that makes the Data module accessible for the site
void Application_Start(object sender, EventArgs e)
{
OurCompany.Data.ConnectionManager.DatabaseConnectionName = "MasterConnection";
}
[ ------------ ConnectionManager Class ------------ ] 这是在数据模块中,除了站点
public static class ConnectionManager
{
public static SqlConnection GetMasterConnection()
{
string connectionString = ConfigurationManager.ConnectionStrings[**DatabaseConnectionName**].ConnectionString;
SqlConnection conn;
//conn.Open();
conn = new SqlConnection(connectionString);
return conn;
}
private static string **databaseConnectionName**;
public static string DatabaseConnectionName
{
get
{
return databaseConnectionName;
}
set
{
databaseConnectionName = value;
}
}
==结束================================================ =============
--- 问题是: ---
在哪里存储连接?(这是 ConnectionManager 类中的一个属性,theCompany.Data.ConnectionManager.DatabaseConnectionName)
什么时候建立这种联系?(这里是 Global.asax 应用程序加载时间)
哪种方法最适合存储此类信息:SessionState 或 ViewState 或简单属性
这个策略好不好?你知道任何更好的方法或常见的模式吗?
感谢您提供任何信息 - MHM -