微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php-在Laravel中使用groupby选择最新行

我有一个类似以下的表项:

+---------+---------+----------+
| Test_id | User_id | Attempts |
+---------+---------+----------+
|      12 |       5 |        1 |
|      13 |       5 |        1 |
|      12 |       5 |        2 |
+---------+---------+----------+

现在,我想通过test_id选择elements组,并应获取最新条目.

我试过这个查询

$tests_took = Testresult::where('course_id', $courseId)
                        ->where('user_id', Auth::id())
                        ->groupby('test_id')
                        ->orderBy('attempts', 'desc')
                        ->get();

当我显示结果时,我仅获得前两行(一个test_id仅获得一行-这是我想要的.)但是,代替test_id = 12的最后一行,它显示的是第一行.我一直希望展示最大的尝试.

我当前的输出是这样的:

|      12 |       5 |        1 |
|      13 |       5 |        1 |

但是我想要这个:

|      12 |       5 |        2 |
|      13 |       5 |        1 |

我该如何实现?当我使用groupby时获得最新的行作为第一个数组元素,还是有其他方法可以做到这一点?

解决方法:

ORDER BY和GROUP BY配合不佳…

如果您只是想要每个test_id的最大尝试,我建议使用MAX()函数

$tests_took = Testresult::select('test_id', 'user_id', DB::raw('MAX(attempts) AS max_attempts'))
                ->where('course_id', $courseId)
                ->where('user_id', Auth::id())
                ->groupby('test_id')
                ->get();

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。