PHP根据日期选择器输入

时间:2016-03-08 13:54:24

标签: php mysql

我有两页index4.phpgenerate.php。用户必须选择日期范围,然后点击index4.php中的按钮以生成generate.php中的用户报告。

index4.php
index4.php

数据库表
database table

我希望用generate.php这样的结果显示这些结果:
result table

这是我对两个页面的编码:
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 的无限循环...任何解决方案?

1 个答案:

答案 0 :(得分:1)

你必须以这种方式改变循环:

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

使用原始语法:

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

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