加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – CodeIgniter Active Record:一次加载一行

发布时间:2020-12-13 13:51:28 所属栏目:PHP教程 来源:网络整理
导读:文档中描述的正常result()方法似乎立即加载所有记录.我的应用程序需要加载大约30,000行,并且一次一个,将它们提交给第三方搜索索引API.显然,一次将所有内容加载到内存中并不能很好地工作(由于内存过多而导致错误). 所以我的问题是,如何实现传统MySQLi API方法
文档中描述的正常result()方法似乎立即加载所有记录.我的应用程序需要加载大约30,000行,并且一次一个,将它们提交给第三方搜索索引API.显然,一次将所有内容加载到内存中并不能很好地工作(由于内存过多而导致错误).

所以我的问题是,如何实现传统MySQLi API方法的效果,在循环中一次加载一行?

这是你可以做的事情.
while ($row = $result->_fetch_object()) {
  $data = array(
    'id'         => $row->id
    'some_value' => $row->some_field_name
  );
  // send row data to whatever api
  $this->send_data_to_api($data);
}

这将在当时获得一行.检查CodeIgniter源代码,您将看到执行result()方法时它们将执行此操作.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读