3

我想为我的两张表创建一个汇总报告,一张是员工表,另一张是 sims 表。这些表具有一对多的关系。我知道我们可以使用导出模型的数据, ->fromModel($model) 但是有没有办法可以根据这两个表生成报告?

4

1 回答 1

13

所以,我问了一个问题,一个无法回答但懦弱的人给了-1。但是,我想出了如何手动执行此操作。发布代码,以便它可以帮助像我这样的未来初学者。

public function downloadSummary(){

        Excel::create('records', function($excel) {

            $excel->sheet('Sheet1', function($sheet) {
                $employees = Employee::all();

                $arr =array();
                foreach($employees as $employee) {
                    foreach($employee->sims as $sim){
                        $data =  array($employee->id, $employee->name, $employee->nic, $employee->address, $employee->title,
                            $sim->id, $sim->msisdn, $sim->imei, $sim->issued_to);
                        array_push($arr, $data);
                    }
                }

                //set the titles
                $sheet->fromArray($arr,null,'A1',false,false)->prependRow(array(
                        'Employee Id', 'Employee Name', 'Employee NIC', 'Employee Address', 'Employee Title',
                        'Sim Id', 'Sim MSISDN', 'IMEI', 'Issued To'
                    )

                );

            });

        })->export('xls');
    }
于 2015-11-02T21:16:09.877 回答