如何在 php mysqli_fetch_array获取第一个值

How to get the first value in mysqli_fetch_array php

提问人:BrightCode 提问时间:9/16/2020 最后编辑:ADysonBrightCode 更新时间:9/16/2020 访问量:620

问:

我有这个代码,能够使用 php mysqli_fetch_array 和 while 循环完美地从数据库中获取所有值


    $pid = 1;                                             
    $sqlSI = "SELECT * FROM productcolor where proId='$pid'";
    $SIresult = mysqli_query($conn, $sqlSI);
        
    if (mysqli_num_rows($SIresult) == 1) {
        echo ' <h4>Color</h4>
        <div class="colors">';

        while ($row = mysqli_fetch_array($SIresult)) {
            ?>

        <a href="javascript:void(0)" class="s-colors" data-color="<?= $row['colors']; ?>" style="background-color: <?= $row['colors']; ?>;"></a>

        <script>
            $(document).ready(function () {
                $(".pdt-color-cart").val("<?= $row['colors']; ?>");
            })
        </script>

<?php
        }
        echo ' </div>';
    }
    else if (mysqli_num_rows($SIresult) > 1) {
        
        $rowed = mysqli_fetch_array($SIresult);
        echo $rowed['colors'];

        echo ' <h4>Color</h4>
        <div class="colors">';
        
        while ($row = mysqli_fetch_array($SIresult)) {
            
            ?>

        <a href="javascript:void(0)" class="s-colors" data-color="<?= $row['colors']; ?>" style="background-color: <?= $row['colors']; ?>;"></a>

<?php
        }
        echo ' </div>';
    } else {
        echo "";
    }
    

?>

在上面的代码中,我做了一个,如果值是,则执行此操作,否则如果值是,则仍然执行此操作。1more than 1

但我想要的是,当它执行> 1 循环时,我仍然希望能够从中获取一个值 - 尤其是将要出现的第一个值。

你是怎么做到的?

php while-loop mysqli

评论

0赞 ADyson 9/16/2020
对不起,我不确定你所说的“希望仍然能够从中获取一个值”的确切含义。在您当前的代码中,如果我理解正确的话,它似乎可以满足该要求 - 这一行总是获得结果的第一行。那么在这种情况下,你遇到的具体问题是什么?因为代码似乎已经按照您的要求执行了操作。$rowed = mysqli_fetch_array($SIresult);
0赞 BrightCode 9/16/2020
@ADyson当我这样做时,让我说有三个值被获取并且我使用了$rowed然后它只会在$row中返回两个值,在$rowed中返回一个值,我不希望这样
0赞 Dharman 9/16/2020
@ADyson会将内部指针移动到第二行。当循环开始时,它将从第二行开始迭代。mysqli_fetch_array()while
0赞 ADyson 9/16/2020
@Dharman是的,我知道。我试图澄清这是否是 OP 的意图(或者确实是他们的意图。我发现问题的措辞不清楚)。

答:

0赞 Tor Sverre Lund 9/16/2020 #1

如果我理解正确的话,你想“记住”弹出的第一个颜色是什么吗?在这种情况下,您可以在第一个 if 之前设置一个变量,例如 $saveColor = TRUE。然后在 elseif 中,选中 $saveColor,如果为 TRUE,则将其更改为 FALSE,并设置第二个变量来保存颜色,例如

$firstColorFound = $rowed['colors'];

或类似的东西。

下次循环时,$saveColor将不再是 TRUE,因此$firstColorFound不会被覆盖。希望对您有所帮助!

2赞 Dharman 9/16/2020 #2

如果你稍微整理一下你的代码,这个任务可以更容易地完成。无需将数据库逻辑与表示逻辑混合使用,只需在开始输出 HTML/JavaScript 之前获取数据即可。您可以将元素的数量存储在变量中。

// Fetch the data and store it in an array
$stmt = $conn->prepare('SELECT * FROM productcolor where proId=?');
$stmt->bind_param('s', $pid);
$stmt->execute();
$data = $stmt->get_result()->fetch_all(MYSQLI_ASSOC);
$no_of_elements = count($data);

// If more than one element present in the results
if ($no_of_elements > 1) {
    echo $data[0]['colors'];
}

echo ' <h4>Color</h4>
<div class="colors">';
foreach ($data as $row) {
    echo <<<S_COLORS_BLOCK
    <a href="javascript:void(0)" class="s-colors" data-color="{$row['colors']}" style="background-color: {$row['colors']};"></a>
    S_COLORS_BLOCK;
}

// If only one element is present then display JavaScript
if ($no_of_elements === 1) {
    echo '
    <script>
        $(document).ready(function () {
            $(".pdt-color-cart").val('.json_encode($row['colors']).');
        })
    </script>';
}