首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel - Eloquent group by

Laravel - Eloquent group by
EN

Stack Overflow用户
提问于 2016-08-17 19:53:48
回答 1查看 720关注 0票数 0

当我使用group by时,结果被分组,但并不是所有的结果都被返回。这里我有六个结果,但我只得到五个结果。因此,基本上room_id = 17获取条目103,而不返回条目106

下面是我正在做的事情:

代码语言:javascript
复制
$prices = $hotel->prices()->groupBy('room_id')->get();
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-08-18 15:35:52

有一种方法可以像你想要的那样分组。当eloquent执行查询时,您可以对集合返回使用groupBy()。诀窍是在数据库检索之后执行groupBy()。有关更多信息,请查看this

示例如下所示:

代码语言:javascript
复制
$prices = $hotel->prices()->get(); // Returns a Collection of results

$prices = $prices->groupBy('room_id'); // Grouped by room_id

这将产生一个如下所示的集合:

代码语言:javascript
复制
[
    '39' => [
        // 1 row
    ],
    '40' => [
        // 1 row
    ],
    '17' => [
        // 2 rows
    ], 
    .....
]

此数组的键将表示room_id。在每个键上,此数组将是另一个数组,其中包含具有指定room_id的行。

希望这能有所帮助:)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38995911

复制
相关文章

相似问题

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