我有两页index4.php
和generate.php
。用户必须选择日期范围,然后点击index4.php
中的按钮以生成generate.php
中的用户报告。
这是我对两个页面的编码:
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 <input type="date" name="start_date" required/></td>
<td width="24">TO</td>
<td width="173"> <input type="date" name="end_date" required/></td>
</tr>
<tr>
<td colspan="4"><i><font color="#FF0000">*</font> 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
的无限循环...任何解决方案?
答案 0 :(得分:1)
你必须以这种方式改变循环:
while( $row = mysql_fetch_array($select_page_view) )
{
(...)
}
使用原始语法:
$row = mysql_fetch_array($select_page_view);
(...)
while( $row )
{
(...)
}
$row
被取一个,然后它不会改变,所以循环不会停止。