Laravel SQL从Join表

时间:2016-07-12 14:14:40

标签: php laravel-5

我正在使用以下代码创建一个带连接的查询。

$query      =   rs_vehicles::select(   
                            'rs_vehicles.id',
                            'rs_vehicles.type', 
                            'rs_vehicles.make', 
                            'rs_vehicles.model',
                            'rs_vehicles.year',
                            'rs_vehicles.status',
                            'rs_vehicle_regs.registration'

                            );            

    $query      ->leftJoin('rs_vehicle_regs', function($join){

                    $join->on('rs_vehicle_regs.rs_vehicles_id', '=', 'rs_vehicles.id')
                         ->where('rs_vehicle_regs.registration_date', '=',
                                DB::raw("(select max(registration_date) from rs_vehicle_regs where rs_vehicles_id = rs_vehicles.id)"));
                });       

    $rsGrid =   $query->get();

这会生成以下sql语句:

select rs_vehicles.id, rs_vehicles.type, rs_vehicles.make, 
s_vehicles.model, rs_vehicles.year, rs_vehicles.status, 
s_vehicle_regs.registration from rs_vehicles 
left join rs_vehicle_regs 
on rs_vehicle_regs.rs_vehicles_id = rs_vehicles.id 
and rs_vehicle_regs.registration_date = (select max(registration_date) from rs_vehicle_regs where rs_vehicles_id = rs_vehicles.id)

当我在MySQL Workbench中执行它时,Laravel生成的SQL语句运行完美,它会带回 ALL 字段的预期值。但是,当我在Laravel中执行代码时,虽然脚本运行完美且没有错误并且带回了几乎所有必需的数据,但是在连接表中的'rs_vehicle_regs.registration'字段返回为null。我花了很多年时间试图解决这个问题而且我无处可去。任何人都知道为什么这不会在Laravel工作?我的智慧结束了。

我尝试将get()更改为toSql()并获得以下内容

select `rs_vehicles`.`id`, `rs_vehicles`.`type`, `rs_vehicles`.`make`, `rs_vehicles`.`model`, `rs_vehicles`.`year`, `rs_vehicles`.`vehicle_status`, `vh_type`.`display_text` as `type_text`, `vh_status`.`display_text` as `vehicle_status_text`, `rs_vehicle_regs`.`registration` as `registration` from `rs_vehicles` left join `app_params` as `vh_type` on `rs_vehicles`.`type` = `vh_type`.`list_value` and `vh_type`.`param_type` = ? left join `app_params` as `vh_status` on `rs_vehicles`.`vehicle_status` = `vh_status`.`list_value` and `vh_status`.`param_type` = ? left join `rs_vehicle_regs` on `rs_vehicle_regs`.`rs_vehicles_id` = `rs_vehicles`.`id` where `rs_vehicles`.`status` = ?

我也尝试了以下内容:

        $query      ->leftJoin('rs_vehicle_regs', function($join){
                $join->on('rs_vehicle_regs.rs_vehicles_id', '=', 'rs_employees.rs_vehicles_id')
                     ->where('rs_vehicle_regs.registration_date', '=', 'max(registration_date)'); 
            });    

这会产生与原始查询完全相同的结果,其中对象作为字段但值为null。

然后我尝试了这个:

$query      ->leftJoin('rs_vehicle_regs', 'rs_vehicle_regs.rs_vehicles_id', '=', 'rs_vehicles.id');

这个连接工作并带回我正在寻找的数据但是如果连接表有多个与父表相关的条目,我可以发生所有返回的记录,我只想要一条记录是max(registration_date)。这让我完全难过。

0 个答案:

没有答案