明らかに、わかりました。最初にそれを分解して、学ぶべきことがあるようにします。
while($row2 = mysql_fetch_array($result))
{
...
}
この部分は大丈夫です。ループの内部を見てみましょう。
$myarray = array("id"=>$theid, "name"=>name($id), "text"=>$row2[text]);
複数のポイントがあります。おそらく最も重要なのは、ループ内にあるため、$myarray
反復ごとに上書きすることです。代わりに、配列に追加したいとします。これをやろう:
$myarray = array(); # initialize the array first!
while($row2 = mysql_fetch_array($result))
{
$myarray[] = $row2; # add the row
}
その後、それを出力して、基本的に機能することを証明できます。
var_dump($myarray);
これは、すべての行を含む配列を示しています。次に、データベースクエリを変更するだけで、関心のあるフィールドのみが返されるようになります。
データベースでそれができない場合は、配列を操作することもできます。
$myarray = array(); # initialize the array first!
while($row2 = mysql_fetch_array($result))
{
$myarray[] = array(
"id" => $theid,
"name" => name($id),
"text" => $row2['text']
);
}
var_dump($myarray);
これで、結果は希望どおりになります。出力するには$myarray
:
foreach ($myarray as $number => $row)
{
echo '<div>Number ', $number, ':<dl>';
foreach ($row as $k => $v)
{
printf("<dt>%s</dt><dd>%s</dd>\n", $k, htmlspecialchars($v));
}
echo '</dl></div>'
}