像all()和get(),还有一些处理模型关系这种会返回多条数据的方法,在Eloquent里面会返回一个collection对象集合(对象装在对象里),而不是像DQB的数组结果集合(对象装在数组里)。Collection其实前面已经讲过了,它是在数据查询出来后,提供了一系列处理数据的方法,很是强大实用。数组
首先,全部的collection均可以遍历:spa
$users = App\User::where('active', 1)->get();
foreach ($users as $user) {
echo $user->name;
}
可是,collection的能力远远不止于此,很是强大,例如:code
$users = App\User::all();
$names = $users->reject(function ($user) {
return $user->active === false;
})
->map(function ($user) {
return $user->name;
});
这段代码把全部非激活状态的用户去除,并把剩余用户的名字列出来;对象
请参考官网。继承
主要方法是覆盖newCollection()
方法:get
namespace App;
use App\CustomCollection;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
public function newCollection(array $models = [])
{
return new CustomCollection($models);
}
}
`
CustomCollection()就是你自定义的一个类;在里面你能够组织返回collection的内容;it
目前这个方法只是对Usermodel适用,若是你想对全部适用,能够把覆盖方法放到一个全部模型都继承的基类中去。io