统计在线人数couter

原文:[url]http://tutorial.jcwcn.com/Web-Design/PHP/Web-Traffic-Analysis/2007-08-24/3025.html[/url]
 
InBlock.gifCREATE TABLE `user_online` ( 
InBlock.gif`session` char(100) NOT NULL default '', 
InBlock.gif`time` int(11) NOT NULL default '0' 
InBlock.gif) TYPE=MyISAM;
 
使用你的mysql客户端工具建立数据库表
 
InBlock.gif<?php 
InBlock.gifsession_start(); 
InBlock.gif$session=session_id(); 
InBlock.gif$time=time(); 
InBlock.gif 
InBlock.gif//$time_check用于检测是否超时 
InBlock.gif$time_check=$time-600; //设置时间10分钟=10*60秒 
InBlock.gif 
InBlock.gif$host="localhost"// 主机名 
InBlock.gif$username="root"// Mysql u用户名 
InBlock.gif$password="123456"// Mysql 密码 
InBlock.gif$db_name="test"// 数据库 名 
InBlock.gif$tbl_name="user_online"// 表格名 
InBlock.gif 
InBlock.gif// 连接到服务器并选择数据库 
InBlock.gifmysql_connect("$host""$username""$password")or die("无法连接mysql服务"); 
InBlock.gifmysql_select_db("$db_name")or die("无法选择数据库"); 
InBlock.gif 
InBlock.gif$sql="SELECT * FROM $tbl_name WHERE session='$session'"
InBlock.gif$result=mysql_query($sql);//执行查询 
InBlock.gif 
InBlock.gif$count=mysql_num_rows($result); 
InBlock.gif 
InBlock.gif//检查指定的session是否存在,否则插入记录 
InBlock.gifif($count=="0"){ 
InBlock.gif//指定的session不存在 
InBlock.gif$sql1="INSERT INTO $tbl_name(session, time)VALUES('$session', '$time')"
InBlock.gif$result1=mysql_query($sql1);//执行插入 
InBlock.gif}else { 
InBlock.gif$sql2="UPDATE $tbl_name SET time='$time' WHERE session = '$session'"
InBlock.gif$result2=mysql_query($sql2);//如果存在则修改连接时间 
InBlock.gif
InBlock.gif 
InBlock.gif$sql3="SELECT * FROM $tbl_name"
InBlock.gif$result3=mysql_query($sql3); 
InBlock.gif 
InBlock.gif$count_user_online=mysql_num_rows($result3);//统计session次数决定在线人数 
InBlock.gif 
InBlock.gifecho "在线人数 : $count_user_online "
InBlock.gif 
InBlock.gif//删除超时的session记录,10分钟之前连接的用户视为超时过期 
InBlock.gif$sql4="DELETE FROM $tbl_name WHERE time<$time_check"
InBlock.gif$result4=mysql_query($sql4); 
InBlock.gif 
InBlock.gifmysql_close(); 
InBlock.gif 
InBlock.gif// 打开多个浏览器页面测试下 
InBlock.gif?>
 
 
根据自己情况修改数据库配置。






本文转自 xcf007 51CTO博客,原文链接:http://blog.51cto.com/xcf007/108560,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值