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

PHP:Dynamic Drop down s optgroup

Dvě smyčky for nejsou vnořeny do vašeho kódu:

foreach ($groups as $label => $opt) { ?>
    <optgroup label="<?php echo $label; ?>">
<?php   } <-- wrong here
    foreach ($groups[$label] as $id => $name) { ?>
        <option value="<?php echo $id; ?>"><?php echo $name; ?></option>
<?php } ?>

Výsledkem je, že nejprve jsou vytvořeny všechny skupiny opt a poté jsou přidáni zaměstnanci pro poslední skupinu (protože $label a $opt jsou dostupné i po dokončení smyčky).

Smyčky musíte vnořit (pomocí alternativní syntaxe pro ovládání struktur ):

<?php foreach($groups as $label => $opt): ?>
    <optgroup label="<?php echo $label; ?>">
    <?php foreach ($opt as $id => $name): ?>
        <option value="<?php echo $id; ?>"><?php echo $name; ?></option>
    <?php endforeach; ?>
    </optgroup>
<?php endforeach; ?>

Dále si myslím, že musíte použít emp_id , nikoli grp_id při vytváření pole:

while ($qa = $employees->GetRows()) {
    $groups[$qa['groupname']][$qa['emp_id']] = $qa['empname'];
}



  1. Jak vytvořit dočasnou tabulku v SQL?

  2. Jak dosáhnu toho, aby se kategorie první úrovně zobrazovala pouze jednou?

  3. Jak mohu zálohovat vzdálenou databázi SQL Server na místní jednotku?

  4. Jak zjistit kořenové heslo MySQL