gpt4 book ai didi

php - 如何使用 pdo 发送数组以在 smarty 3.1.21 的 html_options 中使用它

转载 作者:行者123 更新时间:2023-11-30 22:04:21 24 4
gpt4 key购买 nike

我正在更新使用 MySQL 到 PDO 的部分以显示 {html_options} 聪明。此代码实际上适用于 MySQL,但我不知道如何使用 PDO 获得相同的结果。

这是实际运行良好的代码:

// Send states
$q="SELECT id, state FROM states";
$data=$db->execute($q);
$idStates=array();
$states =array();
for ($i=0; $i<sizeof($data);$i++) {
array_push($idStates,$data[$i]->id);
array_push($states,$data[$i]->state);
}
$smarty->assign('idStates',$idStates);
$smarty->assign('states',$states);

然后在 .tpl 文件中一切正常

<select name="des_idState" class="form-control">
<option>Select state</option>
{html_options output="$states" values="$idStates" selected=$data.idState}
</select>

我尝试用 PDO 做的事情使用 {foreach} 效果很好,但我需要使用 selected ,我认为使用 Smarty 的 {html_options} 最简单,但我不知道如何从 PDO 发送数组。

$sql1="SELECT id, state FROM states";

$stmt = $dba->prepare($sql1);
$stmt->execute();

while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {

$idStates = $row['id'];
$states = $row['state'];

$smarty->assign('idStates', $idStates);
$smarty->assign('states',$states);
}

我一直在尝试使用此代码向我展示使用 echo $idStates . ' ' . $states . '<br>'; 的数组,但是它在 {html_options} 中不起作用,没有显示,没有错误,只有一个空格。

有人能帮帮我吗?

最佳答案

我知道这个问题发布已经有一段时间了,但是您找到问题的解决方案了吗?我相信您可以通过最少的代码修改将 idstate 变量修复为数组。

在下面的示例中,我在开头添加了 id 和 state 数组声明,以确保数组为空(作为下一步的预防措施)。然后我将 $idStates= 更改为 $idStates[]= 并将 $states= 更改为 $states[]= ,这会将当前值添加到每个循环中的那些数组。最后,我将 smarty 变量赋值移动到 while 循环之后,以便数组将被完全填充。这是修改后的代码:

$sql1="SELECT id, state FROM states";

$stmt = $dba->prepare($sql1);
$stmt->execute();

$idStates = array();
$states = array();

while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {

$idStates[] = $row['id'];
$states[] = $row['state'];
}

$smarty->assign('idStates', $idStates);
$smarty->assign('states',$states);

我还在下面提供了一个替代解决方案,它应该会返回相同的数据。在此示例中,我使用 $stmt->fetchAll 而不是 $stmt->fetch 一次获取所有行,然后将它们存储在关联数组中。然后我使用 array_column在声明 smarty 赋值时,它从 $rows 关联数组中分离出 id 和 state 列。这样可以在不牺牲可读性的情况下减少代码量:

$sql1 = "SELECT id, state FROM states";

$stmt = $dba->prepare($sql1);
$stmt->execute();

$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);

$smarty->assign('idStates', array_column($rows, 'id'));
$smarty->assign('states', array_column($rows, 'states'));

关于php - 如何使用 pdo 发送数组以在 smarty 3.1.21 的 html_options 中使用它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42235986/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com