如何在循环中获得最大值

时间:2013-06-27 16:12:04

标签: php max

好吧所以我正在使用这个循环并从DB获取信息:

for($i0 = 0; $i0 < $total0; $i0 ++) {
    $id = $oconecta->retrieve_value($i0, "id_tam_product");
    $price = $oconecta->retrieve_value($i0, "price_tam_product");

    echo $id; // RESULTS: 312, 313, 314
    echo $price; // RESULTS: 180.00, 250.00, 300.00
}

我想知道如何获得该循环的MAX值:

echo $id; //RESULTS: 314 
echo $price; //RESULTS: 300.00 

2 个答案:

答案 0 :(得分:2)

$maxID = 0;
$maxPrice = 0;
for($i0=0;$i0<$total0;$i0++)
{
  $id=$oconecta->retrieve_value($i0,"id_tam_product");
  $price=$oconecta->retrieve_value($i0,"price_tam_product");

  $maxID = max($id, $maxID);
  $maxPrice = max($price, $maxPrice);
}

echo "MAX ID: $maxID - Max PRICE: $maxPrice";

使用max()功能确定一组的最高编号。

答案 1 :(得分:1)

如果你可以修改你的SQL查询,你可以使用SQL的MAX(),或者在每个循环中保持变量的最大值,并且每次都重新分配它:

$firstLoop = true;
$maxId = 0;
$maxPrice = 0;

for ($i0 = 0; $i0 < $total0; $i0++)
{
    $id = $oconecta->retrieve_value($i0, "id_tam_product");
    $price = $oconecta->retrieve_value($i0, "price_tam_product");

    if ($firstLoop) {
        $firstLoop = false;
        $maxId = $id;
        $maxPrice = $price;
    }
    else {
        $maxId = max($maxId, $id);
        $maxPrice = max($maxPrice, $price);
    }
}

(如果您有负值,则布尔值在此处,如果$ maxPrice和$ maxId初始化为0则不起作用)