微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将 sql 查询存储在列表中时,PHP 内存耗尽

如何解决将 sql 查询存储在列表中时,PHP 内存耗尽

我想在列表中获取 sql 查询的结果,但由于它有很多数据,因此会导致内存耗尽。

致命错误:允许的内存大小为 536870912 字节已用尽(尝试分配 20480 字节)

这就是我尝试这样做的方式。有没有另一种方法不会导致内存耗尽?增加内存是不可能的,因为会出现更大的数据集。

$sql = $pdoconnect->query('SELECT id FROM contacts');
$id_liste = $sql->fetchAll();

我已经用循环尝试过,但结果是一样的:

while($row = $statement->fetch()){
    $id_liste[] = $row['id'];  }

解决方法

使用发电机。这就是它们的设计目的。

像这样重写你的代码:

function fetchContacts()
{

   $result = $this->db->query('SELECT * FROM contacts');

   while($record = $result->fetch(PDO::FETCH_ASSOC)) {

       yield $record;

   }
}

// Then elsewhere in your code where you actually use the contacts:
foreach (fetchContacts() as $contact) {
    // All of your code here.
}

PHP 只会使用每个字段而不是每条记录所需的内存。它应该可以工作。

另外,尝试在 SQL 中使用 LIMIT,因为您可能不想一次处理所有 100,000 个联系人,对吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。