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

下面是我正在做的事情:
$prices = $hotel->prices()->groupBy('room_id')->get();发布于 2016-08-18 15:35:52
有一种方法可以像你想要的那样分组。当eloquent执行查询时,您可以对集合返回使用groupBy()。诀窍是在数据库检索之后执行groupBy()。有关更多信息,请查看this。
示例如下所示:
$prices = $hotel->prices()->get(); // Returns a Collection of results
$prices = $prices->groupBy('room_id'); // Grouped by room_id这将产生一个如下所示的集合:
[
'39' => [
// 1 row
],
'40' => [
// 1 row
],
'17' => [
// 2 rows
],
.....
]此数组的键将表示room_id。在每个键上,此数组将是另一个数组,其中包含具有指定room_id的行。
希望这能有所帮助:)
https://stackoverflow.com/questions/38995911
复制相似问题