发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート: q. Q8 \3 T4 t1 D

2 r( X" A1 T+ ^6 Y相信现在很多人的数据库都会出现重名角色被替换的情况。
/ i0 [6 ]4 r: L# s8 {8 m: J魔力私服,最新魔力宝贝私服技术交流这种情况实际上是由数据库中的几个字段造成的,
1 i' s$ _: @+ S4 h! }4 L0 t  c% S0 P首先我们来分析一下数据库表
3 e1 c/ ^& E7 L; ]( q5 R妖城在线论坛
, n3 H& v+ i! I, C( E魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表tbl_user 这个 是存放角色登入账号的。其中包括:妖城在线论坛1 ]9 X! X% z' U& b# q
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
4 S8 o- X8 H% ]4 Rbbs.mocwww.com—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, j+ k' r# q( D" ~  J" u
这里基本英文大家也明白了
( x8 [5 r( Q; y1 z2 c—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートEnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 g& R% T6 W0 u1 W$ M: G  }
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
2 m* C! e9 k, Z/ Y0 Y& z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这个字段直接影响到
1 u# q& p4 |" _; Vbbs.mocwww.comtbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号妖城在线论坛1 R6 t7 f% Z* G5 u
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】妖城在线论坛2 W+ Z- L2 x8 d/ Y
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式) L+ D4 T5 E" j2 ?
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート  ?4 }9 d; Y6 s4 w) X/ G' H5 Y8 ?6 b
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
, C+ t) e& ]- ^7 q7 Vbbs.mocwww.com—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 F9 E( F# @! Q1 m0 l
bbs.mocwww.com* o. |; o* d% W. t# a6 l
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
4 o2 n: |+ }6 k/ @5 V4 `& w; s魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表所以
+ X$ U; H, |* |* J( c魔力私服,最新魔力宝贝私服技术交流恢复人物的方法是。
; T. M3 a3 u. g8 H% o/ Z魔力私服,最新魔力宝贝私服技术交流在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( i( l8 R# B7 ^# N7 ~
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可$ a  c* q2 {) _- x! V, R
这个RegistNumber 在tbl_skill的第二个字段也一样。
$ e6 t% f. `+ L魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表决定了该人物的技能
2 T( a( H/ E. F' q魔力私服,最新魔力宝贝私服技术交流那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
% D! W. D( c1 u4 V5 [
: n- ]: _2 Y' n; @* B# y! L6 r- ibbs.mocwww.com小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了bbs.mocwww.com. P- i! o$ c0 w: Y+ ]- e  u1 s6 k3 v" j
方法如下 打开注册网站的注册页
* o8 q2 R1 `- C4 Z3 X# m—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート找到这一行SQl语句:魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 a+ B' W" p  J. p1 t

: Z3 c& i! ]- N; s+ P5 U魔力私服,最新魔力宝贝私服技术交流$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')";
: T. Q, l1 K8 |& ]5 w0 e6 T魔力私服,最新魔力宝贝私服技术交流
  d3 {/ J+ r9 r* Q: u/ M5 E+ x魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表后字段的 '100'就是 创建人物序号
# t; |& v. d" \0 C妖城在线论坛自己更改即可造成重复也不会消失的人物。
; V2 z2 x0 X# e" `! i% K5 K妖城在线论坛—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート: T' {! B) m' K8 {
给高手们的建议:
5 s7 F7 Z6 [. J9 |7 t4 H, Z由于本人的汇编很烂(我搞C++的)
1 I" X" U8 Y1 s4 N8 S( R—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート所以不想研究gmsv或者cg_190的 IDA反汇编编译。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 l; g  L% c! O: \3 u

& A6 D( Z6 Q$ Z' V5 W! `7 r8 U妖城在线论坛懂这方面的朋友可以进行以下操作:魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( b, [2 w+ E% l0 [/ U
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
5 r- w- w; L' P% \5 D2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ N- u. ^& h* ?6 @
这样的话还是允许重名,但至少不会再删除。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表4 z' j9 z! C6 @. _5 l2 p3 }

' D; [6 j- O7 A% }* N) f魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート) M/ S9 q" L( o, S, W
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 S6 I8 C9 C2 q$ ~
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
- U  {6 }3 N$ r) ]妖城在线论坛REPLACE tbl_character VALUES……妖城在线论坛* h, a4 Y. w' b6 G: H$ f2 @! {( W) c
查mysql手册可知
! `. x" c; K  g1 z; X( B) D妖城在线论坛REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
8 I. x1 i4 P* n' M魔力私服,最新魔力宝贝私服技术交流嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
/ W7 j7 I3 ?! t1 }bbs.mocwww.com
9 c/ q5 W+ U0 }/ c4 p不过这样不删除数据,但是还会有重名的角色存在bbs.mocwww.com1 [; w7 P2 g% l: z
完善的解决方法可以从2方面考虑bbs.mocwww.com' y/ T$ |; k2 p
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)妖城在线论坛8 m4 ~- Q3 ^. r' c9 W
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
- a% }2 j) ^) B- L2 W1 Y# I妖城在线论坛和Name一样 就一定会被删除

TOP

发新话题