我有一些用户,我想要通过左连接表进行锻炼并为每个用户获得一行来进行计数。所以那些只在健身表中出现过一次或更多的用户,但我只需要每个user_id一行。
这是通过在原始sql查询中使用in来实现的,但尝试在laravel中对其进行格式化则不起作用:
$users->leftJoin('workout', function($join){
$join->on('user.id', '=', 'workout.user_id')
->where('workout.user_id', '>', 1)
->groupBy('workout.user_id');
})这是一个与原始查询相同的查询:
select * from `users`
left join (select workout.user_id, workout.id_holofit from workout where workout.user_id > 1 group by workout.user_id) workout ON workout.user_id = users.id发布于 2019-06-28 17:23:20
将groupby移出您的join闭包。
$users->leftJoin('workout', function ($join) {
$join->on('user.id', '=', 'workout.user_id')
->where('workout.user_id', '>', 1);
})
->groupBy('workout.user_id')https://stackoverflow.com/questions/56804066
复制相似问题