php-在Laravel中使用groupby选择最新行
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php-在Laravel中使用groupby选择最新行,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1147字,纯文字阅读大概需要2分钟。
内容图文
![php-在Laravel中使用groupby选择最新行](/upload/InfoBanner/zyjiaocheng/662/bfe225c4decd471eb45e5f137c77ba1c.jpg)
我有一个类似以下的表项:
+---------+---------+----------+
| 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();
内容总结
以上是互联网集市为您收集整理的php-在Laravel中使用groupby选择最新行全部内容,希望文章能够帮你解决php-在Laravel中使用groupby选择最新行所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。