发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
) o. I/ j( n0 o8 _: R—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート* L; r2 [% ]5 s% I: z3 S4 Y
相信现在很多人的数据库都会出现重名角色被替换的情况。
5 ~1 e- z8 k$ L妖城在线论坛这种情况实际上是由数据库中的几个字段造成的,
  [' @# l' J! z魔力私服,最新魔力宝贝私服技术交流首先我们来分析一下数据库表8 s* v+ y9 G8 x

% t/ [5 a( @  R& s" X& F4 r1 Mbbs.mocwww.comtbl_user 这个 是存放角色登入账号的。其中包括:妖城在线论坛1 B6 O# \) p7 F3 x
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
- p6 \6 l. p, H( |6 _4 l- x, ~% x- \—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
) p4 U. S/ w7 g3 o; d这里基本英文大家也明白了 魔力私服,最新魔力宝贝私服技术交流  d7 [3 v; M. j9 V, o8 y
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
, [7 _/ A$ @2 o, V) H. @* c2 m—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートSequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 D: L3 @! G; j' L0 w1 n; U+ E8 m% W
这个字段直接影响到魔力私服,最新魔力宝贝私服技术交流( h1 W, h  ?0 D& u* e6 L
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
, u2 }  `) f! l' O9 S魔力私服,最新魔力宝贝私服技术交流实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
* m8 d  a& a( r* `( d! U  w- T妖城在线论坛就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式妖城在线论坛- y5 U" f7 D, B' l" K' F3 \
妖城在线论坛, C5 N1 I, Z5 A  b$ g
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
9 j3 y- K( R, @1 p/ S8 G4 _魔力私服,最新魔力宝贝私服技术交流
$ l7 a, D; k# z6 O9 o) U1 I8 jbbs.mocwww.com# H6 ]. i+ b$ i) f
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
& }  w1 E* M; U- I" T所以魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( ?, q9 J% W; g" o$ @/ z- E5 i# j
恢复人物的方法是。
7 r# Z4 }7 h  T2 j# f  ]在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和bbs.mocwww.com; p6 L& J0 ^( @9 B5 o7 [+ y
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可妖城在线论坛: c' ?" O( P/ }- M
这个RegistNumber 在tbl_skill的第二个字段也一样。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート. \& ?0 K  ^" w
决定了该人物的技能
& o/ |; O  V) M! U- w$ Z魔力私服,最新魔力宝贝私服技术交流那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
. Q7 Z, t/ {0 e8 W% y. w魔力私服,最新魔力宝贝私服技术交流9 e# X: Z; K" S: K0 t
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
# g) ^/ Q) w/ F魔力私服,最新魔力宝贝私服技术交流方法如下 打开注册网站的注册页! E( w: I  F: }
找到这一行SQl语句:bbs.mocwww.com0 Z/ G1 s: y6 [$ @

, Q: B! M' G' G% U5 ^( k魔力私服,最新魔力宝贝私服技术交流$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')";魔力私服,最新魔力宝贝私服技术交流6 R9 Z$ X& H$ L; e
魔力私服,最新魔力宝贝私服技术交流# Y$ h6 O9 q/ Z. u
后字段的 '100'就是 创建人物序号
! s3 t* q4 p& ]6 D( X% t7 M0 e' m  t妖城在线论坛自己更改即可造成重复也不会消失的人物。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% O, E5 I% B# j9 s) z1 |

* P) y& h6 N8 T8 Z; ^& C5 N; a& N2 y给高手们的建议:
$ ]& J$ o/ p. t4 Q- e妖城在线论坛由于本人的汇编很烂(我搞C++的)魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 q$ ~9 e1 j% A/ y( r; k! r# a
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
+ L0 A  Y; ?+ x/ d; k% l/ Ubbs.mocwww.com魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( Z2 {) ^3 }" n4 E
懂这方面的朋友可以进行以下操作:
, W  {6 _2 b8 h魔力私服,最新魔力宝贝私服技术交流1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
6 T* u0 x- |4 p2 K) \+ ^$ K妖城在线论坛2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表6 ~4 I5 z# |8 b3 }, l- G
这样的话还是允许重名,但至少不会再删除。妖城在线论坛+ p" q  p$ b/ V9 M: ^- k# i+ v
妖城在线论坛, t* e% K' l5 u8 r2 m
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。魔力私服,最新魔力宝贝私服技术交流0 A/ Q$ D4 I' `9 b* x8 q
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的魔力私服,最新魔力宝贝私服技术交流; J# u  C1 ^$ o( O. k4 R
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート. W! }$ C9 V/ l' R$ G; V
REPLACE tbl_character VALUES……bbs.mocwww.com. p& Z1 D2 H5 S% l9 ?
查mysql手册可知
; i' g5 T' t  r1 v- K妖城在线论坛REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。bbs.mocwww.com; t$ ^6 p2 E4 o! U7 L- |7 \. |
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 |- D) M2 }7 b$ g- R3 ~. I1 U

3 D; W: {3 @& z妖城在线论坛不过这样不删除数据,但是还会有重名的角色存在—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート- N# d" x" B) q8 @3 q) c
完善的解决方法可以从2方面考虑
2 _* U  p( \6 p! O6 f% l: e- A妖城在线论坛gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
9 R/ i% Y% T* Jcg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber4 ~$ j% y7 H# h# d; }# |: A
和Name一样 就一定会被删除

TOP

发新话题