发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
- C" s" ^, A. ^bbs.mocwww.com魔力私服,最新魔力宝贝私服技术交流' S& u2 M  }8 g9 X" ?
相信现在很多人的数据库都会出现重名角色被替换的情况。
5 W( ^, X6 F% [1 v—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这种情况实际上是由数据库中的几个字段造成的,
+ i3 o$ n+ Q3 u% B( e# X0 X, ]首先我们来分析一下数据库表
, s5 C1 F8 v9 B' k5 s. H& T—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, r3 \: l9 L: Z8 T6 ^* E
tbl_user 这个 是存放角色登入账号的。其中包括:魔力私服,最新魔力宝贝私服技术交流( r& e/ {/ k0 M" n
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
* N& O+ c8 ]$ x/ k( u( @
& c: h1 Q5 k3 c/ N* Y% I8 r魔力私服,最新魔力宝贝私服技术交流这里基本英文大家也明白了 —魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート. B9 q7 \' q0 _, N6 q; r
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
  Q! _8 X8 k* W' O  r魔力私服,最新魔力宝贝私服技术交流SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
' G( {% c! \3 U5 P7 X. k' Ibbs.mocwww.com这个字段直接影响到0 l  F5 u! b- b" U
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, {) w" w' n2 K/ d* ~
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】妖城在线论坛) [4 k9 @+ ~  D
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式bbs.mocwww.com7 a; N. v5 e1 f2 c& d, a& e$ S

' ~0 a/ i* Q5 [; X2 S: S! v4 ?  V魔力私服,最新魔力宝贝私服技术交流即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
2 ]. W7 w* F' M+ V" E& w, ~# m  l魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表bbs.mocwww.com/ G$ W+ b* S. {" e1 _3 W8 m
bbs.mocwww.com& A- i: F9 s* O
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。妖城在线论坛  [3 N5 t! _$ {5 H6 r4 _/ ]
所以, C; n# S1 M3 {1 d, n
恢复人物的方法是。
& Q$ N! K; @/ K- y: L魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和魔力私服,最新魔力宝贝私服技术交流( J3 Q# F4 b: A: o$ A# _9 _
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可妖城在线论坛$ M- \, e: I/ R& l8 g
这个RegistNumber 在tbl_skill的第二个字段也一样。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 `# Y4 U9 ^: E+ T5 J8 d; P
决定了该人物的技能 魔力私服,最新魔力宝贝私服技术交流- L" ]2 H; `+ E: [
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~bbs.mocwww.com  _% z; D) E; h6 |

( |& x( M9 D$ V4 {* g, H; p7 o+ b小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了bbs.mocwww.com6 l8 ?+ o4 Y5 ?4 o  T: H" h4 L/ B1 }
方法如下 打开注册网站的注册页妖城在线论坛! \  s5 T: r4 j% l" W
找到这一行SQl语句:bbs.mocwww.com. G8 k' ]& z" x) ^

9 L4 {( T. v# ], f! }妖城在线论坛$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')";+ G7 W" B% j6 g3 _' w' M0 f0 c
魔力私服,最新魔力宝贝私服技术交流2 v2 n4 W0 |4 h
后字段的 '100'就是 创建人物序号
* E+ [; z- L( w6 ]: c$ U—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート自己更改即可造成重复也不会消失的人物。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  Z. E$ o( b8 R; D! w: e1 O# s
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表" o2 ?0 e" r8 e5 l$ \
给高手们的建议:5 N) l9 E& j0 Q& M' w, l
由于本人的汇编很烂(我搞C++的)
  k3 C6 g; w# [1 @. W4 d所以不想研究gmsv或者cg_190的 IDA反汇编编译。
/ s& o, t! H' o, C' Z8 A—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$ E% ]* G. n0 \4 {+ D
懂这方面的朋友可以进行以下操作:
, q) }( p( Z2 C% Z( B9 V( k! d+ e—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
/ L3 J# G: v, ^+ @# m1 I7 w5 `* }9 t2 e2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
7 Z, W2 z0 Q- B1 M—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这样的话还是允许重名,但至少不会再删除。
: @, {+ i: `, N  j1 n, g! e魔力私服,最新魔力宝贝私服技术交流
1 x' s- K/ {$ I9 E妖城在线论坛PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。$ K- J: y- @( T3 b9 ~
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
, S) f( a. g( i+ V* e# G妖城在线论坛希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为bbs.mocwww.com7 j  u, c" }, [, C
REPLACE tbl_character VALUES……! m/ y1 T8 j# {' H6 P
查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表/ g' s- Z& A6 m9 [! d
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
: [& j/ o4 j  e—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
+ [# }4 U: d6 V2 L. o& b7 _( \—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート妖城在线论坛* G/ T' \( x# g; v4 y
不过这样不删除数据,但是还会有重名的角色存在
8 `' A% s$ H6 g4 i6 m8 t魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表完善的解决方法可以从2方面考虑bbs.mocwww.com+ m$ r% ?5 o: h% P8 g
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート( j) N! L, h- c
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber魔力私服,最新魔力宝贝私服技术交流5 }  z- d( ^* j* d
和Name一样 就一定会被删除

TOP

发新话题