【发布时间】:2018-09-21 14:32:56
【问题描述】:
我正在尝试使用数据库中的行填充表。但是,其中一列是需要填充多个值的下拉列表,因此需要使用 fetchAll。但是,我遇到了麻烦,因为我在另一个 foreach 构造中使用了一个 foreach 构造。
我猜这是不可能的,还是我做错了什么?如何找到一种解决方法,以便我可以填充整个表格,同时使用多个值填充下拉列表,但仍将其默认为数据库中的值?
<?php
$sql = "SELECT TOP 100 *
FROM Table_OS_List
ORDER BY [CURRENT_SKU] ASC";
$drops = "SELECT [Purchasing_Group]
FROM Table_OS_List
GROUP BY [Purchasing_Group]";
$drop = $dbh->query($drops);
?>
<?php
/* Foreach loop that brings in information to populate table */
foreach ($dbh->query($sql) as $rows) {
?>
<tr class="row">
<td class="old_sku" id="old_sku"><?php echo intval ($rows['OLD_SKU'])?></td>
<td class="current_sku" id="current_sku"><?php echo intval ($rows['CURRENT_SKU'])?></td>
<td class="id" id="id" style="display: none;"><?php echo intval ($rows['ID'])?></td>
<td class="dropdown-select" id="purchgroup">
<select id="selected_group" class="selected_group" disabled>
<?php foreach($drop->fetchAll() as $dropdown) { ?>
<option class="choice" value="Purchasing Group"><?php echo $dropdown['Purchasing_Group'];?></option>
<?php } ?>
</select>
</td>
<td><input type="button" class="edit" name="edit" value="Edit"></td>
<td><input type="button" class="delete" name="delete" id="<?php echo intval ($rows['ID'])?>" value="Delete"></td>
</tr>
<?php
}
?>
注意 此代码正确填充整个表格,但下拉列表仅包含每行中的值,如果我需要选择不同的值,则不会填充其他值选项:
<?php
/* Foreach loop that brings in information to populate table */
foreach ($dbh->query($sql) as $rows) {
?>
<tr class="row">
<td class="old_sku" id="old_sku"><?php echo intval ($rows['OLD_SKU'])?></td>
<td class="current_sku" id="current_sku"><?php echo intval ($rows['CURRENT_SKU'])?></td>
<td class="id" id="id" style="display: none;"><?php echo intval ($rows['ID'])?></td>
<td class="dropdown-select" id="purchgroup">
<select id="selected_group" class="selected_group" disabled>
<option class="choice" value="Purchasing Group"><?php echo $rows['Purchasing_Group'];?></option>
</select>
</td>
<td><input type="button" class="edit" name="edit" value="Edit"></td>
<td><input type="button" class="delete" name="delete" id="<?php echo intval ($rows['ID'])?>" value="Delete"></td>
</tr>
<?php
}
?>
编辑:
每个下拉菜单都会自动默认为 Bowling Green,即使该行不应该是 Bowling Green。大多数行都在东南或密歇根,但不管它应该是什么,出于某种原因它默认为鲍林格林
【问题讨论】:
-
我的第一个猜测,你只是做错了,让我们仔细看看
-
这个也需要改一下
<option class="choice" value="<?php echo $rows['Purchasing_Group'];?>"><?php echo $rows['Purchasing_Group'];?></option> -
为下拉列表创建一个新查询,而不是使用初始查询的第一行结果。
标签: php sql-server foreach