• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php如何实现百万级数据快速导出CSV

php 搞代码 4年前 (2022-01-04) 20次浏览 已收录 0个评论

在php中,可以使用了服务器的缓存来实现百万级数据快速导出CSV,今天就带大家学习一下快速导出csv的方式,有需要的可以参考参考。

php实现百万级数据导出这里使用了服务器的缓存来实现

实现:

一:建立测试表,并加入测试数据

1:创建测试表

这里我建了一个test表,字段分别为:id,name,age,email

2:加入测试数据

(1)首先手动向表中添加若干行数据

然后执行如下命令批量添加数据

INSERT INTO test (name,age,email) SELECT name,age,email FROM test;

多次执行上面的命令测试数据会呈指数增加,这样就可以得到很多测试数据

二:php实现导出百万级数据(这里我的查询命令使用的时Yii框架自带的查询命令)

//让程序一直运行
set_time_limit(0);
//设置程序运行内存
ini_set('memory_limit', '128M');
//导出文件名
$fileName = '测试导出数据';
header('Content-Encoding: UTF-8');
header("Content-type:application/vnd.ms-excel;charset=UTF-8");
header('Content-Disposition: attachment;filename="' . $fileName . '.csv"');
//打开php标准输出流
$fp = fopen('php://output', 'a');
//添加BOM头,<p style="color:transparent">来源gao!daima.com搞$代!码网</p>以UTF8编码导出CSV文件,如果文件头未添加BOM头,打开会出现乱码。
fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF));
//添加导出标题
fputcsv($fp, ['姓名', '岁数', '邮箱']);
$nums = 10000; //每次导出数量
$count = Test::find()->count();
$step = ceil($count/$nums);//循环次数
for($i = 0; $i < $step; $i++) {
    $result = Test::find()
        ->select(['name', 'age', 'email'])
        ->limit($nums)
        ->offset($i * $nums)
        ->asArray()
        ->all();
    foreach ($result as $item) {
        fputcsv($fp, $item);
    }
    //每1万条数据就刷新缓冲区
    ob_flush();
    flush();
}
exit;

如上测试后可以发现导出一百万左右数据只需十几秒左右时间,效率还算是不错的

以上就是php如何实现百万级数据快速导出CSV的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php如何实现百万级数据快速导出CSV

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址