douchou8935 2014-03-26 12:44
浏览 21

循环记录集PHP

I have just used this code in a project which works perfectly, but I have noticed that the first record is always not displayed. Eg. the SQL query lists 15 results, but the output only display 14, missing the first record. Any ideas why?

<?php
$result = mysql_query($sql);

//first put all the results into an array so we can look backward and see previous items
$resultSet = array();
while($record = mysql_fetch_array($rs2Dfiles)) {
$resultSet[] = $record;
}

for ( $i = 0 ; $i < count($resultSet) ; $i++ ) {
if ( $i == 0 ) {
//for the first item, show the category name
echo '<div class="Box"><div class="BoxHeader gfgreen"><h3>'.$resultSet[$i]['ftCatName'].'</h3>    </div>';
} else if ($resultSet[$i]['ftCatName'] != $resultSet[$i-1]['ftCatName']) {
//every time we encounter a new category, display a new line and show the category name
echo '</div><div class="Box"><div class="BoxHeader gfgreen"><h3>'.$resultSet[$i]  ['ftCatName'].'</h3></div>';
}

echo '<p class="Document"><a title="View file details" href="download.php?id='.$resultSet[$i]    ['DownloadID'].'">'.$resultSet[$i]['DownloadName'].'</a> ('.formatSize(    filesize('DOCS/'.$resultSet[$i]['DownloadFilename'].'')).')</p>';
}
echo '</div>';
?>
  • 写回答

1条回答 默认 最新

  • drh78568 2014-03-26 12:52
    关注

    You could use a foreach, might make things easier?

    $last = null;
    
    foreach($resultSet as $resultRow)
    {
        if ($resultRow != $last) 
        {
            echo 'your html content goes here';
            echo $resultRow['propertyName'];
        }
    
        $last = $resultRow
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题