optimus/genie

3.3.5 2023-12-28 13:00 UTC

README

Latest Version Software License Build Status Coverage Status Total Downloads

介绍

Eloquent 的基础仓库类,包含大多数查询的便捷方法。有助于将持久层从业务代码中抽象出来。

献给 Genie

献给世界上最好的(也是唯一的)瓶中精灵。 恭喜你获得自由,我的朋友

安装

适用于 Laravel 5.4 及以上版本

composer require optimus/genie ~2.0

适用于 Laravel 5.3 及以下版本

composer require optimus/genie ~1.0

实现

以下示例将使用一个名为 User 的假设 Eloquent 模型。

<?php

namespace App\Repositories;

use App\Models\User;
use Optimus\Genie\Repository;

class UserRepository extends Repository
{
    protected function getModel()
    {
        return new User;
    }
}

选项

Genie 已经与 Optimus\Bruno 集成。有关更多信息,请参阅 Bruno 文档。所有 get 方法的 $options 键采用以下格式

注意: 如果你使用 Bruno 的控制器,它将自动将请求的查询字符串解析为正确的格式。

API

以下示例将使用一个名为 User 的假设 Eloquent 模型。

get (array $options = [])

获取所有 User

getById ($id, array $options = [])

通过主键获取一个 User

getRecent (array $options = [])

created_at 降序获取 User

getRecentWhere (string $column, mixed $value, array $options = [])

获取 User 行,其中 $column=$value,按 created_at 降序排序

getWhere (string $column, mixed $value, array $options = [])

获取 User 行,其中 $column=$value

getWhereArray (array $clauses, array $options = [])

通过多个 where 子句([$column1 => $value1, $column2 => $value2])获取 User

getWhereIn (string $column, array $values, array $options = [])

获取 User 行,其中 $column 可以是 $values 中给出的任何值

getLatest (array $options = [])

获取最新的 User

getLatestWhere (string $column, mixed $value, array $options = [])

获取最新的 User,其中 $column=$value

delete ($id)

通过主键删除 User

deleteWhere ($column, $value)

删除 User 行,其中 $column=$value

deleteWhereArray (array $clauses)

通过多个 where 子句([$column1 => $value1, $column2 => $value2])删除 User

标准

本包符合 PSR-1PSR-2PSR-4。如果你注意到符合标准的问题,请通过 pull request 发送补丁。

测试

$ phpunit

贡献

请参阅 CONTRIBUTING 以获取详细信息。

许可

MIT 许可证(MIT)。有关更多信息,请参阅 许可文件