我何时应该在PHP中关闭数据库连接?

Kiw*_*iwy 9 php mysql mysqli

我不像是一个php开发人员,但我必须使用它,而我并不知道PHP如何在会话期间处理内存分配.

我正在开发一个请求HTTP身份验证的应用程序,一旦您登录,您可以通过一个漂亮的界面操作数据.
有人在另一篇文章中告诉我,我不应该在每次执行后关闭mysql数据连接,但我不知道这个连接在使用这个应用程序时是如何保留内存的,因为在服务器端我不知道PHP保留了什么记忆与否.

所以我的问题是我应该用一个单独连接到数据库,并永远不会关闭它(因为我永远不会知道当应用程序在不使用或者我应该站在我今天做:打开连接 - >执行语句 - - >关闭连接.

PS:我正在使用mysqli

编辑1:
我的应用程序设计具有MVC模式含义:

|''''''''''|      |'''''''''''''|      |''''''''''''''|
| view.php |  ==> | control.php |  ==> | database.php |
|----------|      |_____________|      |______________|
Run Code Online (Sandbox Code Playgroud)

该模式允许视图仅与数据交互control.php,然后将数据从database.php调用到数据SELECTEDIT数据.你给我的解释,我应该说:

public function __destruct(){
    mysql_close($this->connection);
}
Run Code Online (Sandbox Code Playgroud)

在内部database.php,但是当需要选择或修改数据时,该页面会加载,因此它仅在短时间内执行,这意味着它仍将在请求结束时关闭连接.

这给出了一个更精确的问题,即我应该在哪里提供您提供的代码的安静,或者我的模式在PHP中是否相关?

Gia*_*ini 13

永远不要为每个查询创建新连接; 您甚至不必手动关闭它.

只需在页面开头创建连接即可

看看:如何在不重新连接每个查询的情况下有效地连接到php中的mysql

你可以用这个:

public function __destruct()
{
   mysql_close($this->connection);
}
Run Code Online (Sandbox Code Playgroud)

页面关闭时会调用它