All multi-result sets returned by Eloquent are an instance of the Illuminate\Database\Eloquent\Collection object, including results retrieved via the get method or accessed via a relationship. The Eloquent collection object extends the Laravel base collection, so it naturally inherits dozens of methods used to fluently work with the underlying array of Eloquent models.

Of course, all collections also serve as iterators, allowing you to loop over them as if they were simple PHP arrays:

$users = App\User::where('active', 1)->get();

foreach ($users as $user) {
    echo $user->name;

However, collections are much more powerful than arrays and expose a variety of map / reduce operations that may be chained using an intuitive interface. For example, let's remove all inactive models and gather the first name for each remaining user:

$users = App\User::where('active', 1)->get();

$names = $users->reject(function ($user) {
    return $user->active === false;
->map(function ($user) {
    return $user->name;

Note: While most Eloquent collection methods return a new instance of an Eloquent collection, the pluck, keys, zip, collapse, flatten and flip methods return a base collection instance.

Available Methods

The Base Collection

All Eloquent collections extend the base Laravel collection object; therefore, they inherit all of the powerful methods provided by the base collection class:

all first intersect prepend shift toArray
chunk flatten isEmpty pull shuffle toJson
collapse flip keyBy push slice transform
contains forget keys put sort unique
count forPage last random sortBy values
diff get map reduce sortByDesc where
each groupBy merge reject splice whereLoose
every has pluck reverse sum zip
filter implode pop search take  

Custom Collections

If you need to use a custom Collection object with your own extension methods, you may override the newCollection method on your model:


namespace App;

use App\CustomCollection;
use Illuminate\Database\Eloquent\Model;

class User extends Model
     * Create a new Eloquent Collection instance.
     * @param  array  $models
     * @return \Illuminate\Database\Eloquent\Collection
    public function newCollection(array $models = [])
        return new CustomCollection($models);

Once you have defined a newCollection method, you will receive an instance of your custom collection anytime Eloquent returns a Collection instance of that model. If you would like to use a custom collection for every model in your application, you should override the newCollection method on a model base class that is extended by all of your models.