发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~bbs.mocwww.com) ]4 V+ c" m' Y8 l- K
魔力私服,最新魔力宝贝私服技术交流% Q5 p1 _3 P5 e8 G1 X
相信现在很多人的数据库都会出现重名角色被替换的情况。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 D2 r2 i' }" t+ K1 r( L
这种情况实际上是由数据库中的几个字段造成的,魔力私服,最新魔力宝贝私服技术交流: y+ S4 f" e7 [0 j" p) q1 f
首先我们来分析一下数据库表
; r% ~9 v. G" @: v# [; Ybbs.mocwww.com
- J2 ~+ O% P9 n1 E$ k妖城在线论坛tbl_user 这个 是存放角色登入账号的。其中包括:
$ [" r2 U5 w2 _5 K7 u" P' d魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
2 ~& K9 x* Y( }1 j5 `# i& ^2 B/ \$ hbbs.mocwww.com
1 ?2 Z! d( C& I8 ?  B这里基本英文大家也明白了
2 B) L6 G8 C' ^魔力私服,最新魔力宝贝私服技术交流EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
3 {3 c! G9 b1 X/ Lbbs.mocwww.comSequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 —魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, Q' v( Z2 m+ V5 y0 ]4 `9 ~; Y
这个字段直接影响到魔力私服,最新魔力宝贝私服技术交流, f0 a, f% B0 |2 b/ g
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号bbs.mocwww.com+ A0 _, g6 y5 v, Z  f9 F) v
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
, x  A- R1 q3 h3 J魔力私服,最新魔力宝贝私服技术交流就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
( W  s0 F: u2 J8 [/ K- [  C, g5 D魔力私服,最新魔力宝贝私服技术交流- x3 z7 q* Y2 q& P/ b0 u+ F
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。bbs.mocwww.com8 I- Y9 u: \6 ]' Y+ F! Z
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 k$ T' K# g- U+ @6 B

$ u. \/ C* }4 Y魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
* U+ N9 H) b) a% a; Q: g! i# `bbs.mocwww.com所以
1 [9 X* B5 c; W0 F3 Z9 i4 X妖城在线论坛恢复人物的方法是。bbs.mocwww.com' n  i; {& Z' L+ ?) I0 s% w' t
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和魔力私服,最新魔力宝贝私服技术交流3 O; M7 v6 w2 e  A; e2 ~" a
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート) B+ o% [3 t( k$ W" G
这个RegistNumber 在tbl_skill的第二个字段也一样。
6 Z' K7 K9 |7 m9 z; G妖城在线论坛决定了该人物的技能
- P& q# ~0 [1 _0 V; ^) L* }魔力私服,最新魔力宝贝私服技术交流那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  w- R2 _) u0 L

+ H3 }1 Z0 |( {8 ^9 @: g& V, z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( c# {, ~" x0 i- J
方法如下 打开注册网站的注册页
6 Z4 M9 C- F3 I5 O  j3 W6 X+ S5 r妖城在线论坛找到这一行SQl语句:
! F/ D9 x5 x6 j; {. H1 L0 J—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
/ |- `6 [5 n9 ?! K! u—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$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')";9 R! b! U! [. \( N5 h  l! Z0 ]
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% _9 a9 n0 e9 ?+ T( d/ t
后字段的 '100'就是 创建人物序号魔力私服,最新魔力宝贝私服技术交流5 @; w2 S9 I  M0 A6 J, `
自己更改即可造成重复也不会消失的人物。5 t% r: Y) I/ p! W) m
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表9 x9 r; f" U1 r  K9 ?
给高手们的建议:
. n7 u& r$ s' f3 z, i—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート由于本人的汇编很烂(我搞C++的)
" t- A& Y8 D! H魔力私服,最新魔力宝贝私服技术交流所以不想研究gmsv或者cg_190的 IDA反汇编编译。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表* h4 b* Z$ c  ]9 u2 r) N, u

( R: p: ?7 U1 z6 }妖城在线论坛懂这方面的朋友可以进行以下操作:
+ x7 x1 C! ~: L# t妖城在线论坛1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 D0 y$ j8 ]2 e* }. y
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
3 @9 ^4 J# R- R# I( V妖城在线论坛这样的话还是允许重名,但至少不会再删除。bbs.mocwww.com- S: `2 O' {2 \9 P
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  [! w8 F+ ~$ R. t& F; B
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
  g/ A1 c; b4 ~* ~) z7 v—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
' d2 J" z7 c) Kbbs.mocwww.com希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
. [! }. u5 F2 s: j' m—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートREPLACE tbl_character VALUES……
$ p9 m1 \3 T* y& I+ Y- S查mysql手册可知魔力私服,最新魔力宝贝私服技术交流6 f4 G: D' |( u6 K  n+ n
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート2 ]- V! R( c6 D7 k$ v; U
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
+ E, `) r8 q. X2 z( N
: E, b! ?  j0 D—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート不过这样不删除数据,但是还会有重名的角色存在
7 F0 s9 e4 e/ r2 r* _/ D' M( z$ [bbs.mocwww.com完善的解决方法可以从2方面考虑
+ ^, m* ^) h6 L/ ], _- ^3 m% T—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートgmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
7 N0 ]* \4 Y- f' S4 G6 S—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートcg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
2 \+ x$ g1 F8 }/ z魔力私服,最新魔力宝贝私服技术交流和Name一样 就一定会被删除

TOP

发新话题