How to use groupBy() to group a Collection object(如何使用groupBy()对集合对象进行分组)
本文介绍了如何使用groupBy()对集合对象进行分组的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我的目标是检索用户的所有"项目",然后在我的视图中按他们的"状态"分组显示。有4种可能的状态,每种状态在包含项目信息的页面上都有自己的<div>
。经过一番摸索之后,我认为我需要使用groupBy()
方法,如下所示:
$items = Item::ownedBy( Auth::id() )->groupBy('status')->get();
这似乎确实进行了某种分组,但是当我迭代集合时,我最多只能得到4个结果,每个状态对应一个结果。这并没有真正解决我的问题,因为我需要为每个状态显示用户的所有项目,而不是只显示一个项目。我肯定在这里遗漏了一些东西,我真的希望避免查询每个状态并以这种方式显示它们。我想我可以按状态对收藏进行过滤操作并创建4个新收藏,但这不是groupBy()
应该做的吗?
推荐答案
您可以使用LARLAVEL和COLLECTIONS非常容易地做到这一点。集合有强大的API和很多方便的方法,可以轻松实现您想要的功能。
这里的错误在于您在QueryBuilder对象上调用groupBy,该对象仅返回数据库中按记录分组的记录。相反,您必须选择所需的所有记录,然后它们将作为集合返回。之后,您可以随心所欲地操作集合。因此,您需要的是:$items = Item::ownedBy( Auth::id() )->get()->groupBy('status');
您可以查看Colletion类的所有有用方法here。
这篇关于如何使用groupBy()对集合对象进行分组的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何使用groupBy()对集合对象进行分组
基础教程推荐
猜你喜欢
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01
- 在多维数组中查找最大值 2021-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- 超薄框架REST服务两次获得输出 2022-01-01