首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Leftjoin with groupby跳过groupby

Leftjoin with groupby跳过groupby
EN

Stack Overflow用户
提问于 2019-06-28 17:10:49
回答 1查看 24关注 0票数 1

我有一些用户,我想要通过左连接表进行锻炼并为每个用户获得一行来进行计数。所以那些只在健身表中出现过一次或更多的用户,但我只需要每个user_id一行。

这是通过在原始sql查询中使用in来实现的,但尝试在laravel中对其进行格式化则不起作用:

代码语言:javascript
复制
$users->leftJoin('workout', function($join){
  $join->on('user.id', '=', 'workout.user_id')
  ->where('workout.user_id', '>', 1)
  ->groupBy('workout.user_id');
})

这是一个与原始查询相同的查询:

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

发布于 2019-06-28 17:23:20

将groupby移出您的join闭包。

代码语言:javascript
复制
$users->leftJoin('workout', function ($join) {
    $join->on('user.id', '=', 'workout.user_id')
    ->where('workout.user_id', '>', 1);
})
->groupBy('workout.user_id')
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56804066

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档