Eloquent ORM 无疑是十分弱小的,为开发者提供了许多好用的查问结构器。有时候,现有的查问结构器不能满足咱们的要求时,咱们也能够自定义。
模型层父类继承 Eloquent Model ,在构造方法中利用 macro 注册自定义的 builder。示例代码如下:
class Model extends \Illuminate\Database\Eloquent\Model
{
public function __construct(array $attributes = [])
{
/**
* 自定义 builder
*/
/**
* page() 办法
* 参数: $page 页数 ;$limit 每页展现多少条
* 应用办法:query链式调用
*/
\Illuminate\Database\Query\Builder::macro('page', function ($page, $limit) {
return $this->limit($limit)->offset(($page - 1) * $limit);
});
parent::__construct($attributes);
}
}
Users 模型继承自 Model,在控制器中应用如下示例。
class UsersController extends Controller
{
public function index()
{
// TODO:接管参数 $page 和 $limit
$result = [
'list' => Users::query()->with('XXX')->page($page, $limit)->get(),
'total' => Users::select('id')->count(),
];
return json(200, $result);
}
}
finished!
PS:其实文中自定义的 page() ,与 Eloquent Model 中自带办法 perPage() 性能统一,所以自定义 page() 办法仅作示例应用。
发表回复