调用PHP函数只会从查询结果中提供一行

我正在使用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;

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...