使用 laravel-repository 扩展包实现对模型类操作的封装
简介
更多关于 Repository 的使用说明,请戳这里Repository文档地址
laravel-repository
提供了基础的 repository
类, 对laravel 的 model 进行了的封装,提供更多的对外的方法,以及更友好的编辑器提示;对代码进行了的分层,repository
负责对外的业务逻辑处理,model
只负责对数据表的字段、属性、查询条件、返回值的定义,不参与具体的逻辑运算,不对控制层服务.
相对于直接使用model
优势:
- 用操作
数组
的方式操作数据库模型. (php中还有什么比数组用起来更爽的数据结构呢?) - 解决
model
在新增、修改时不自动处理多余字段问题 - 优化
model
查询时的链式调用,直接使用数组的方式进行查询 - 通过查询条件和查询字段,自动处理对应的关联数据查询
- 提供了更友好的编辑器提示
安装使用
安装要求
- PHP >= 7.0.0
- Laravel >= 5.5.0
1.1 安装
composer require littlebug/laravel-repository
1.2 使用命令生成 model
和 repository
假设你的数据库中有一张表 users, 或者你将 users 替换为你数据库中的表名称
php artisan core:model --table=users --name=User
该命令会在:
app/Models/
文件下生成User
文件app/Repositories/
文件下生成UserRepository
文件
1.3 在控制器中使用 repository
use App\Repositories\UserRepository;
class UsersController extends Controller
{
/**
* @var UserRepository
*/
private $userRepository;
public function __construct(UserRepository $userRepository)
{
$this->userRepository = $userRepository;
}
public function index()
{
// 分页查询
$list = $this->userRepository->paginate([ 'name:like' => 'test123', 'status:in' => [1, 2]]);
return view('users.index');
}
public function create()
{
list($ok, $msg, $user) = $this->userRepository->create(request()->all());
// 你的逻辑
}
public function update()
{
list($ok, $msg, $row) = $this->userRepository->update(request()->input('id'), request()->all());
// 你的逻辑
}
public function delete()
{
list($ok, $msg, $row) = $this->userRepository->delete(request()->input('id'));
// 你的逻辑
}
}
1.3.1 关于分页查询数据
更多的代码生成命令
命令都支持指定数据库连接 例如 --table=dev.users
core:model
通过查询数据库表信息生成model
类文件 和repository
类文件
php artisan core:model --table=users --name=User
core:repository
生成repository
类文件
php artisan core:repository --model=User --name=UserRepository
core:request
通过查询数据库表信息生成request
验证类文件
php artisan core:request --table=users --path=Users
1 Comment
666666666666