我有两页index4.phpgenerate.php。用户必须选择一个日期范围,然后单击index4.php中的按钮以在generate.php中生成用户报告。
索引4.php
php - PHP根据日期选择器输入显示mysql结果-LMLPHP
数据库表
php - PHP根据日期选择器输入显示mysql结果-LMLPHP
我希望在generate.php中显示这些结果,如下所示:
php - PHP根据日期选择器输入显示mysql结果-LMLPHP
这是我两页的代码:
index4.php

<form action="generate.php" method="post" target="_blank">
    <table width="528" align="center" boder="0">
    <tr>
        <td width="109">Select date :</td>
        <td width="202">FROM&nbsp;&nbsp;<input type="date" name="start_date" required/></td>
        <td width="24">TO</td>
        <td width="173">&nbsp;<input type="date" name="end_date" required/></td>
    </tr>
    <tr>
        <td colspan="4"><i><font color="#FF0000">*</font>&nbsp;Required field.</i></td>
    </tr>
    <tr>
    <td colspan="4" align="center"><input type="submit" value="Generate User Report"/></td>
    </tr>
    </table>
</form>

generate.php
<table align="center" border="1">
<tr>
    <td align="center">Date</td>
    <td align="center">Page Name</td>
    <td align="center">Page Viewed</td>
</tr>
<?php
    if(mysql_num_rows($select_page_view) > 0)
    {
        $row = mysql_fetch_array($select_page_view); ?>
        <tr>
            <?php $num_rows = mysql_num_rows($select_page_view); ?>
            <td rowspan="<?php echo $num_rows; ?>"><?php echo $row['page_view_date']; ?></td>
        </tr>
        <?php
        while($row)
        {?>
            <tr>
            <td><?php echo $row['page_name'];?></td><td><?php echo $row['visited_times']; ?></td>
            </tr>
  <?php } ?>
<?php }?>
</table>

当我测试我的generate.php时,页面显示了page_name的无限循环。。。有什么解决办法吗?

最佳答案

你必须这样改变循环:

while( $row = mysql_fetch_array($select_page_view) )
{
    (...)
}

在原始语法中:
$row = mysql_fetch_array($select_page_view);
(...)
while( $row )
{
    (...)
}

$row被获取一个,然后它不会改变,所以循环不会停止。

09-10 05:02
查看更多