Ben Giles Asked: 2015-07-23 07:31:11 +0800 CST2015-07-23 07:31:11 +0800 CST 2015-07-23 07:31:11 +0800 CST 临时表或记录集位于何处? 772 使用 mysql 和 php,我想了解临时结果存储在哪里。例如,当我执行返回一组数据供 php 处理的查询时,与数据库的连接是否已关闭并且 php 存储信息以供使用,或者该信息是否保留在数据库中直到 php 完成使用它? mysql php 1 个回答 Voted Best Answer jkavalik 2015-07-23T11:19:03+08:002015-07-23T11:19:03+08:00 这取决于使用的模式(缓冲/非缓冲),如 PHP 手册中所述: 查询默认使用缓冲模式。这意味着查询结果会立即从 MySQL 服务器传输到 PHP,然后保存在 PHP 进程的内存中。这允许进行额外的操作,例如计算行数和移动(查找)当前结果指针。它还允许在处理结果集时在同一连接上发出进一步的查询。缓冲模式的缺点是较大的结果集可能需要大量内存。内存将一直被占用,直到所有对结果集的引用都被取消设置或结果集被显式释放,这将在最近一次请求结束时自动发生。术语“存储结果”也用于缓冲模式,因为整个结果集是一次性存储的。 延伸阅读 http://php.net/manual/en/mysqlinfo.concepts.buffering.php http://dev.mysql.com/doc/apis-php/en/apis-php-mysqlinfo.concepts.buffering.html 这是对您问题的“正文”的回答。该问题的标题询问有关临时表的问题,这是 MySQL 内部的另一回事。如果您也对此感兴趣,请参阅 https://dev.mysql.com/doc/refman/5.5/en/internal-temporary-tables.html 简单地说,MySQL 将小而简单的临时结果存储在内存中,而较大的和/或用于一些更复杂操作的结果通常存储在磁盘上的临时文件夹中。
这取决于使用的模式(缓冲/非缓冲),如 PHP 手册中所述:
延伸阅读
这是对您问题的“正文”的回答。该问题的标题询问有关临时表的问题,这是 MySQL 内部的另一回事。如果您也对此感兴趣,请参阅 https://dev.mysql.com/doc/refman/5.5/en/internal-temporary-tables.html
简单地说,MySQL 将小而简单的临时结果存储在内存中,而较大的和/或用于一些更复杂操作的结果通常存储在磁盘上的临时文件夹中。