Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Fügen Sie Daten mithilfe eines mehrdimensionalen Arrays aus mehreren Feldern ein

AKTUALISIEREN

(Wow, das ist schwierig):Sie definieren alle Ihre Eingabefelder in Ihrem HTML-Formular als Arrays. Sie können diese [] entweder entfernen was sie zu Arrays macht, oder Sie können name=insp[] verwenden auf Ihrem insp -Kontrollkästchen. Geben Sie dann Ihre Übermittlung mit var_dump($_POST) aus und Sie sehen, wie Sie das Array parsen können.

Oder erstellen Sie ein verschachteltes Array. So etwas wird helfen:

while($row = mysqli_fetch_assoc($result)) {

    extract($row);

    echo "<tr>\n
    <td><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][id]' /></td>\n
        <td><center>{$scaffreq_id}</center></td>\n
        <td><center>{$level} m</center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][a]' /></center></td>\n            
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][b]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][c]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][d]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][e]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][f]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][g]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][h]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][i]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][j]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][k]' /></center></td>\n
        <td><center><input type='checkbox' checked='checked' name='items[{$scaffreq_id}][insp][l]' /></center></td>\n
        <td><center><p><input type='text' name='items[{$scaffreq_id}][reason]' maxlength='255' size='45' value='Reason{$insp_reason}'></p></center></td>\n
        </tr>\n";
}

Es ist nicht einfach zu helfen, ohne den HTML-Formularcode zu sehen. Aber wie es mir scheint, $ID ist höchstwahrscheinlich kein Array. Verwenden Sie also foreach($ID as ...) ist nicht gut. Bauen Sie Ihren String stattdessen wie folgt auf:

$query = "INSERT INTO `inspect` (`ID`,`a`,`b`,`c`,`d`,`e`,`f`,`g`) VALUES ";
$query .= "({$ID}, {$a}, {$b}, {$c}, {$d}, {$e}, {$f}, {$g})";

Warnung:
Beachten Sie, dass Ihr Code unsicher und anfällig für SQL-Injektionen ist (siehe dieses SO Q&A ). Verwenden Sie PDO-Prepared-Statements statt mysql() Funktionen!