发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~: t/ s2 {  A6 i

4 `3 F; ~5 b* r7 y6 E6 h# F* Y8 [4 |—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート相信现在很多人的数据库都会出现重名角色被替换的情况。
% B$ g6 u. Z( k# ~" E8 W+ j魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这种情况实际上是由数据库中的几个字段造成的,魔力私服,最新魔力宝贝私服技术交流! i6 C+ Q2 @& x; M* p
首先我们来分析一下数据库表—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート6 f# v% k: }" e7 d+ U7 M  v
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表" E1 y+ u7 [6 i- i
tbl_user 这个 是存放角色登入账号的。其中包括:魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 j4 r5 V; n7 \6 H  V) E7 z
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート% y7 u- b  u1 a3 J
: ~, r/ L9 z: ?# e. s% p) Y
这里基本英文大家也明白了 bbs.mocwww.com" e% L7 Y' u. `! U# k% q
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是  M: e4 C& ]- o
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
( E4 ]! d  Q- \& I+ O  v3 A魔力私服,最新魔力宝贝私服技术交流这个字段直接影响到
, k3 u( w- K. o6 M( k9 ztbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  l# |0 m  p5 }9 [" G
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
/ _! L, Q- y2 T* c6 p5 G—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式4 n4 n  C0 }! [

* V) j  Z' }0 z; t: R; m( S—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。魔力私服,最新魔力宝贝私服技术交流8 E$ T0 Y" }1 s4 e) Q
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) i2 H" i4 Q& l2 l# p8 S/ O2 j+ F
妖城在线论坛1 ~: H2 R/ v0 @' v3 t0 f$ }% u' U
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。妖城在线论坛4 G* l  J% g) g  t
所以
4 _- Q+ Z, n0 A; Ebbs.mocwww.com恢复人物的方法是。
9 D5 I' M5 j4 G8 H; b魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート* @+ g- R) \! y* b- \& C$ j7 m% ^
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート; f9 N+ E- [0 W, @1 K6 E
这个RegistNumber 在tbl_skill的第二个字段也一样。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表4 {5 x1 X$ V' ~1 v' e+ J4 s
决定了该人物的技能 魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表! n! x: Y9 [2 w) u- H0 G! z
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
3 K3 b! V" }1 ~: ?, J
8 c% ^2 X* ]7 H—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了bbs.mocwww.com  b& p  ]8 X" p+ U: G  |' l
方法如下 打开注册网站的注册页bbs.mocwww.com, N- @0 r* F" [4 `
找到这一行SQl语句:
6 x8 {" o! u0 j+ ^7 W5 s5 h% P
/ u' I0 I4 n( U3 Z+ Ybbs.mocwww.com$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')";
- w$ J" O5 @9 p3 {- Z妖城在线论坛
( L8 w- ?: T- V4 N/ D后字段的 '100'就是 创建人物序号—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 |0 V5 K3 h7 E
自己更改即可造成重复也不会消失的人物。
* p  w- a; H4 _* _/ _  ^bbs.mocwww.com
! Y+ V" M0 A3 S  U2 S7 Hbbs.mocwww.com给高手们的建议:+ M1 Z- l8 J& [
由于本人的汇编很烂(我搞C++的)—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート0 u3 J, S5 R% t1 b
所以不想研究gmsv或者cg_190的 IDA反汇编编译。妖城在线论坛9 D% q* M5 X' ^+ V
- w6 L! r+ M$ \' }: `
懂这方面的朋友可以进行以下操作:
; {9 D' ]5 v' S5 I; C% p魔力私服,最新魔力宝贝私服技术交流1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート0 B/ a# R7 w0 I" S
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
" p2 N- f) s; m—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这样的话还是允许重名,但至少不会再删除。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表; O1 R( E: c$ u' Q6 ]( J
( W- ]4 k8 i2 j2 g1 ~" j
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。bbs.mocwww.com6 x9 w: v3 B2 H4 X, Y( L
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的7 E) E- l" s# V8 b+ K2 Z
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
( `5 \. L4 E+ p) N6 E妖城在线论坛REPLACE tbl_character VALUES……魔力私服,最新魔力宝贝私服技术交流* I$ N# T! ?4 [  }
查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表: v8 h% P5 I% h4 E6 [; T; Q
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
3 z! q+ v5 g0 h9 l% w4 T5 p# Fbbs.mocwww.com嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート( @$ X4 T) L  E  d. i% r- g+ ]

) E7 @4 L" b9 c1 x: f3 X8 r魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表不过这样不删除数据,但是还会有重名的角色存在魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表# W- v6 n! S4 f1 j
完善的解决方法可以从2方面考虑妖城在线论坛. {, ~9 d8 {. ~. z! q% X$ V: ~
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
3 g& n* i. L  _% j( {3 j. m( ^—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートcg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
! V3 O# d) _' E, M魔力私服,最新魔力宝贝私服技术交流和Name一样 就一定会被删除

TOP

发新话题