public function export()
{
$where = [];
$total = Order::where($where)->count();
if ($total == 0) {
return '无数据';
}
$title = ['订单号', '商品名称', '规格', '数量','订单价格','创建时间', '订单状态','收货人姓名','电话','省份','市区','区域','地址'];
set_time_limit(0);
ini_set('memory_limit', '5M');
$fileName = '订单信息统计'.date('Y-m-d');
header('Content-Encoding: UTF-8');
header("Content-type:application/vnd.ms-excel;charset=UTF-8");
header('Content-Disposition: attachment;filename="' . $fileName . '.csv"');
$fp = fopen('php://output', 'a');
fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF));
fputcsv($fp, $title);
$sqlLimit = 500;
for($i = 0;$i < ceil($total/$sqlLimit);++$i){
$lists = Db::table('orders as a')
->leftJoin('address_users as b','a.address_id' ,'=' ,'b.id')
->leftJoin('product_skus as c','a.sku_id','=','c.id')
->leftJoin('product_spus as d','c.product_id','=','d.id')
->where($where)
->select('a.order_no','d.title','c.attrbute_text','a.num','a.amount','a.created_at','a.status','b.name','b.mobile','b.province','b.city','b.area','b.address')
->forPage($i,$sqlLimit)
->get()
->map(function ($value) {
$value->status = $this->orderStatus[$value->status];
return $value;
});
$lists = self::yieldData($lists);
foreach($lists as $r) {
$r->order_no = "\t".$r->order_no;
fputcsv($fp, (array)$r);
}
ob_flush();
flush();
}
}
public static function yieldData($data)
{
foreach ($data as $datum){
yield $datum;
}
}
|