- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人建议我重新排列我的代码以“汇集”我的 ADO 连接。在每个网页上,我都会打开一个连接并继续使用相同的打开连接。但有人告诉我,这在 10 年前很重要,但现在不那么重要了。如果我在网络发布上进行 5 次分贝调用,那么使用我打开/关闭的 5 个单独的连接是否有问题?
最佳答案
与 SQL Server 的连接自动汇集在 ASP.NET 应用程序中:每个不同的连接字符串对应一个池。如果您遵循最佳实践并将数据库代码隐藏在连接字符串在整个应用程序中保持不变的 DAL 中,那么您将始终使用单个连接对象池。
那么这对您使用数据库的方法意味着什么?好吧,一方面它意味着“关闭连接”实际上转化为“将连接返回到池”,而不是真正关闭应用程序与 SQL Server 的链接。因此,关闭和重新开放并不是什么大问题。然而,话虽如此,这里有一些最佳实践可以遵循。
首先,即使您的应用程序大幅扩展,您也不希望池中的连接用完。也就是说,永远不要轮流考虑“此页面上的用户” - 考虑“使用此页面的千人”。
其次,即使关闭和重新打开连接并不费力,您通常希望以 的形式打开连接。迟到尽可能使用它直到它完成,然后将其关闭为 早尽可能。唯一的异常(exception)是,如果您有一个耗时的过程,必须在检索某些数据之后和保存或检索其他数据之前进行。
第三,我强烈建议不要在页面生命周期的早期打开连接并在生命周期的后期以不同的方法关闭它。为什么?因为您能做的最糟糕的事情就是让连接保持打开状态,因为您忘记添加关闭它的逻辑。是的,当 GC 启动时,它们最终会被关闭,但是,再次,如果您正在考虑“使用此页面的数千人*,真正麻烦的机会就变得很明显了。
现在,如果你说你确定你关闭了连接,因为你总是在某个关键的、合乎逻辑的地方这样做(例如 Page_Unload 方法)。好吧,这很好,只要您可以自信地说您永远不会抛出跳出页面生命周期的错误。你不能。所以......不要在页面生命周期的一种方法中打开并在另一种方法中关闭。
最后,我强烈建议实现一个 DAL 来管理数据库连接并提供用于处理数据的工具。最重要的是,构建一个业务逻辑层 (BLL),它使用这些工具为您的 UI 提供类型安全的对象(例如“模型”对象)。如果您使用 IDisposable 接口(interface)实现 BLL 对象,那么您始终可以使用范围确保连接安全。它还可以让您在很短的时间内保持数据库连接打开:只需打开 BLL 对象,将数据拉入本地对象或列表,然后关闭 BLL 对象(超出范围)。然后,您可以在连接关闭后使用 BLL 返回的数据。
那么……这看起来像什么。好吧,在您的页面(UI)上,您将使用如下业务逻辑类:
using (BusinessLogicSubClass bLogic = new BusinessLogicSubClass())
{
// Retrieve and display data or pull from your UI and update
// using methods built into the bLogic object
.
.
.
} // <-- Going out of scope will automatically call the dispose method and close the database connection.
public class BusinessLogic : IDisposable
{
protected DBManagementClass qry;
public BusinessLogic()
{
qry = new DBManagementClass();
}
public void Dispose()
{
qry.Dispose(); <-- qry does the connection management as described below.
}
... other methods that work with the qry class to
... retrieve, manipulate, update, etc. the data
... Example: returning a List<ModelClass> to the UI ...
}
public class DBManagementClass : IDisposable
{
public static string ConnectionString { get; set; } // ConnectionString is initialized when the App starts up.
public DBManagementClass()
{
conn = new SqlConnection(ConnectionString);
conn.Open();
}
public void Dispose()
{
conn.Close();
}
... other methods
}
关于.net - 汇集我的连接对我来说有多重要?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2440237/
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
我正在尝试修改网站的布局,但有时网站会使用 !important,有没有办法覆盖它?我似乎无法弄清楚如何在页面的 css 文件之后加载 css 内容脚本。 最佳答案 !important CSS 规则
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 9 年前。 我写了一些 html,并在第三方网站中注入(inject)了一些 css 样
好的,我在这里安装了一个 wordpress 主题(www.sullivansuccesscoaching.com/home ...我们需要/home,因为仍然有一个 index.html 隐藏了 w
我已经为我的 Wordpress 模板创建了一个覆盖原始 CSS 的自定义样式表。但是,在我的日历页面上,原始 CSS 具有使用 !important 声明设置的每个表格单元格的高度: td {hei
这个问题在这里已经有了答案: How to document deconstructed parameters with JsDoc (1 个回答) 关闭 5 年前。 我正在努力寻找对文档 ES6
我的网站使用 bootstrap 4 和我制作的 css 文件。 在这个 css 文件的底部,我放置了一些媒体查询: @media (max-width: 575px) { .address .c
可以将 background-position X 设置为 0 带有标志 !important 和背景位置 Y 不带 !important? 例如: background-position-x: 0
我只想在焦点状态下去掉下拉列表中的轮廓。看这张图 我尝试使用 !important 覆盖 Bootstrap ,但根本不起作用。只是检查开发工具,突然看到这个。 Bootstrap 也使用 !impo
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 1 年前。
发生了什么事?:我的 jQuery Accordion 的动画坏了。在关闭上一个选项卡之前短时间单击下一个选项卡后,它会显示之前打开的选项卡。动画也不滑动。 CSS:来自this answer /*
如何使用 javascript 或 CSS 覆盖样式“color: red”?我想让它成为“2px”而不是“1px”边框。 Lorem... 我无法向“div”添加类、id。这不
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 5 年前。
滚动有问题不想显示其内容,如果我这样做 #callCenter { position: fixed; z-index: 2411 !important; display: bl
序言 1、MySQL表操作(创建表,查询表结构,更改表字段等), 2、MySQL的数据类型(CHAR、VARCHAR、BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大
如何将!important添加到客户端包GWT中的gwt-image: 我有这个: @sprite .superButton{ gwt-image : 'superButton'; backg
请帮助我..我想验证表单并使用 ajax 发送。 验证没有 ''onsubmit="return validateForm(this);"'' 工作。 但是当表单正确时,它的发送表单(页面刷新..)请
我是一名优秀的程序员,十分优秀!