1

我想将站点的数据模块分成一个程序集(单个 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;
        }
    }

==结束================================================ =============

--- 问题是: ---

  1. 在哪里存储连接?(这是 ConnectionManager 类中的一个属性,theCompany.Data.ConnectionManager.DatabaseConnectionName)

  2. 什么时候建立这种联系?(这里是 Global.asax 应用程序加载时间)

  3. 哪种方法最适合存储此类信息:SessionState 或 ViewState 或简单属性

  4. 这个策略好不好?你知道任何更好的方法或常见的模式吗?

感谢您提供任何信息 - MHM -

4

1 回答 1

0

一些想法...

  1. 您不应该存储并挂在打开的数据库连接上。打开连接,进行数据库操作,然后立即关闭。应用晚获取,早发布的规则。

  2. 见第 1 点。

  3. 不要将数据库连接存储在会话状态中。再次参见第 1 点。如果您指的是连接字符串,那么只需在需要时从配置管理器中读取它。它已经为您缓存,不要重新发明或包装轮子。

  4. 我建议您看一下模式和实践企业库,它抽象出许多管理数据访问的常见模式:

http://www.codeplex.com/entlib

于 2008-12-31T17:04:54.597 回答