mysql 点击量_php 关于周排行,点击量,月排行,点击量

本文介绍了如何使用MySQL来统计文章一周和一月的点击量。通过创建一个名为`ranking`的表,记录文章每日点击率,并利用`DATE_FORMAT`、`WEEK`和`MONTH`等函数进行数据分组和查询,实现周排行和月排行的统计。PHP程序用于更新和获取这些统计信息。
摘要由CSDN通过智能技术生成

SELECT sum(hitnum) hitnum, `vid` FROM `ranking` WHERE DATE_FORMAT(addtime,'%X%V')=

DATE_FORMAT(now(),'%X%V') GROUP BY vid ORDER BY hitnum

一句话搞定

预备知识: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 = $_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代码我就不写出来了。

三:更优化方法

计的Sql语句比较好写,sql语句如下:

SELECT DATE_FORMAT(ec_salesorder.duedate,'%Y-%m') as m,

sum(ec_salesorder.total) as total, count(*) as so_count FROM

ec_salesorder GROUP BY m ORDER BY m,也就是把duedate日期以月的形式显示

那么按周如何统计呢?通过mysql的week函数来做,

sql语句如下:SELECT WEEK(ec_salesorder.duedate) as m,

sum(ec_salesorder.total) as total, count(*) as so_count FROM

ec_salesorder GROUP BY m ORDER BY m,这个方法有个缺陷,不能显示年份,仅仅靠一个周数不方便查看统计信息。

继续研究mysql manual,在DATE_FORMAT函数介绍发现2个格式符和周有点关系:

%X Year for the week where Sunday is the first day of the week,

numeric, four digits; used with %V

%x Year for the week, where Monday is the first day of the week,

numeric, four digits; used with %v

把上面的Sql语句中改成:

SELECT DATE_FORMAT(ec_salesorder.duedate,'%x %v') as m,

sum(ec_salesorder.total) as total, count(*) as so_count FROM

ec_salesorder GROUP BY m ORDER BY m

显示的结果如下:

m total so_count

2009 11 10000.00 3

2009 12 44000.00 5

如果周日为一周的第一天,那么sql语句应该为:

SELECT DATE_FORMAT(ec_salesorder.duedate,'%X %V') as m,

sum(ec_salesorder.total) as total, count(*) as so_count FROM

ec_salesorder GROUP BY m ORDER BY

m

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值