如何一次性取10w条数据php,PHP有什么办法 可以把10万条记录一次性导出到Excel里?...

PHP有什么办法 可以把10万条记录一次性导出到Excel里?

回复内容:

PHP有什么办法 可以把10万条记录一次性导出到Excel里?

使用MYSQLI_USE_RESULT无缓冲查询,细水长流,逐条从MySQL获取,在循环fetch_row里fputcsv($fp, $row)逐条写入数据到文件,然后提供给用户下载.代码逻辑大概如下:query($sql, MYSQLI_USE_RESULT); //无缓冲查询

while ($row = $result->fetch_row()) { //逐条读取(无缓冲查询)

fputcsv($fp, $row); //逐条写入

}

fclose($fp);

header('Content-Disposition: attachment; filename="file.csv"');

readfile('file.csv');

你正常下载就可以啊。

PHPExcel支持行缓存,将设置一个文件缓存即可。

https://github.com/PHPOffice/...

分批次写入,一次性导出10w条记录并进行写入容易出现超时的情况,建议根据服务器的性能情况及内容的大小进行测试

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值