| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 | <?php// +----------------------------------------------------------------------// | Niucloud-admin 企业快速开发的saas管理平台// +----------------------------------------------------------------------// | 官方网址:https://www.niucloud.com// +----------------------------------------------------------------------// | niucloud团队 版权所有 开源版本可自由商用// +----------------------------------------------------------------------// | Author: Niucloud Team// +----------------------------------------------------------------------namespace core\base;use app\validate\sys\Page;use think\db\exception\DbException;use think\Model;/** * 基础服务层 * Class BaseService * @package app\service */abstract class BaseService{    /**     * Model 实例     * @var BaseModel     */    protected $model;    protected $request;    public function __construct()    {        $this->request = request();    }    /**     * 分页列表参数(页码和每页多少条)     * @return mixed     */    public function getPageParam()    {        $page = request()->params([            ['page', 1],            ['limit', 15]        ]);        validate(Page::class)            ->check($page);        return $page;    }    /**     * 分页列表     * @param Model $model     * @param array $where     * @param string $field     * @param string $order     * @param array $append     * @return array     * @throws DbException     */    public function getPageList(Model $model, array $where, string $field = '*', string $order = '', array $append = [], $with = null, $each = null)    {        $page_params = $this->getPageParam();        $page = $page_params['page'];        $limit = $page_params['limit'];        $list = $model->where($where)->when($append, function ($query) use ($append) {            $query->append($append);        })->when($with, function ($query) use ($with) {            $query->with($with);        })->field($field)->order($order)->paginate([            'list_rows' => $limit,            'page' => $page,        ]);        if (!empty($each)) {            $list = $list->each($each);        }        return $list->toArray();    }    /**     * 分页数据查询,传入model(查询后结果)     * @param $model BaseModel     * @return array     * @throws DbException     */    public function pageQuery($model, $each = null)    {        $page_params = $this->getPageParam();        $page = $page_params['page'];        $limit = $page_params['limit'];        $list = $model->paginate([            'list_rows' => $limit,            'page' => $page,        ]);        if (!empty($each)) {            $list = $list->each($each);        }        return $list->toArray();    }    /**     * 分页视图列表查询     * @param Model $model     * @param array $where     * @param string $field     * @param string $order     * @param array $append     * @return array     * @throws DbException     */    public function getPageViewList(Model $model, array $where, string $field = '*', string $order = '', array $append = [], $with = null, $each = null)    {        $page_params = $this->getPageParam();        $page = $page_params['page'];        $limit = $page_params['limit'];        $list = $model->where($where)->when($append, function ($query) use ($append) {            $query->append($append);        })->when($with, function ($query) use ($with) {            $query->withJoin($with);        })->field($field)->order($order)->paginate([            'list_rows' => $limit,            'page' => $page,        ]);        if (!empty($each)) {            $list = $list->each($each);        }        return $list->toArray();    }}
 |