(1)问题提出

我在从数据库查出来的数据中发现其是一个对象,而不是一个数组,这样我们就无法遍历它从而达到一些目的

(2)寻求解决

这里是我的controller层的一小段代码

$producestyle = exhibitionsql::allproducestyle();//产品类型
    //var_dump($producestyle);
    $j=0;
    $producearray = array();
    foreach($producestyle as $value){
      //var_dump($value);
 
      $j++;
      $producearray[$j]=$value->producecolortype;
 
    }

这里是我model层的一小段代码

 public static function allproducestyle(){//产品类型
    $data =db::select("select distinct producecolortype from produce ");
 
    return $data;
  }

可以看出我在controller中把得到的数据首先遍历一遍,同时定义一个数组,接住这个对象中的一个字段中的值,这样我就可以把这个数据都存入一个数组进行使用了

如下:

for($i=1; $i <= $j; $i++){
      // echo "sad";
      //var_dump($producearray[$i]['producecolortype']);
      if($select == $producearray[$i]){
        // echo "sda";
        $producedata =exhibitionsql::producecolor($select);//产品数据
        $carouseldata =exhibitionsql::secondcarouseldata();//轮播图
        return view('b_page/produce',[
          'carouseldata'=>    $carouseldata,
          'producestyle'=>    $producestyle,
          'producedata'=>     $producedata
        ]);
      }

(3)网友解决

 public function object_array($array) {
    if(is_object($array)) {
      $array = (array)$array;
    } if(is_array($array)) {
      foreach($array as $key=>$value) {
        $array[$key] = object_array($value);
      }
    }
    return $array;
  }

网友提供了一个这样的方法但是我试了没有效果,所以在此我也想请教一下大家,给点指导

以上这篇laravel框架之数据库查出来的对象实现转化为数组就是www.887551.com分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持www.887551.com。