當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Builder::whereIn方法代碼示例

本文整理匯總了PHP中Illuminate\Database\Eloquent\Builder::whereIn方法的典型用法代碼示例。如果您正苦於以下問題:PHP Builder::whereIn方法的具體用法?PHP Builder::whereIn怎麽用?PHP Builder::whereIn使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Illuminate\Database\Eloquent\Builder的用法示例。


在下文中一共展示了Builder::whereIn方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: scopeWithTag

 public static function scopeWithTag(Builder $query, $tags, $type = 'slug')
 {
     $tags = (new static())->prepareTags($tags);
     return $query->whereHas('tags', function ($query) use($type, $tags) {
         $query->whereIn($type, $tags);
     });
 }
開發者ID:phantomlight,項目名稱:programme-chameleon,代碼行數:7,代碼來源:TaggableTrait.php

示例2: whereIn

 /**
  * Add a whereIn to the query
  *
  * @param  string $field
  * @param  array  $values
  * @param  bool   $order
  *
  * @return $this
  */
 public function whereIn($field, $values, $order = false)
 {
     $this->builder = $this->builder->whereIn($field, $values);
     if ($order) {
         $this->builder = $this->builder->orderByRaw(DB::raw("FIELD(" . $field . ", " . implode(',', $values) . ")"));
     }
     return $this;
 }
開發者ID:kodebyraaet,項目名稱:pattern,代碼行數:17,代碼來源:BaseRepository.php

示例3: scopeInLog

 public function scopeInLog(Builder $query, ...$logNames) : Builder
 {
     if (is_array($logNames[0])) {
         $logNames = $logNames[0];
     }
     return $query->whereIn('log_name', $logNames);
 }
開發者ID:spatie,項目名稱:laravel-activitylog,代碼行數:7,代碼來源:Activity.php

示例4: setIn

 /**
  * In
  *
  * @param $key
  * @param $value
  * @return $this
  */
 private function setIn($key, $value)
 {
     if (is_array($value)) {
         $this->query->whereIn($key, $value);
     }
     return $this;
 }
開發者ID:aginev,項目名稱:search-filters,代碼行數:14,代碼來源:Filter.php

示例5: onQuerying

 /**
  * Fired just before querying
  * for table entries.
  *
  * @param Builder $query
  */
 public function onQuerying(Builder $query)
 {
     $uploaded = $this->getUploaded();
     $query->whereIn('id', $uploaded ?: [0]);
     $query->orderBy('updated_at', 'ASC');
     $query->orderBy('created_at', 'ASC');
 }
開發者ID:tobz-nz,項目名稱:file-field_type,代碼行數:13,代碼來源:UploadTableBuilder.php

示例6: apply

 /**
  * Apply the scope to a given Eloquent query builder.
  *
  * @param  \Illuminate\Database\Eloquent\Builder  $builder
  * @return void
  */
 public function apply(Builder $builder, Model $model)
 {
     $subclassTypes = array_keys($model->getSingleTableTypeMap());
     if (!empty($subclassTypes)) {
         $builder->whereIn($model->getQualifiedSingleTableTypeColumn(), $subclassTypes);
     }
 }
開發者ID:phaza,項目名稱:single-table-inheritance,代碼行數:13,代碼來源:SingleTableInheritanceScope.php

示例7: constrainWhereIsAll

 /**
  * Constrain the given users query by all provided roles.
  *
  * @param  \Illuminate\Database\Eloquent\Builder  $query
  * @param  string  $role
  * @return \Illuminate\Database\Eloquent\Builder
  */
 public function constrainWhereIsAll($query, $role)
 {
     $roles = array_slice(func_get_args(), 1);
     return $query->whereHas('roles', function ($query) use($roles) {
         $query->whereIn('name', $roles);
     }, '=', count($roles));
 }
開發者ID:jonagoldman,項目名稱:bouncer,代碼行數:14,代碼來源:Roles.php

示例8: apply

 /**
  * Apply the scope to a given Eloquent query builder.
  *
  * @param  \Illuminate\Database\Eloquent\Builder  $builder
  * @param  \Illuminate\Database\Eloquent\Model  $model
  * @return void
  */
 public function apply(Builder $builder, Model $model)
 {
     if (isset($model->type_field) && isset($model->type)) {
         if (!is_array($model->type)) {
             $builder->where($model->type_field, $model->type);
         } else {
             $builder->whereIn($model->type_field, $model->type);
         }
     } elseif (isset($model->type)) {
         if (!is_array($model->type)) {
             $builder->where('type', $model->type);
         } else {
             $builder->whereIn('type', $model->type);
         }
     }
 }
