被动式统计网站在线人数(2)
Session("GuestIP")=Guest_IP
'在线人数统计
' 判断在在线列表中是否在在已经超时的访客
IF Conn.ExeCute("SELECT COUNT(ol_ID) FROM blog_Online
WHERE DateDiff('n',ol_Time,Now())>20")(0)>0 Then
' 如果有则覆盖一个已超时访客的记录
Conn.ExeCute("UPDATE blog_Online SET ol_IP='"&Guest_IP&"',
ol_Time=Now() WHERE ol_ID IN (SELECT TOP 1 ol_ID
FROM blog_Online WHERE DateDiff('n',ol_Time,Now())>20)")
Else
' 如果没有则添加一条在线访客记录
Conn.ExeCute("INSERT INTO blog_Online (ol_IP)
VALUES ('"&Guest_IP&"')")
End IF
' 统计blog在线人数
blog_OnlineNums=Conn.ExeCute("SELECT DISTINCT COUNT(ol_ID)
FROM blog_Online WHERE DateDiff('n',ol_Time,Now())<20")(0)
' 更新blog信息中的在线人数
Conn.ExeCute("UPDATE blog_Info SET blog_OnlineNums="&blog_OnlineNums&"")
SQLQueryNums=SQLQueryNums+3
End IF
这样,在blog中需要显示在线人数的地方引用变量blog_OnlineNums就行了。
并且因为是被动式统计,对blog页面执行时间的影响几乎可以忽略不计,另外,这个方法统计的blog在线人数也有一定的准确性,可以满足一般的需求了。