Change eagerloaded array keys
Change eagerloaded array keys
I've got several eager loaded
relations in Laravel 5.6
. I would like to change the array key name to a property on the eager loaded object.
eager loaded
Laravel 5.6
So let's say I have eager loaded this:
How do I make sure that array key 0
and 1
become the name property ("COSTS
" and "SAIL_BOAT_FRIENDLY
") ?
0
1
COSTS
SAIL_BOAT_FRIENDLY
Is that even possible?
-- EDIT
return Port::filter($filters)
->with('scores')
->actives()
->paginate(14);
Scores relation
public function scores()
return $this->hasMany(Score::class)
->select("id", "port_id", "name", DB::raw('AVG(score) as score'))
->groupBy('port_id', 'name');
1 Answer
1
You can use keyBy()
:
keyBy()
$ports = Port::filter($filters)
->with('scores')
->actives()
->paginate(14);
foreach($ports as $port)
$port->setRelation('scores', $port->scores->keyBy('name'));
Thanks for contributing an answer to Stack Overflow!
But avoid …
To learn more, see our tips on writing great answers.
Required, but never shown
Required, but never shown
By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.