我正在使用PHP文件来存储我项目中需要的所有功能.
其中之一是以下内容:
function recuperar_opcion_plato_linea ($plato_id) {
/*** MysqL hostname ***/
$hostname = 'localhost';
/*** MysqL username ***/
$username = 'xxxx';
/*** MysqL password ***/
$password = 'xxxxxxx';
try {
$dbh = new PDO("MysqL:host=$hostname;dbname=xxx", $username, $password);
/*** echo a message saying we have connected ***/
/*** The sql SELECT statement ***/
$sql = "SELECT * FROM tb_opciones_linea_comanda WHERE id_linea = '".$plato_id."'";
foreach ($dbh->query($sql) as $row)
{
return $row['id_opcion'];
}
/*** close the database connection ***/
$dbh = null;
}
catch(PDOException $e)
{
echo $e->getMessage();
}
}
从另一个文件我调用此函数,但它只给出查询结果的第一行,并且至少有3行.
这是调用函数recuperar_opcion_plato_linea的PHP代码:
<?PHP do { ?>
<p><?PHP echo $row_Recordset1['cantidad_pedido']." "; ?>
<?PHP echo recuperar_nombre_plato($row_Recordset1['plato_pedido'])." "."$".$row_Recordset1['precio_linea']." ".$moneda?></p>
<p><?PHP
$opcion_selecionada = recuperar_opcion_plato_linea ($row_Recordset1['id_random']);
echo recuperar_nombre_opcion($opcion_selecionada) ?></p>
<?PHP } while ($row_Recordset1 = MysqL_fetch_assoc($Recordset1)); ?>
解决方法:
当你说return $row [‘id_opcion’];它会立即结束你的foreach循环并告诉函数返回.相反,你应该简单地返回$dbh-> query($sql)
此外,如果您在查询中只需要一列id_opcion,则应使用SELECT id_opcion而不是SELECT *
为了举例,假设您仍然想要使用循环,您可以这样做:
// create a blank results array
$results = array();
foreach ($dbh->query($sql) as $row) {
// add the row to the array
$results[] = $row['id_opcion'];
}
// return the finished results array
return $results;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。