sql >> Databáze >  >> RDS >> Mysql

Vyplnění výběrového vstupního pole hodnotou z mysql

Získejte možnosti pouze jednou (není nutné opakovat to pro každou osobu):

$sqlStatuses = 'SHOW COLUMNS FROM '.$table_name2.' WHERE field="'.$column_name2.'"';
$rowStatuses = $db_con->query($sql1)->fetch(PDO::FETCH_ASSOC);
$personStatuses = explode("','",substr($rowStatuses['Type'],6,-2));

Poté přejděte přes osoby

foreach ($results2 as $value2) { 
    // Your code
    echo "<tr>";
    echo "<td>Name #".$s."<input type=\"hidden\" name=\"person_id_".$s."\" value='". $person_id = $value2['person_id']."' readonly=\"readonly\"/><input id=\"person_fname_".$s."\" name=\"person_fname_".$s."\" placeholder=\"Person #".$s." First Name\" type=\"text\" value='" . $value2['first_name'] ."'/></td>";

    // Added
    echo '<td><select name="person_status_'.$s.'">';
    foreach($personStatuses as $option) {
        echo '<option value="'.htmlspecialchars($option).'" ';
        if ($value2['person_status'] == $option) {
            echo 'selected="selected"';
        }
        echo '>' . htmlspecialchars($option) . '</option>';
    }
    echo '</select></td>';

    // Your code again
    echo "</tr>";
    $s++;   
}

Sestavit to do jednoho dotazu SELECT je zbytečně složité (ačkoli je to možné, ale dává vám nečitelný kód).

Jo, a podívejte se na htmlspecialchars (), pokud název obsahuje "-znak, vaše HTML se posere




  1. SQL dotaz pro výpočet zůstatku účtu

  2. Operátor neexistuje:json =json

  3. Zrušte vnoření více polí paralelně

  4. Připravená mezipaměť příkazů s MySQL a JDBC