按列分组的数据库中的不同的最新数据

hujrc8aj  于 2021-06-25  发布在  Mysql
关注(0)|答案(1)|浏览(388)

我正在数据库中存储数据。存储的数据如下所示

vin                    date_traitement
    VF15R060H54847102   2018-04-05 00:00:00
    UU1HSDC9553072004   2017-08-07 15:01:00
    UU1HSDC9553072004   2017-08-07 14:51:00
    VF15R060H54847102   2017-08-07 14:57:00

在我的控制器中,我试图检索不同的vin,但获取每个vin的最新插入版本以提取到excel。目前我正在努力

return Bddrenault::groupBy('vin')->orderBy('date_traitement', 'desc')
             ->get()
             ->map(function ($item, $key) {
             return (array) $item;
             })
             ->all();

问题是,这是返回的excel文件为空,我试图得到这个

vin                    date_traitement
    VF15R060H54847102   2018-04-05 00:00:00
    UU1HSDC9553072004   2017-08-07 15:01:00

我怎样才能做到这一点?
谢谢

zzzyeukh

zzzyeukh1#

使用此选项:

$join = Bddrenault::select('vin')
    ->selectRaw('MAX(`date_traitement`) `date_traitement`')
    ->groupBy('vin');
$sql = '(' . $join->toSql() . ') as `voiture`';
Bddrenault::select('id', 'bd.vin', 'bd.date_traitement')
    ->from('bddrenaults as bd')
    ->join(DB::raw($sql), function($join) {
        $join->on('bd.vin', 'voiture.vin')
            ->on('bd.date_traitement', 'voiture.date_traitement');
    })->get();

相关问题