sql >> Databasteknik >  >> RDS >> Mysql

Fyller i valt inmatningsfält med värde från mysql

Få alternativ endast en gång (du behöver inte upprepa detta för varje person):

$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));

Gå sedan över personerna

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++;   
}

Att bygga in detta i en SELECT-fråga är onödigt komplicerat (även om det är möjligt, men ger dig oläsbar kod).

Åh, och ta en titt på htmlspecialchars (), om ett namn innehåller ett "-tecken blir din HTML smutsig




  1. Uppdatering av flera rader med olika värden

  2. Hur man använder Access som CRM

  3. MYSQL array aggregat funktion som PostgreSQL array_agg

  4. MySQL:Antal poster med på varandra följande månader