发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~妖城在线论坛/ D* z$ u, K5 ~4 |: V+ e  j
1 W! l( W; s( p+ O0 {8 @
相信现在很多人的数据库都会出现重名角色被替换的情况。1 [6 I& j: d0 B# z" ^- Z, A$ ]
这种情况实际上是由数据库中的几个字段造成的,
7 ^9 {1 _- v; P9 p' n& E% ebbs.mocwww.com首先我们来分析一下数据库表
% q- d2 Y+ _8 g% @: u* U( x—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートbbs.mocwww.com5 a' W8 X" N/ S
tbl_user 这个 是存放角色登入账号的。其中包括:
6 J0 p5 r8 e9 z  g# ^1 [1 X) ?1 D妖城在线论坛AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScorebbs.mocwww.com) S' {0 I, d" m, ?1 ^& C9 b$ l

$ e* ^; M# |/ t魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这里基本英文大家也明白了 妖城在线论坛3 O- I  L2 t* x. D6 Q$ }
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
8 g; e* ]* f' f  y魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 $ _( b% y$ l% X3 d- h
这个字段直接影响到5 d+ A1 O+ @" p4 N9 u) P
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号bbs.mocwww.com, o3 T2 k  x+ E  k" S8 p
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】bbs.mocwww.com, d1 `+ b1 ?% m9 k3 A, h
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
/ K) {& @/ `, G
2 F( N- L% f. [) o# m魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。妖城在线论坛% T5 U4 v6 Z8 ^$ \& A" L& A
妖城在线论坛; i; _* P2 G, [7 Z" _2 r+ p! \

/ r8 g" y% T7 s& y2 P魔力私服,最新魔力宝贝私服技术交流tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
" w" |! e4 h& ]8 X9 N4 I2 y所以
& |# T: j' |! e+ K6 t# Ybbs.mocwww.com恢复人物的方法是。
* Y& H% p6 I8 K6 z* A魔力私服,最新魔力宝贝私服技术交流在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
% x( c8 e/ I5 t2 v, l0 Ktbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
0 H4 v1 K: i; ?9 J; P7 H% S# w魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这个RegistNumber 在tbl_skill的第二个字段也一样。
) V" I2 X$ u; X1 _( K% {2 f4 ~/ F# a—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート决定了该人物的技能 妖城在线论坛, n- ^6 c% a: }* q3 W& W  L
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~魔力私服,最新魔力宝贝私服技术交流: J2 A# ~3 c. Z) V+ M* f
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート# s: y% u4 F  R8 `
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表. ~+ @" w3 A2 F; z; N: J/ k
方法如下 打开注册网站的注册页—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート- i( u6 f. q; h. h4 N7 Y
找到这一行SQl语句:
% q' P) k/ Y+ I* f1 `—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
0 z1 B0 @6 I1 d% `妖城在线论坛$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,电影,黑客,网络,网吧,破解,入侵,注册表$ B" [; b4 x& V5 X- N! z) y

( v6 I6 J3 {+ d0 i. Z' N' F' i" E魔力私服,最新魔力宝贝私服技术交流后字段的 '100'就是 创建人物序号
1 D5 ^; \! D) I# a自己更改即可造成重复也不会消失的人物。
, h$ n/ _; |/ l. p0 [bbs.mocwww.com
0 F7 J3 F* b5 {/ L/ }. l1 d给高手们的建议:魔力私服,最新魔力宝贝私服技术交流$ a: h. U4 z" U) h/ U
由于本人的汇编很烂(我搞C++的)
  ?1 `3 {1 M! l* ^妖城在线论坛所以不想研究gmsv或者cg_190的 IDA反汇编编译。bbs.mocwww.com# p7 t9 W3 y# E1 q8 x' ~( W

' {0 U( D5 i) Y; t$ M妖城在线论坛懂这方面的朋友可以进行以下操作:bbs.mocwww.com6 b' y+ C& R8 L
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
( ~, r1 o3 P; x3 G! y6 s2 x0 S2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート4 g/ j5 {* s% K# a0 R" g) ]
这样的话还是允许重名,但至少不会再删除。
$ O3 m4 x4 j. ~! T2 O- A4 h4 d妖城在线论坛魔力私服,最新魔力宝贝私服技术交流* x0 M1 o6 J6 k0 V, `' t$ G
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
2 \+ ~+ j- o* v9 S妖城在线论坛我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% y2 U4 W# u; {& X3 I, q/ X" N
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
4 o7 U6 l" b4 L—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートREPLACE tbl_character VALUES……魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 ]$ k& b* b. e% I+ ]( _. F
查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表& e1 z9 X) z* Y. \4 ^
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。4 [( e- ~0 n0 l' q! L% W2 B$ t' s8 n
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
( W  K8 l. {# |4 X/ w- p) C—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
( S: v  V& ~( J4 P/ |, B+ p魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表不过这样不删除数据,但是还会有重名的角色存在bbs.mocwww.com- ~; y. A6 J6 \2 e3 Y* F
完善的解决方法可以从2方面考虑
- L% m/ a- M1 ~. ~, N& z—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートgmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
$ r, P# ^; ~2 F% q  N- _3 H. G/ lcg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber3 _. [5 ]# [2 u" Q8 n, n
和Name一样 就一定会被删除

TOP

发新话题