開發者ID:ThunderID,項目名稱:HRIS-API,代碼行數:23,代碼來源:TypeScope.php

示例9: deleteLimit

 /**
  *
  * Delete numbers of notifications equals
  * to the number passing as 2 parameter of
  * the current user
  *
  * @param $user_id    int
  * @param $entity
  * @param $number     int
  * @param $order      string
  * @return int
  * @throws \Exception
  */
 public function deleteLimit($user_id, $entity, $number, $order)
 {
     $notifications_ids = $this->notification->wherePolymorphic($user_id, $entity)->orderBy('id', $order)->select('id')->limit($number)->lists('id');
     if (count($notifications_ids) == 0) {
         return false;
     }
     return $this->notification->whereIn('id', $notifications_ids)->delete();
 }
開發者ID:naimkhalifa,項目名稱:Notifynder,代碼行數:21,代碼來源:NotificationRepository.php

示例10: build

 public function build(Builder $query)
 {
     if (is_array($this->title)) {
         return $query->whereIn('title', $this->title);
     } else {
         return $query->where('title', '=', $this->title);
     }
 }
開發者ID:boomcms,項目名稱:boom-core,代碼行數:8,代碼來源:Title.php

示例11: findAllBy

 public function findAllBy($attribute, $value, $columns = ['*'])
 {
     $this->newQuery();
     // Perform where in
     if (is_array($value)) {
         return $this->query->whereIn($attribute, $value)->get($columns);
     }
     return $this->query->where($attribute, '=', $value)->get($columns);
 }
開發者ID:sthWrong,項目名稱:season5.co,代碼行數:9,代碼來源:AbstractRepository.php

示例12: applySimpleFilter

 /**
  * Apply simple filter
  *
  * @param Filter $filter
  */
 protected function applySimpleFilter(Filter $filter)
 {
     $value = (array) $filter->getValue();
     if (count($value) > 1) {
         $this->query->whereIn($filter->getField(), $value);
     } else {
         $this->query->where($filter->getField(), $filter->getOperator(), $value[0]);
     }
 }
開發者ID:mnabialek,項目名稱:laravel-eloquent-filter,代碼行數:14,代碼來源:QueryFilter.php

示例13: build

 public function build(Builder $query)
 {
     $query->join('assets_tags', 'assets_tags.asset_id', '=', 'assets.id');
     if (is_array($this->tags)) {
         $query->whereIn('assets_tags.tag', $this->tags)->groupBy('tag')->having(DB::raw('count(distinct tag)'), '=', count($this->tags));
     } else {
         $query->where('assets_tags.tag', '=', $this->tags);
     }
     return $query;
 }
開發者ID:robbytaylor,項目名稱:boom-core,代碼行數:10,代碼來源:Tag.php

示例14: apply

 /**
  * Apply the scope to a given Eloquent query builder.
  *
  * @param  \Illuminate\Database\Eloquent\Builder $builder
  * @param  \Illuminate\Database\Eloquent\Model $model
  *
  * @return void
  */
 public function apply(Builder $builder, Model $model)
 {
     $strict = isset($model::$strictModeration) ? $model::$strictModeration : config('moderation.strict');
     if ($strict) {
         $builder->where($model->getQualifiedStatusColumn(), '=', Status::APPROVED);
     } else {
         $builder->whereIn($model->getStatusColumn(), [Status::APPROVED, Status::PENDING]);
     }
     $this->extend($builder);
 }
開發者ID:gecche,項目名稱:laravel-moderation,代碼行數:18,代碼來源:ModerationScope.php

示例15: applyLoggedInScope

 /**
  * Apply logged in scope.
  *
  * @param \Illuminate\Database\Eloquent\Builder  $query
  * @param \Gitamin\Models\User  $user
  *
  * @return \Illuminate\Database\Eloquent\Builder
  */
 public function applyLoggedInScope(Builder $query, User $user)
 {
     $isPrivate = function ($query) use($user) {
         $query->where('visibility_level', '=', self::VISIBILITY_PRIVATE)->where("{$this->tableName}.creator_id", '=', $user->id);
     };
     $whereVisible = function ($query) use($isPrivate) {
         $query->whereIn('visibility_level', [self::VISIBILITY_PUBLIC, self::VISIBILITY_LOGGED_IN])->orWhere($isPrivate);
     };
     return $query->where($whereVisible);
 }
開發者ID:xiaobailc,項目名稱:Gitamin,代碼行數:18,代碼來源:VisibilityScope.php


注:本文中的Illuminate\Database\Eloquent\Builder::whereIn方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。