关于php:Eloquent-ORM-自定义-builder

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() 办法仅作示例应用。

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理