快速业务通道

周排行、月排行榜开发总结(原创)

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-23

 预备知识:group by,MYSQL函数week()、month()

在设计数据库时一般都有一个字段来记录文章的点击率,如果我们要统计一周或一个月点击率排行光靠这一个字段是肯定是无法实现的。这时就要新建一个表,用来记录每篇文章每天的点击率。 假设这个表名为ranking,定义四个字段:rid(表ID),contentid(与文章ID关联),hits(记录每天点击率),date(时间,重要,查询时作比较) ranking大致结构 id      contentid      hits      date 1       2                   12        2010-12-18 2       2                   23        2010-12-19 3       1                   15        2010-12-19 4       2                   21       2010-12-20 一、统计 第一步就是要记录文章每天的点击率,这步非常简单,当用户查看某篇文章时,PHP程序会进行一次数据库查询,判断是否存在该条记录,如果不存在,说明是当天第一次浏览该文章,需要插入一条记录,后面的访客再看这篇文章时,只要更新点击率就行。这就是记录某篇文章一天的点击率。 PHP: $date = date("Y-m-d",time()); $contentid = 周排行、月排行榜开发总结(原创) - 凌众科技
快速业务通道

周排行、月排行榜开发总结(原创)

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-23
content

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号

GET[id];//当前文章ID $query = mysql_query("select * from ranking where contentid=''$contentid'' and date=''$date''); //查询数据库 if($value = mysql_fetch_array($query)){     mysql_query("update ranking set hits = hits+1 where id=''$value[id]'' ");//如果有记录,只需点击率+1 }else{     mysql_query("insert into ranking (`contentid`,`hits`,`date`) values(''$contentid'',''1'',''$date'')");//如果是第一次浏览,插入一条数据,点击率为1 } 二、查询 此时统计工作已经完成,接下来要把这些文章按一周或一个月点击率总和的顺序查询出来,这是个难点。 1.先要给文章分组并计算总点击率:select *,sum(hits) from ranking group by contentid order by sum(hits) desc 2.取本周数据筛选出来:select *,sum(hits) from ranking where week(date)=week(now()) group by contentid order by sum(hits) desc 这是周排行的查询语句,相对比较复杂,查询出来后再放到数组中依次显示出来,月排行也是这样,换一下函数就行,完整的PHP代码我就不写出来了。   http://bbs.php100.com/mode.php?m=o&q=user&u=53700

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号