在Laravel中,如果我执行查询:
$foods = Food::where(...)->get();
… then $ food是Illuminate Collection的Food模型对象。 (本质上是一个模型数组。)
然而,这个数组的键简单:
[0, 1, 2, 3, ...]
…所以如果我想改变,说,Food对象的ID为24,我不能这样做:
$desired_object = $foods->get(24);
$desired_object->color = 'Green';
$desired_object->save();
…因为这只会改变数组中的第25个元素,而不是id为24的元素。
如何通过ANY属性/列(例如但不限于id / color / age /等)从集合中获取单个(或多个)元素?
当然,我可以这样做:
foreach ($foods as $food) {
if ($food->id == 24) {
$desired_object = $food;
break;
}
}
$desired_object->color = 'Green';
$desired_object->save();
…但是,这只是粗略。
当然,我可以这样做:
$desired_object = Food::find(24);
$desired_object->color = 'Green';
$desired_object->save();
…但是这更粗糙,因为它执行额外的不必要的查询,当我已经在$ foods集合中所需的对象。
感谢您的任何指导。
编辑:
要清楚,您可以在Illuminate集合上调用 – > find(),而不生成另一个查询,但它只接受主ID。例如:
$foods = Food::all();
$desired_food = $foods->find(21); // Grab the food with an ID of 21
但是,仍然没有干净(非循环,非查询)方式来从集合的属性抓取元素,如下所示:
$foods = Food::all();
$green_foods = $foods->where('color', 'green'); // This won't work. :(