Laravel过滤多个WhereIn数组

时间:2018-02-06 00:22:54

标签: mysql sql arrays laravel where-in

我正在尝试为电子商务商店创建过滤器。用户可以按标签过滤产品,每个flavor标签都附加到一个数组:$ tags_array

即。 告诉我所有包含' kiwi' AND '薄荷醇'标签

DD($ tags_array);

array:2 [
  0 => "kiwi"
  1 => "menthol"
]

查询的过滤部分

$query = $tags_array ? $query
 ->join('product_product_tag', 'products.id', '=', 'product_product_tag.product_id')
 ->join('product_tags', 'product_tags.id', '=', 'product_product_tag.tag_id')
 ->whereIn('product_tags.value', $tags_array) : $query;

- 一个产品HasMany标签

- 一个标签BelongsToMany产品

product_tags

id | value 
------------------
1  | kiwi 
2  | apple
3  | menthol 
4  | strawberry 

- 透视表:product_product_tag

product_product_tag

id | product_id | tag_id 
----------------------------
1  |    1       |    1
2  |    1       |    3
----------------------------
3  |    2       |    1
4  |    2       |    2
5  |    2       |    3
----------------------------
6  |    3       |    1
7  |    3       |    4
----------------------------
8  |    4       |    3

问题

当前查询显示所有具有奇异果 OR 薄荷醇标签的产品。

实际结果:产品:1,2,3,4

预期结果:产品:1,2

只应用一个标记时,此查询才能正常工作。如何使此过滤器包含多个标记(产品具有kiwi标记 AND 薄荷醇标记)。用户可以按0,1,2,3,...标签过滤

是否有处理动态数量标签的最佳做法?

编辑:我正在使用Laravel数据库查询生成器

第二次修改:尝试btl的回答

  $query = $tags_array ? $query
      ->join('product_product_tag', 'products.id', '=', 'product_product_tag.product_id')
      ->join('product_tags', 'product_tags.id', '=', 'product_product_tag.tag_id') : $query;
  if($tags_array) {
      foreach ($tags_array as $tag) {
          $query->where('product_tags.value', '=', $tag);
      }
  }

第3次修改:转回以下内容:

$query = $tags_array ? $query
 ->join('product_product_tag', 'products.id', '=', 'product_product_tag.product_id')
 ->join('product_tags', 'product_tags.id', '=', 'product_product_tag.tag_id')
 ->where('product_tags.value', $tags_array) : $query;

这仍然不正确。当前过滤器返回找到的第一个标记的结果。将继续致力于更加动态的解决方案

1 个答案:

答案 0 :(得分:0)

<select [(ngModel)]="selectedValue" (ngModelChange)="eventChange()" 将匹配数组中至少包含一个标记的所有内容,因此它的行为为whereIn('product_tags.value', $tags_array)。如果您只需要匹配具有所有选定标签的产品,则需要设置多个where子句,以实现以下效果:

OR

修改

$query = Product::with('tags');
foreach ($tags_array as $tag) {
     $query->whereHas('tags', function($q) use ($tag) {
         $q->where('id', $tag);
     });
 }
 $query->get();