Laravel 集合返回数组

所以我有这张桌子


|id|    price    |  start_time |

--------------------------------

|1 |    45000.00 |  04:45:00   |

|1 |    45000.00 |  07:00:00   |

|2 |    40000.00 |  01:20:00   |

我想创建一个像这样返回 json 的集合


{

   id: 1

   price: 45000.00

   start_time: [

        04:45:00, 07:00:00

    ]

},

{

   id: 2

   price: 40000.00

   start_time: [

        01:20:00

    ]

}


我花了很多时间去弄清楚但我做不到


请帮我弄清楚,提前谢谢


三国纷争
浏览 78回答 1
1回答

当年话下

使用map() $laravelCollcetion->map(function($row){       return $row['start_time'] = [$row['start_time']]  })return $laravelCollcetion;参考链接https://laravel.com/docs/7.x/collections#extending-collections对于您的数据库实例,您可以这样做 $data = \DB::table('schedules')        ->select(\DB::raw('id, price,GROUP_CONCAT(start_time) as start_time'))        ->groupBy('id')        ->get();return $data;
打开App,查看更多内容
随时随地看视频慕课网APP