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