dousong5492 2014-08-14 02:33 采纳率: 100%
浏览 8
已采纳

平均PHP的不同和有序结果

I'm trying to get the averages from the rating column of my table, then display a row in a HTML table for each distinct div_id and its average rating, in descending order. I know this should probably be easy, but I'm having a hard time figuring it out. Any help would be greatly appreciated.

<?php
mysql_connect($db_server, $db_username, $db_password) or die(mysql_error());
mysql_select_db($db_database) or die(mysql_error());

$result = mysql_query("SELECT * FROM ratings") or die(mysql_error());  
while($row = mysql_fetch_object( $result )){

$ad = $row->div_id;

$result2 = mysql_query("SELECT div_id, avg(rating) AS avg, COUNT(*) FROM ratings WHERE div_id = '" . $ad . "' ORDER BY div_id DESC ") or die(mysql_error());  
while($row2 = mysql_fetch_array( $result2 )){

$adid = $row2[0];
$count = $row2[2];
$avg = round($row2[1],2);



echo "<tr><td>";
echo $adid;
echo "</td><td>";
echo $avg;
echo "</td></tr>";

}
}
?>
  • 写回答

2条回答 默认 最新

  • dongsi5381 2014-08-14 02:44
    关注

    Instead do tow queries, you can use the GROUP BY term in only one query.

    SELECT div_id, avg(rating) AS avg, COUNT(*) FROM ratings GROUP BY div_id ORDER BY div_id DESC
    

    php code

    <?php
    
    mysql_connect($db_server, $db_username, $db_password) or die(mysql_error());
    mysql_select_db($db_database) or die(mysql_error());
    
    $result = mysql_query("SELECT div_id, avg(rating) AS avg, COUNT(*) FROM ratings GROUP BY div_id ORDER BY avg DESC") or die(mysql_error());
    
    while($row = mysql_fetch_array( $result )){
    
        $adid = $row[0];
        $count = $row[2];
        $avg = round($row[1],2);
    
        echo "<tr><td>" . $adid . "</td><td>" . $avg . "</td></tr>";
    }
    ?>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)