gpt4 book ai didi

sql - 使用 BasePage 打开和关闭 SQL 连接的安全性或坏性如何?

转载 作者:行者123 更新时间:2023-12-04 06:46:55 25 4
gpt4 key购买 nike

我有其他 .cs 文件而不是 System.Web.UI.Page (公共(public)部分类页面:BasePage)正在使用的 BasePage.cs 类。

我用它来打开和关闭 SQL 连接,以确保每个 SQL 连接都被关闭。

代码看起来像这样

{
public class BasePage: System.Web.UI.Page
{
public SqlConnection globalConnection;

protected override void OnInit(EventArgs e)
{
globalConnection = new SqlConnection();
globalConnection.ConnectionString = ConfigurationManager.ConnectionStrings["kontemiConnectionString"].ToString();
globalConnection.Open();
}

protected override void OnUnload(EventArgs e)
{
if (globalConnection != null)
{
globalConnection.Close();
}
}
}
}

到目前为止,它对我来说效果很好。这意味着每次打开连接时,它也会关闭。或者至少我是这么认为的。

我的问题是这个解决方案是否是防弹的,并且如果在代码执行期间出现一些处理错误,每个连接都会关闭。跟踪此代码时,如果我故意创建错误 500,它总是会转到 OnUnload 事件并关闭。

那么,你认为这种处决安全吗?
(为了停止讨论是否应该在我真正需要的时候打开 SQL,答案是每个使用 BasePage 的页面也打开一个 SQL 连接。)

最佳答案

在您使用它们的地方打开和关闭 SQL 连接是更好的做法。在底层,CLR 无论如何都会管理连接池——重用连接并在它认为合适的时候关闭它们。对具有相同连接字符串的连接进行大量打开和关闭操作并不会像您预期的那样增加开销。

关于sql - 使用 BasePage 打开和关闭 SQL 连接的安全性或坏性如何?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3628816/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com