我有这段代码,你想问while($row=mysqli_fetch_assoc($result_table_main))是否在结果集中没有行时结束?
不明白为什么它会因为没有计数器而结束。
这是我帖子里唯一的问题。也许你能给我一个恰当的解释。
我花了很长时间做这件事,因为我以前对这件事不太了解。现在我要把我的工作记录下来。
谢谢你的回答!

<?php
$sql_table_main = "SELECT id,name_Gleitzeitrahmen, name_Abweichungen, name_Mehrarbeitervolumen, name_Mehrarbeit1, name_Ausgleich, name_Mehrarbeit2, name_Personalmassnahmen, name_Ueberstunden, name_Ueberstunden_abzusehen, name_Klaerungsbedarfe1, name_Klaerungsbedarfe2 FROM landrat_dashboard";
$result_table_main = mysqli_query($con, $sql_table_main);
?>

<div class="card-content table-responsive table-maxheight" style="overflow:scroll;">
<table class="table table-hover table-mc-green table-bordered table-striped table-condensed">
    <thead class="text-primary">
        <th class="thbackground_green">ID</th>
        <th class="thbackground_green">Gleitzeitrahmen</th>
        <th class="thwidth thbackground_green">Abweichungen</th>
        <th class="thwidth thbackground_green">Mehrarbeitervolumen</th>
        <th class="thwidth thbackground_green">Mehrarbeit</th>
        <th class="thwidth thbackground_green">Ausgleich</th>
        <th class="thwidth thbackground_green">Mehrarbeit</th>
        <th class="thwidth thbackground_green">Personalma&szlig;nahmen</th>
        <th class="thwidth thbackground_green">&Uuml;berstunden im Rahmen?</th>
        <th class="thwidth thbackground_green">Sind &Uuml;berstunden abzusehen?</th>
        <th class="thbackground_green">Kl&auml;rungsbedarfe</th>
        <th class="thwidth thbackground_green">Kl&auml;rungsbedarfe Beschreibung</th>
    </thead>
    <tbody>
        <?php
        if(mysqli_num_rows($result_table_main) > 0){
            while ($row = mysqli_fetch_assoc($result_table_main)) {
            echo '<tr>';
            echo '<td>'. $row['id'] .'</td>';
            echo '<td>'. $row['name_Gleitzeitrahmen'] .'</td>';
            echo '<td>'. $row['name_Abweichungen'] .'</td>';
            echo '<td>'. $row['name_Mehrarbeitervolumen'] .'</td>';
            echo '<td>'. $row['name_Mehrarbeit1'] .'</td>';
            echo '<td>'. $row['name_Ausgleich'] .'</td>';
            echo '<td>'. $row['name_Mehrarbeit2'] .'</td>';
            echo '<td>'. $row['name_Personalmassnahmen'] .'</td>';
            echo '<td>'. $row['name_Ueberstunden'] .'</td>';
            echo '<td>'. $row['name_Ueberstunden_abzusehen'] .'</td>';
            echo '<td>'. $row['name_Klaerungsbedarfe1'] .'</td>';
            echo '<td>'. $row['name_Klaerungsbedarfe2'] .'</td>';
            echo '</tr>';
            }
        }
        ?>
    </tbody>
</table>

最佳答案

引用mysqli_fetch_assoc函数的documentation
返回值:返回表示
已提取行。如果结果集中没有更多行,则为空
因此,如果没有更多的行来获取,函数将返回null。如果查看while循环条件,它将如下所示(仅当没有更多行时):

$row = null

它将计算为false,因此不满足条件,因此循环将结束。

关于php - 使用SQL和PHP创建数据表-需要简单说明,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48280869/

10-16 13:32