faisalrizal / genie
Requires
- faisalrizal/bruno: ~3.0
- illuminate/database: >=4.0
Requires (Dev)
- mockery/mockery: 0.9.*
- phpunit/phpunit: ~4.7
- satooshi/php-coveralls: dev-master@dev
README
简介
为 Eloquent 提供一个基础仓库类,其中包含覆盖大多数查询的便捷方法。有助于将持久化层从业务代码中抽象出来。
致 Genie
致世界上最优秀(也是唯一)的瓶中精灵。 恭喜你获得自由,我的朋友。
安装
composer require faisalrizal/genie
实现
以下示例将使用一个假设的 Eloquent 模型 User
。
<?php namespace App\Repositories; use App\Models\User; use Jasahub\Genie\Repository; class UserRepository extends Repository { protected function getModel() { return new User; } }
选项
Genie 已与 Optimus\Bruno 集成。有关更多信息,请参阅 Bruno 文档。所有 get 方法给出的 $options
键采用以下格式
注意: 如果您使用 Bruno 的控制器,它将自动将请求的查询字符串解析为正确的格式。
API
以下示例将使用一个假设的 Eloquent 模型 User
。
get (array $options = [])
获取所有 User
行
getById ($id, array $options = [])
通过主键获取一个 User
getRecent (array $options = [])
按 created_at
降序获取 User
行
getRecentWhere (string $column, mixed $value, array $options = [])
按 created_at
降序获取 $column=$value
的 User
行
getWhere (string $column, mixed $value, array $options = [])
获取 $column=$value
的 User
行
getWhereArray (array $clauses, array $options = [])
通过多个 where 子句获取 User
行 ([$column1 => $value1, $column2 => $value2]
)
getWhereIn (string $column, array $values, array $options = [])
获取 $column
可为 $values 中给定值的 User
行
getLatest (array $options = [])
获取最新的 User
getLatestWhere (string $column, mixed $value, array $options = [])
获取 $column=$value
的最新 User
delete ($id)
通过主键删除 User
行
deleteWhere ($column, $value)
删除 $column=$value
的 User
行
deleteWhereArray (array $clauses)
通过多个 where 子句删除 User
行 ([$column1 => $value1, $column2 => $value2]
)
标准
本软件包符合 PSR-1、PSR-2 和 PSR-4。如果您注意到有违规之处,请通过 pull request 发送补丁。
测试
$ phpunit
贡献
有关详细信息,请参阅 CONTRIBUTING。
许可
MIT 许可证 (MIT)。有关更多信息,请参阅 许可文件。