承接 blasttech/laravel-where-plus 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

blasttech/laravel-where-plus

最新稳定版本:2.0.3

Composer 安装命令:

composer require blasttech/laravel-where-plus

包简介

Extra where scopes for Laravel Eloquent

README 文档

README

Extra where scopes for Laravel Models

Functions:

  • whereOrEmptyOrNull($column, $value, $ignore)
  • whereInColumn($column, $value)
  • whereNotInColumn($column, $value)
  • whereIfNull($column, $ifNull, $operator = null, $value = null, $boolean = 'and')

whereOrEmptyOrNull

This adds a where condition for when a $column should be equal to $value, but not equal to a $ignore

  $query->whereOrEmptyOrNull('Country', $input['country'], '');

If $input['country'] is not equal to '' then this will be the equivalent of:

  $query->where('Country', $input['country']);

Otherwise if $input['country'] === '' then a where statement isn't added.

Likewise, a default value could be added, eg.

$query->whereOrEmptyOrNull('Country', $input['country'], 'Australia');

If you wanted to only add a where statement when $input['country'] isn't 'Australia'.

This can also be run with an array of columns, e.g.:

  $query->whereOrEmptyOrNull([
          'Country' => $input['country'],
          'State' => $input['state'],
          'Locality' => $input['locality']
      ], '', '');

which would add where statements for Country, State and Locality if the input fields weren't empty.

whereInColumn

This adds a where condition to only include records where $value is in $column. The value of $column should be a comma delimited list.

For example:

  $query->whereInColumn('Country', 'Australia');

In SQL, this would be the equivalent of:

  WHERE CONCAT(',', `Country`, ',') LIKE '%,Australia,%'

whereNotInColumn

This adds a where condition to only include records where $value is not in $column. The value of $column should be a comma delimited list.

For example:

  $query->whereNotInColumn('Country', 'Australia');

In SQL, this would be the equivalent of:

  WHERE CONCAT(',', `Country`, ',') NOT LIKE '%,Australia,%'

whereIfNull($column, $ifNull, $operator = null, $value = null, $boolean = 'and')

This adds a where condition with the column wrapped in an SQL 'IFNULL' with the column as the first parameter and $ifNull as the second parameter.

For example:

  $query->whereIfNull('Country', 'Australia', '=', 'New Zealand');

In SQL, this would be the equivalent of:

  WHERE IFNULL(`Country`, 'Australia') = 'New Zealand'

Aggregates

Available scopes

  • addCount
  • addSum
  • addAvg
  • addMin
  • addMax

Example

Calls::make()
  ->select(['calltype'])
  ->addCount('id')
  ->addSum('seconds')
  ->addSum('seconds', 'seconds2')
  ->groupBy('calltype');

In SQL, this would be the equivalent of:

  select calltype, count(id), sum(seconds), sum(charge) 
    from calls 
   group by calltype

Group and Order

Available scopes

  • groupByIndex
  • orderByIndex

Example

Calls::make()
  ->select(['calltype', 'description'])
  ->addSum('charge')
  ->groupByIndex(1, 2);
  ->orderByIndex(1);
  select calltype, description, sum(charge) 
    from calls 
   group by 1, 2
   order by 1

统计信息

  • 总下载量: 25.05k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 9
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-01-25