转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> MySql >> 正文
PHP中利用mysql进行访问统计的思路和实现代码         ★★★★

PHP中利用mysql进行访问统计的思路和实现代码

作者:闵涛 文章来源:闵涛的学习笔记 点击数:871 更新时间:2009/4/22 20:48:25

看了网上很多统计都是使用文本来存储信息的,但是那样的话非常不方便,而且如果数据丢失了的话就很麻烦,如果存储在数据库里的话就比较好,把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存取 Mysql 数据乱码终极解决方案  [MySql]解决Table xxx is marked as crashed and should …
[MySql][MySQL]快速解决"is marked as crashed and shoul…  [MySql]MySQL DELETE语法用法详解
[MySql]mysql中时间日期格式化  [MySql]修改mysql导入文件大小限制
[其他]MySql常用命令大全  [Web开发]把ACCESS的数据导入到Mysql中的方法详解
[MySql]解决mysql 1040错误Too many connections的方法  [系统软件]利用crontab系统每天定时备份MySQL数据库
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台