当前位置:  开发笔记 > 后端 > 正文

在asp.net应用程序中管理与数据库的连接

如何解决《在asp.net应用程序中管理与数据库的连接》经验,为你挑选了1个好方法。

我想知道,在asp.net中管理数据库连接的最佳方法是什么.

我的应用程序是使用N层架构构建的.DAL由静态类和方法组成

Public Shared Sub Delete( _
    ByVal connection As MyConnectionClass, _
    ByVal contact_id As Integer, _
    ByVal contact_timestamp As Date _
)

    With connection.ProcParams
        .Add(New StoredProcParam("p_contact_id", contact_id, OracleDbType.Int32))
        .Add(New StoredProcParam("p_contact_timestamp", contact_timestamp, OracleDbType.Date))
    End With

    connection.Execute("PKG_DATA_ACCESS.DeleteContact")

End Sub

这里需要注意的是,我将连接从BLL传递给DAL.

以下是我考虑过的观点,但对我来说似乎都没有,所以我只是在征求意见.

我应该在MasterPage中创建连接,将其存储在一个对象中,然后在创建它时将它传递给我的业务对象(我试图避免的事情)

我应该使用静态类创建连接并在其上调用CreateConnection等方法,从我的业务对象的构造函数(我想要的东西,但我不希望每个对象有一个连接,我喜欢它要为我的对象的所有实例共享,但由于asp.net是多线程的,静态类对存储连接没有意义)

理想情况下,该解决方案也应该在Windows窗体环境中运行良好(因此,没有连接存储在会话中,并在类中使用静态方法检索它,对于当前上下文)



1> Neil N..:

不要试图坚持连接.在您使用它的每个范围内实例化它..Net将为您管理一个连接池,在windows窗体或asp.net中.

试图保持连接是一个会话对象或在母版页中实际上会损害性能,更不用说介绍其他问题了.

来自BC的评论:

连接字符串必须是相同的字符串才能在同一个池中结束.

推荐阅读
虎仔球妈_459
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有