error在php类别和子类别中的数组到字符串转换

时间:2014-12-26 11:52:40

标签: php multidimensional-array

我已经遵守php代码,它给出了一个字符串转换错误的数组,创建了类别和子类别树节点但是在编译时发生了错误,让我解释一下我得到了错误。

<?php
  $conn = mysqli_connect('localhost','res_user','Res@123','res_db');
   if (mysqli_connect_errno())
  {
     echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }

  $sql = " SELECT * , category.id AS catId FROM category INNER JOIN sub_category ON category.id = sub_category.category_id
ORDER BY category.id, sub_category.category_id";
$res = mysqli_query($conn, $sql);
$categoryArray = array();
$oldCatId = 0;
while ($row = mysqli_fetch_assoc($res)) {
    if ($row['catId'] != $oldCatId) {
        $categoryArray[$row['catId']] = array(
            'success' => true,
            'category_' . $row['catId'] = array(
        'cat_id' => $row["catId"],
        'cat_name' => $row['cat_name'],
        'cat_img' => $row['cat_img'],
        'sub_category' => array(
            'sub_id' => $row['category_id'],
            'sub_name' => $row['sub_name']
        )
            )
        );
        $oldCatId = $row['catId'];
    } else {
        $categoryArray[$row['catId']]['category_' . $row['catId']]['sub_category'][] = array(
            'sub_id' => $row['category_id'],
            'sub_name' => $row['sub_name']
        );
    }
}
   echo $categoryArray;


?>

2 个答案:

答案 0 :(得分:0)

您不能echo array用于输出一个或多个字符串,您需要print_r或{{3}它,如:

print_r($categoryArray);

答案 1 :(得分:0)

错误消息的原因是代码正在尝试显示带有 echo 的数组。此构造仅用于显示字符串,而不是数组。只要您为PHP提供标量值(boolean,int,string,float),如果标量的数据类型不是字符串,PHP将暂时将其提升为字符串。

通常,您需要遍历数组以显示其元素的任何标量值,编写某种循环结构。 PHP为使用多维数组提供了极大的便利,函数 array_walk_recursive()与回调一起使用。下面是问题中提到的数组的变体,以便您了解如何将array_walk_recursive()与回调一起使用。现在PHP支持匿名函数,我们可以使用一个用于回调,如下所示:

    <?php
    $categoryArray[0]['category_0']['sub_category'][] = array(
            'sub_id' => 500,
            'sub_name' => '1a'
        );
    array_walk_recursive($categoryArray,
                function($value,$key){
                  echo "$key: $value\n";

                });
    // output:
    sub_id: 500
    sub_name: 1a

array_walk_recursive()的优点在于它将遍历多维数组,并且回调显示任何可用数据。注意,回调需要按特定顺序排列参数,第一个参数必须对应一个元素的值,而第二个参数必须代表它的键。

另请参阅实时演示here