问题是我只从表中得到最后一个值commg。我认为这是因为我在构建数组时将其值引用到同一个对象,并且它不断变化。我知道while循环不会为每次迭代创建一个新的范围,这就是问题所在。
为每次迭代获得新范围的最佳方法是什么
代码:
$namesArray= array();
while ($row=mysql_fetch_array($result))
{
$nameAndCode->code = $row['country_code2'];
$nameAndCode->name = $row['country_name'];
array_push($namesArray,$nameAndCode);
}
return $namesArray;
您需要在每次迭代中创建一个新对象:
while ($row=mysql_fetch_array($result))
{
$nameAndCode = new stdClass;
$nameAndCode->code = $row['country_code2'];
$nameAndCode->name = $row['country_name'];
$namesArray[] = $nameAndCode;
}
否则,您将一次又一次地引用同一个对象,并覆盖其值。
如果你不需要对象,你也可以用数组来做到这一点:
while ($row=mysql_fetch_array($result))
{
$nameAndCode = array();
$nameAndCode['code'] = $row['country_code2'];
$nameAndCode['name'] = $row['country_name'];
$namesArray[] = $nameAndCode;
}
或者更简洁地说:
while ($row=mysql_fetch_array($result))
{
$namesArray[] = array(
'code' => $row['country_code2'],
'name' => $row['country_name']
);
}
我会选择这样的东西:
$namesArray=array();
while($row=mysql_fetch_array($result)){
$nameAndCode=array("code"=>$row["country_code2"],
"name" => $row["country_name"]);
array_push(&$namesArray,$nameAndCode);
};
我也会尝试通过引用传递$namesArray
,就像Viktor提到的那样。我的代码制作了一个全新的数组来推送每次迭代,这确保了你不会覆盖内容。此外,如果你想通过索引访问数组来添加内容,你应该使用以下方法:
// This is the right way
$someArray["foo"]="bar";
$someArray["baz"]="quux";
// This is wrong, it's only for OOP
$someArray->foo="bar";
$someArray->baz="quux";
尝试
array_push(&$namesArray,$nameAndCode);
我认为array_push
需要一个引用或指针。
你不使用$namesArray[]
有什么原因吗?代替上述内容:
$namesArray[] = $nameAndCode;