2つのforループはコードにネストされていません:
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 } ?>
その結果、最初にすべてのoptグループが作成され、次に最後のグループの従業員が追加されます($label
のため) および$opt
ループが終了した後も利用できます。
ループをネストする必要があります(制御に代替構文を使用する構造 ):
<?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; ?>
さらに、emp_id
を使用する必要があると思います 、grp_id
ではありません アレイを作成するとき:
while ($qa = $employees->GetRows()) {
$groups[$qa['groupname']][$qa['emp_id']] = $qa['empname'];
}