在我的代码中,我从sql db获取数据(三列),我想将行存储在关联的PHP数组中。该数组必须是多维的,因为我想使用数据库中的行id作为键,以便我可以获取这样的值:
$产品[ “f84jjg”] [ “名称”]
$产品[ “245”] [ “代码”]
我尝试过使用以下代码但不起作用:
while ($row = mysql_fetch_row($sqlresult))
{
$products = array($row[0] => array(
name => $row[1],
code => $row[2]
)
);
}
另外,如果从变量中获取密钥,我该如何引用密钥呢?我想做的是:
$productName = $products[$thisProd]["name"];
这会有用吗?
答案 0 :(得分:8)
这应该这样做,假设row[0]
的内容是唯一标识符(否则你可以覆盖一行):
while($row = mysql_fetch_row($sqlresult)) {
$products[$row[0]] = array(
'name' => $row[1],
'code' => $row[2]
);
}
您需要在数组键周围加上引号,然后创建一个数组数组数组。
另请注意,您可以使用mysql_fetch_assoc
代替mysql_fetch_row
,这会为您提供数组键作为列名称,这将使这更容易/更清洁:
while($row = mysql_fetch_assoc($sqlresult)) {
$products[$row['myidcolumn']] = $row;
}
执行此操作后,您描述的代码将起作用。