首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >函数返回implode():传递的无效参数

函数返回implode():传递的无效参数
EN

Stack Overflow用户
提问于 2020-12-11 11:51:55
回答 2查看 106关注 0票数 0

我是内爆一些id,它工作时,数组有至少一个值。如果数组为null,则implode函数返回错误作为implode():传递的无效参数

代码语言:javascript
复制
$arr=implode(',', $request->id);


 $product= DB::table('sub_categories')
        ->join('categories','sub_categories.category_id','=','categories.category_id')
        ->join('products','sub_categories.subcategory_id','=','products.subcategory_id')
         ->join('colors','colors.color_id','=','products.product_color')
         ->select('products.*','categories.category_name','sub_categories.subcategory_name','colors.*')
         ->whereRaw('color_id IN ('.$arr.')')
         ->where(strtolower('sub_categories.subcategory_slug'),$request->subcategory_id) 
        ->orderBy('products.product_name','ASC')
        ->get();
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-12-11 11:56:22

尝试使用默认值来说明$request->id为null时的场景。

代码语言:javascript
复制
$arr = implode(',', $request->input('id', []));

可以在查询中有条件地执行whereIn。

代码语言:javascript
复制
```php

$arr=implode(',',$request->输入(‘id’,[]));

$query= DB::表(‘sub_categories’)

代码语言:javascript
复制
    ->join('categories','sub_categories.category_id','=','categories.category_id')
代码语言:javascript
复制
    ->join('products','sub_categories.subcategory_id','=','products.subcategory_id')
代码语言:javascript
复制
     ->join('colors','colors.color_id','=','products.product_color')
代码语言:javascript
复制
     ->select('products.*','categories.category_name','sub_categories.subcategory_name','colors.*')
代码语言:javascript
复制
     ->where(strtolower('sub_categories.subcategory_slug'),$request->subcategory_id);

如果(!空($arr)){

代码语言:javascript
复制
$query->whereRaw('color_id IN ('.$arr.')');

}

$product = $query->orderBy('products.product_name','ASC')->get();

代码语言:javascript
复制
票数 1
EN

Stack Overflow用户

发布于 2020-12-11 12:05:47

如果给定的数据不是数组,则implode()函数将引发警告错误。要消除错误,可以使用方法检查数组:

代码语言:javascript
复制
if(is_array($request->id)){
   $arr = implode(',', $request->id);
} else {
   $arr = NULL;
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65250869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档