0

我需要下面的帮助,我知道它过去曾提出过,但我目前正在努力找出错误不能使用 stdClass 类型的对象作为在线数组

$score[$counter] = ($bronze * $tempArray[6]) + ($silver * $tempArray[5]) + ($silver * $tempArray[4]);

代码:

<?php
       //turning the date other way around that is why explode the date string and stored in an Array
    $gold=$_GET['gold_input'];
    $silver=$_GET['silver_input'];
    $bronze=$_GET['bronze_input'];
    $gdp_value=$_GET['gdp_checked'];
    $link = new mysqli('localhost', 'root', '','coa123cdb');
    $myArray = array();
    //data format for information
//[{"name":"Ahmet Akdilek","country_name":"Turkey","gdp":"773091000000","population":"72752000"}
    $query = "SELECT  * FROM  coa123cdb.Country";

    $result = mysqli_query($link, $query)
    or die("Error: ".mysqli_error($link));
    $row_cnt = $result->num_rows;
    if ($result = $link->query($query)) {
    $tempArray = array();
    $scorex=array($row_cnt);
    $score=(object)$scorex;
    $counter=0  ;
    //while($row = $result->fetch_object()) {
    while($row=mysqli_fetch_object($result)){

      $tempArray = $row;
                if($gdp_value==0)
            {
            $score[$counter]=($bronze*$tempArray[6])+($silver*$tempArray[5])+($silver*$tempArray[4]);
            }
            else
            {$score[$counter]=($bronze*$tempArray[6]+$silver*$tempArray[5]+$silver*$tempArray[4])*$tempArray[1]/$tempArray[2]/10000;
            }
            array_push($tempArray, $score[$counter]);
            array_push($myArray, $tempArray);
                            $counter=$counter+1;
        }



        //var_dump($score);
    echo json_encode($myArray);
    }

    $result->close();
    $link->close();

  ?>
4

2 回答 2

2

mysqli_fetch_object返回一个对象。

所以行之后$row=mysqli_fetch_object($result)是一个对象。

如果你想要一个数组使用mysqli_fetch_array改用。

并在使用该数组之前检查其内容var_dump($row);(以防止进一步的问题)。

于 2013-05-15T01:34:03.613 回答
1

看看你是如何声明的$score

首先你做$scorex=array($row_cnt);然后$score=(object)$scorex;

$score投射到一个对象上也是如此。但是,在您的代码中,您仍然像数组一样处理它,即$score[$counter]. 您应该将其作为对象引用。

编辑

或者,将您的定义更新为$score以下内容:

 $score = array_fill (0, $row_cnt, 0);

这样,您的任务$score[$counter]仍然有效(我认为按照您的意图)。

于 2013-05-15T01:34:53.307 回答