問題の現在の要約:特定のIDの目標番号と目標名をリストするテーブル「main」から情報を取得しています(最大10行まで可能です)。これらは、Webページの表に表示されます。テーブルの行数を反映するチェックボックスを最初の列に追加しました。このためのコードは以下のとおりです。この部分は正しく機能しています。出力は、チェックボックス、目標番号、目標名の3つの列と、その特定のIDのテーブル内の情報量に応じて最大10行です。
Goals.php
<tr>
<td valign=top colspan=3>
Current Goals<br>
<?php
//this data is being pulled from 'main'
$result = mysql_query("SELECT * FROM main WHERE idnumber = $idnumber ORDER BY goalnumber");
if ($result) {
$total_rows = mysql_numrows($result);
} else { $total_rows = 0; }
print "<table border=1 width=400>\n";
print "<tr> \n";
print "<th> Checkbox </th> \n";
print "<th> Goal Number </th> \n";
print "<th> Goal Name </th> \n";
print "</tr> \n";
//}
$i = 0;
while ( $i < $total_rows )
{
$goalno = intval(mysql_result($result, $i, "goalnumber"));
$goalname = mysql_result($result, $i, "goalname");
$goal_id = intval(mysql_result($result, $i, "goal_id"));
print "<tr> \n";
print "<td> <center><input type=\"checkbox\" name=\"goal_id_$i\" value=\"$goalnumber - $goalname\"></td> \n";
print "<td> $goalnumber </td> \n";
print "<td> $goalname </td> \n";
print "</tr> \n";
$i = $i + 1;
}
?>
</table>
</td>
ユーザーがこれらのチェックボックスの1〜10をチェックしてフォームを送信したら、その選択の値をdbに渡す必要があります(各選択はdbテーブル「updated_goals」の新しいフィールドに書き込まれる必要があります。送信時に以下のファイルが呼び出されます。同じdb'updated_goals'内の別のテーブルにチェックボックスの値を書き込んでいることに注意してください。コードのどこが間違っているのかわかりませんが、目標はチェックボックスの値を書き込むことです。 「$goalnumber-$goalname」をgoal_idフィールドに入力します。
Goals_submit.php
// process data in table: updated_goals
$query = "SELECT idnumber from updated_goals where idnumber = {$_POST['idnumber']}";
$result = mysql_query($query);
$total_rows = mysql_numrows($result);
//writing data to 'updated_goals'
if (isset($_POST ['goal_id_$i'])) { $goal_id = ReplaceQuotes($_POST['goal_id_$i']); } else { $goal_id = ""; }
$query = "INSERT INTO updated_goals ( ";
$query .= "goal_id ";
$query .= ") VALUES ( ";
$query .= "'$goal_id' ";
$query .= ")";