使用 laravel-repository 扩展包实现对模型类操作的封装

简介

更多关于 Repository 的使用说明,请戳这里Repository文档地址

laravel-repository 提供了基础的 repository 类, 对laravelmodel 进行了的封装,提供更多的对外的方法,以及更友好的编辑器提示;对代码进行了的分层,repository 负责对外的业务逻辑处理,model 只负责对数据表的字段、属性、查询条件、返回值的定义,不参与具体的逻辑运算,不对控制层服务.

相对于直接使用model优势:

  • 用操作数组的方式操作数据库模型. (php中还有什么比数组用起来更爽的数据结构呢?)
  • 解决model在新增、修改时不自动处理多余字段问题
  • 优化model查询时的链式调用,直接使用数组的方式进行查询
  • 通过查询条件和查询字段,自动处理对应的关联数据查询
  • 提供了更友好的编辑器提示

安装使用

安装要求

  • PHP >= 7.0.0
  • Laravel >= 5.5.0

1.1 安装

composer require littlebug/laravel-repository

1.2 使用命令生成 modelrepository

假设你的数据库中有一张表 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 关于分页查询数据

member message 的数据

关于repository更多使用方法请查看

更多的代码生成命令

命令都支持指定数据库连接 例如 --table=dev.users

  1. core:model 通过查询数据库表信息生成 model 类文件 和 repository 类文件
	php artisan core:model --table=users --name=User
  1. core:repository 生成 repository 类文件
	php artisan core:repository --model=User --name=UserRepository  
  1. core:request 通过查询数据库表信息生成 request 验证类文件
	php artisan core:request --table=users --path=Users

上一篇: 推荐:好用的 Laravel Repository 包

下一篇: 基于 Laravel Prequel 扩展包通过 Web 界面管理 MySQL 数据库