Laravel how to add a new field to the query result

How to add a new field to each element I used put(), but it only adds the last element.

return self::where('latest', 1)
            ->where('competitionId',$competitionId)
            ->orderBy('won','desc')
            ->orderBy('teamName','asc')
            ->get(['teamName','played','won','lost','percentage', 'streak'])
            ->put('test', ['123', '345'])
            ->toJson();

Result:

{
"0": {"teamName": "A"},
"1": {"teamName": "B"},
"2": {"teamName": "C", "test": ['123', '345']},
}

Expected Result:

{
"0": {"teamName": "A", "test": "qwerty"},
"1": {"teamName": "B", "test": "qwerty"},
"2": {"teamName": "C", "test": "qwerty"},
}
+4
source share
1 answer

you can use map ()

->map(function ($item) {
  $item['test'] = ['123', '345'];
  return $item;
});
+5
source

Source: https://habr.com/ru/post/1598363/


All Articles