飞飞世界论坛

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 16972|回复: 0
打印 上一主题 下一主题

在线玩家数(没有错误)

[复制链接]

197

主题

203

帖子

1086

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1086
QQ
跳转到指定楼层
楼主
发表于 2016-1-10 03:45:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在过去,我已经看到了各种方法检查当前在线玩家人数,但我见过有一个致命的缺陷。根据服务器被关闭(或更确切地说,如果它崩溃)播放器的计数被搞砸了。下面是我在谈论一个:
1 ^- ?9 z8 }- Y8 k/ P4 Z代码:
4 U( W* M( q3 H; W! K( k; @; j; x
7 U6 G/ k) H. J. y1 X6 i+ Y$mssql = mssql_query("SELECT * FROM [ACCOUNT_DBF].dbo.[ACCOUNT_TBL] WHERE isuse='J'");" \/ ^: b" F$ i
echo mssql_num_rows($mssql);- j0 V; ]: ?) }  b. t1 J
这里有一个更正确的代码,它会自动复位计数,每当世界上的服务器程序打开当前在线:
9 `* C% o8 K2 L$ O5 C
. v6 t0 u1 @/ C# k9 i+ d7 V代码:
4 P$ k# y/ F9 w6 D" v4 }* z: U$mssql = mssql_query("SELECT * FROM [CHARACTER_01_DBF].dbo.[CHARACTER_TBL] WHERE MultiServer!=0");
( M" L: o* s. M7 b# ]echo mssql_num_rows($mssql);Credits to Sedrika for changing MultiServer=1 to Multiserver!=0
" V5 l" ?; L, X2 P3 s' K2 J) `5 ?* \! i/ |4 ^' a6 @/ r
Spikensbror的更快的方法: 1 k# c  B- {9 [; @
邮编:
1 y/ |9 E+ L( F7 r* N2 x4 M# O7 v" C+ i& S' e  \$ u
$query = mssql_query('SELECT COUNT(*) as [CCU] FROM [CHARACTER_01_DBF].[dbo].[CHARACTER_TBL] WHERE [MultiServer] != 0;');
1 l+ G( t' ]. I8 d4 d$ccu = mssql_fetch_assoc($query);
$ G# T6 G- y  M  C  T# Z1 w, L$ F$ccu = $ccu['CCU'];6 K* d$ L3 ?% f! I
6 C4 ?, e- G- t1 ]9 ~( J7 V

8 l% t3 H$ [" l6 e& j8 ~" |: V) i3 O6 D$ H" V
4 W( |3 x: Q% y& S- n
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|飞飞世界技术论坛  

GMT+8, 2025-12-13 22:14 , Processed in 0.059013 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表