发新话题
打印

[讨论] 【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。

【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
: i  q4 Y% W$ P4 V8 `bbs.mocwww.com
" p8 q# n' f4 V+ B3 D* S相信现在很多人的数据库都会出现重名角色被替换的情况。
9 L% Z% _0 Z0 J4 A魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这种情况实际上是由数据库中的几个字段造成的,魔力私服,最新魔力宝贝私服技术交流/ o7 D! k1 A3 j  A4 C6 @
首先我们来分析一下数据库表
- B, \1 }6 |4 ]3 m, ~/ `
% e; [4 e$ M  C3 u. o9 [. m8 ]tbl_user 这个 是存放角色登入账号的。其中包括:
1 x& v! o" O$ A  W$ \' o+ T6 a8 _7 j魔力私服,最新魔力宝贝私服技术交流AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
4 Q4 T( z6 W6 w+ M
0 A$ n1 M+ g7 ^6 l! K9 \妖城在线论坛这里基本英文大家也明白了 魔力私服,最新魔力宝贝私服技术交流+ I1 `( N1 {  Y5 O1 t. K
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
: e6 N/ c" u  \6 ]$ G) X# O$ [bbs.mocwww.comSequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 / Q' f& x- _3 t( x# d
这个字段直接影响到+ ^1 d9 C* P3 C% G* x
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
) n5 I  g& [  S5 A  u. g魔力私服,最新魔力宝贝私服技术交流实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
, ]6 n! V5 ^5 [) k2 z9 |5 J! B魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
# [( {) A# N) k' P" K: @魔力私服,最新魔力宝贝私服技术交流- d4 H3 ?' c: k# f9 N  E
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表6 N2 e5 n2 ?) d9 y
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) C7 V, A! _0 Q  n  Q

% g! c6 f3 G6 n3 _5 }bbs.mocwww.comtbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
* z; }. Y1 ~: y妖城在线论坛所以bbs.mocwww.com( }* R+ m& R# |" T3 I' t, |
恢复人物的方法是。! W6 {( [' |9 W0 d& M  j" N
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和bbs.mocwww.com9 `" b( ?8 y$ d7 Z7 i( d
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可bbs.mocwww.com$ J; b  |1 Z0 `9 ?, m
这个RegistNumber 在tbl_skill的第二个字段也一样。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表2 t# P7 r) L+ {# {9 L
决定了该人物的技能
/ x8 t9 W# [% e' l- x魔力私服,最新魔力宝贝私服技术交流那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~bbs.mocwww.com: O1 Y1 \5 H0 q7 f" P& Y
bbs.mocwww.com& y# s' H  d' v  Y" k
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了bbs.mocwww.com( k' d, S7 D4 c; A2 ?# s
方法如下 打开注册网站的注册页
  A! G5 x& @8 p找到这一行SQl语句:
0 _5 B" ]8 H& m7 W  n0 @% B—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ {( K" M# a2 n0 G0 K0 w
$sql2="insert into tbl_user (AccountID,AccountPassword,EnableFlg,TrialFlg,DownFlg,ExpFlg,SequenceNumber,UseFlg,BadMsg,CdKey,safeword,RegTime,ip,HellScore) values ('$id','$pass','1','8','0','0','100','1','0','$id','$mlhy','$data','$userip','$regscore')";魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ C' @6 t7 }3 J4 J& R- {

4 v  i( ?3 a& A" V魔力私服,最新魔力宝贝私服技术交流后字段的 '100'就是 创建人物序号妖城在线论坛* e- @, L/ g8 U; y- ], P
自己更改即可造成重复也不会消失的人物。6 ?. _7 x7 b3 l  C' i3 `

; x2 ?9 z% F+ r& B6 A5 j+ G魔力私服,最新魔力宝贝私服技术交流给高手们的建议:
* f: J' x3 A& b: Bbbs.mocwww.com由于本人的汇编很烂(我搞C++的)
% o- w; G" y6 }- H' ~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート所以不想研究gmsv或者cg_190的 IDA反汇编编译。魔力私服,最新魔力宝贝私服技术交流9 V1 t6 y! \. u1 `* P; t: l

, ~0 s. z/ {7 E* Y) F魔力私服,最新魔力宝贝私服技术交流懂这方面的朋友可以进行以下操作:妖城在线论坛/ a8 }& }/ L9 @5 x, g
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
# i( n) U% n; S魔力私服,最新魔力宝贝私服技术交流2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
) E, Z& {" N7 D5 I, G% ]* {7 ]% Kbbs.mocwww.com这样的话还是允许重名,但至少不会再删除。妖城在线论坛) Y) E: p& W' H/ N+ ~6 e

9 Y' S# [0 V: {' Z0 l  P7 JPS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
1 M# P& K+ o) a9 M& A8 {- A" y—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的妖城在线论坛/ u. c# l6 w8 i6 F" ^
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为魔力私服,最新魔力宝贝私服技术交流6 a9 v& ~3 v  ?0 I
REPLACE tbl_character VALUES……魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表, e7 ?) I3 V& Y6 y( Y
查mysql手册可知
, [3 b4 [/ R; q& k: e! s魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
; \& E  e. z9 y. W7 a5 m1 P8 V妖城在线论坛嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
* i. V5 Z6 N. x" V—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
9 D' \2 y, A/ q; l2 q9 V: d# `魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表不过这样不删除数据,但是还会有重名的角色存在妖城在线论坛7 R/ i. f/ Q- p3 D% l# A
完善的解决方法可以从2方面考虑
. Z% d) W. o7 k魔力私服,最新魔力宝贝私服技术交流gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
& g$ q6 b! U) {0 Obbs.mocwww.comcg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

在我今日的悲伤里,最为苦涩的是我昨日欢乐的回忆。

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
  C1 @0 Z! d% _  N' Q) F* u和Name一样 就一定会被删除

TOP

发新话题