发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
) N7 z% y. n) }4 |) A. o. X' d, F魔力私服,最新魔力宝贝私服技术交流7 a, D. M& @$ v
相信现在很多人的数据库都会出现重名角色被替换的情况。
9 X3 a* L9 g+ D  q0 z魔力私服,最新魔力宝贝私服技术交流这种情况实际上是由数据库中的几个字段造成的,
. d; X# D* V7 f+ `# Y—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート首先我们来分析一下数据库表bbs.mocwww.com8 m  `& A) N% r( F& X

$ `& _0 y+ {. @/ H0 g! g$ P妖城在线论坛tbl_user 这个 是存放角色登入账号的。其中包括:
  {" j+ A3 `2 t5 h1 l5 r—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートAccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore妖城在线论坛% L' Y9 U2 o. Z# q9 i. F
魔力私服,最新魔力宝贝私服技术交流5 R: c' s/ K5 J2 v; M. o' G2 X# c, s
这里基本英文大家也明白了
: H6 y, V/ \/ z3 V2 J魔力私服,最新魔力宝贝私服技术交流EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是魔力私服,最新魔力宝贝私服技术交流6 A, N* j7 T3 f& e9 A4 ?
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
/ t. f. L' P( E: d) z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这个字段直接影响到魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 P- r0 c" }& `' m
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号魔力私服,最新魔力宝贝私服技术交流" C- Q0 t- x& J9 d7 I: k3 d2 b# q/ P' S
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート1 r3 [+ k, O" \1 J/ N- F! Q
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
$ t- M0 W. r: L6 ^魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 n; R4 {7 g( Z5 ]3 A, Q7 _) ^
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。bbs.mocwww.com- y/ K4 l+ M0 ^
妖城在线论坛# L1 u5 R* ^! s9 Y
魔力私服,最新魔力宝贝私服技术交流: \! C1 |1 ]* F* R) C# i$ l
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。魔力私服,最新魔力宝贝私服技术交流* z% O3 Z  S8 x& \4 \" i0 |9 }, }
所以魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表2 L6 z+ u+ d3 ^5 x) p
恢复人物的方法是。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" n( W, H; S% t
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート8 ?9 R8 N+ p) h
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
6 Y8 N/ v" J5 R妖城在线论坛这个RegistNumber 在tbl_skill的第二个字段也一样。妖城在线论坛8 k7 q2 N& b$ L/ v) L- c
决定了该人物的技能
% O$ d2 \/ ]9 c. C那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~妖城在线论坛2 K' E( S9 s3 I$ N, W# b
$ y  r* G' k3 x$ _: b- L
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了% a) \; i! Y: \$ Z; H8 W
方法如下 打开注册网站的注册页% B$ f. E; r) Q* B- I9 |# t. G. _
找到这一行SQl语句:魔力私服,最新魔力宝贝私服技术交流( e2 g* T! l8 p+ r3 a3 m& q

8 _- ~: K; X2 w$ E' k- n6 `, H* Y! p魔力私服,最新魔力宝贝私服技术交流$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')";
$ l1 P+ u+ G0 I" [) d' e( z, Qbbs.mocwww.com魔力私服,最新魔力宝贝私服技术交流0 L- E) r0 F( l4 G3 k; v8 n2 J: |
后字段的 '100'就是 创建人物序号妖城在线论坛) @$ J* @( }+ Z. }) R
自己更改即可造成重复也不会消失的人物。
9 o/ Z8 \* t# t6 H/ Y7 \+ E% Z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
5 h7 H: q) u6 J$ {+ L# }& _妖城在线论坛给高手们的建议:4 g5 I* l4 G: J! I% H* g
由于本人的汇编很烂(我搞C++的)—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート5 {% q: w' f' R3 G! \: A4 L
所以不想研究gmsv或者cg_190的 IDA反汇编编译。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$ }! A$ a, e4 g5 @3 o

8 `) B" t4 c& @懂这方面的朋友可以进行以下操作:
9 ~1 k$ h+ ^% h6 O! c魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
) l+ d! ~9 ?' D7 ^0 O, N2 M2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
4 E; ]# f9 n: H8 }1 t* O; vbbs.mocwww.com这样的话还是允许重名,但至少不会再删除。
' b$ Z4 n) Q9 D8 I  e% `—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 {" p" Q" T7 q9 l4 x; K4 A
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート4 q8 U/ ^, v) A# f
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート# m8 z" ]' n# v5 e, g  {6 b3 K! R% G2 Q
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
( D3 E& r; W2 s+ s3 ~, W—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートREPLACE tbl_character VALUES……—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" m$ M* ^5 e. U0 [4 I8 l& }
查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) T/ k5 z3 _9 Y8 k2 n
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。bbs.mocwww.com! J' Z, [, H. o- u4 {
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート+ s6 z7 ]& H2 Y9 i" {

/ U3 k& J) }: T" Y3 I; {5 t妖城在线论坛不过这样不删除数据,但是还会有重名的角色存在魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ I, F" K' g! \& e) l
完善的解决方法可以从2方面考虑
, w  p. c3 ]8 m3 z" V魔力私服,最新魔力宝贝私服技术交流gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)bbs.mocwww.com% T; q! }, z$ @- \/ K! {4 v/ Q) W/ c
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート' n9 e; {2 x- A4 z1 \8 ~
和Name一样 就一定会被删除

TOP

发新话题