PHP中利用MySQL进行访问统计的思路

ZDNet软件频道 时间:2008-07-02 作者: | 中国IT实验室 我要评论()
本文关键词:访问 MySQL PHP Linux
 看了网上很多统计都是使用文本来存储信息的,但是那样的话非常不方便,而且如果数据丢失了的话就很麻烦,如果存储在数据库里的话就比较好,把WEB服务器和数据库服务器分开的话,那么就能够长期的保持访问统计的数据了。
 看了网上很多统计都是使用文本来存储信息的,但是那样的话非常不方便,而且如果数据丢失了的话就很麻烦,如果存储在数据库里的话就比较好,把WEB服务器和数据库服务器分开的话,那么就能够长期的保持访问统计的数据了。
  
  基本访问统计包括:日访问量、月访问量、总访问量、平均访问量、日最高访问量等等数据
  
  那些数据主要是关于时间的运算,为了方便运算,我们采用Unix时间戳是最方便合理的,下面我简单的说以下我实现统计的代码。
  
  数据库结构:
  
  #
  # 访问统计表
  #
  
  DROP TABLE IF EXISTS `st_accesscount`;
  CREATE TABLE `st_accesscount` (
  `access_id` int(11) unsigned NOT NULL auto_increment,
  `session_id` varchar(100) NOT NULL default '',
  `access_time` int(20) NOT NULL default '0',
  `access_ip` varchar(100) default NULL,
  `access_source` varchar(100) default NULL,
  `access_page` varchar(255) default NULL,
  `access_os` varchar(100) default NULL,
  `access_browse` varchar(100) default NULL,
  PRIMARY KEY (`access_id`)
  );
  
  实现代码:
  
  我把核心代码写出来,其他显示层代码和复杂计算自己想想,呵呵 :-)
  
  <?PHP
  /*********************************************
  * 文件:count.PHP
  * 用途:网站访问统计页
  * 版本:v1.0
  * 创建:2005-04-06 17:08
  * 修改:2005-04-06 17:14
  * 版权:heiyeluren
  *********************************************/
  
  /* 网站访问量统计 */
  /* 基本变量 */
  
  // 当前时间
  $cur_date = date("Y年m月d日 H:i:s");
  $time = time();
  
  // 把当前时间单独取出
  $c[y] = date("Y");
  $c[m] = date("m");
  $c[d] = date("d");
  $c[h] = date("H");
  $c[i] = date("i");
  $c[s] = date("s");
  
  // 今日访问
  $today = mktime(0,0,0);
  $db->query(" SELECT * FROM st_accesscount WHERE access_time>=$today AND access_time<=$time ");
  $today_count = $db->nf();
  
  // 昨日访问
  $yesterday = mktime(0,0,0,$c[m],$c[d]-1,$c[y]);
  $db->query(" SELECT * FROM st_accesscount WHERE access_time>=$yesterday AND access_time<=$today ");
  $yesterday_count = $db->nf();
  
  // 本月访问
  $month = mktime(0,0,0,$c[m],1,$c[y]);
  $db->query(" SELECT * FROM st_accesscount WHERE access_time>=$month AND access_time<=$time ");
  $month_count = $db->nf();
  
  // 总统计天数
  $db->query(" SELECT MIN(access_time) AS ago_time FROM st_accesscount ");
  while($db->next_record())
  {
  $ago_time = $db->f("ago_time");
  }
  $day = ($time-$ago_time)/60/60/24;
  (($day-floor($day)) > 0) ? ($all_day = floor($day)+1) : ($all_day = floor($day));
  
  // 总访问
  $db->query(" SELECT * FROM st_accesscount ");
  $all_count = $db->nf();
  
  // 日均访问
  $day_access = round($all_count/$all_day, 1);
  
  ?>
  
  上面的代码比较清晰,自己慢慢琢磨,恩,另外说一句,上面使用了PHPlib的db类库。

访问

MySQL

PHP

Linux


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134