发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~魔力私服,最新魔力宝贝私服技术交流6 |: R. S  d4 w  e

. x0 `; L$ [9 ?+ E% {( H- l' Pbbs.mocwww.com相信现在很多人的数据库都会出现重名角色被替换的情况。
0 m1 Y/ W9 B% a8 X2 Z3 a6 [bbs.mocwww.com这种情况实际上是由数据库中的几个字段造成的,魔力私服,最新魔力宝贝私服技术交流6 a) n( u1 U5 Y7 Y
首先我们来分析一下数据库表魔力私服,最新魔力宝贝私服技术交流5 F" X9 s4 O" K& K

* i6 m% I, t; h1 ttbl_user 这个 是存放角色登入账号的。其中包括:
; |8 O2 ]- {' P/ ?4 {—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートAccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore: G4 ]0 m) N; ~# o7 u3 |4 ?
bbs.mocwww.com6 x1 b& x" o: T, ?" x( O' n
这里基本英文大家也明白了
2 S' w! G) z, q3 ^) ]5 `—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートEnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是妖城在线论坛1 w/ h5 ^& K& ~6 y+ x2 ^, V
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 0 d" ?; h" w+ z8 u
这个字段直接影响到
4 |. P1 |- \  V—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートtbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
& j, i1 u. L" ~, }! T$ U( e# ^实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
  t) F' h; m# g0 T+ D: u% O' \魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式# `+ C% t/ k. }2 @
妖城在线论坛! Y, W) ^2 N6 y9 g; O0 ]; q6 U
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。; N! w3 j! ?1 S8 |7 m/ ^! a1 l- G
妖城在线论坛4 @+ {9 a7 U: S5 B5 Y$ j% c
妖城在线论坛; v  z+ O. j& Y6 G: N" o8 `
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
# U( @7 j0 \3 B( O7 q' T所以
  y% h3 j, f+ y$ q# g3 J4 ?魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表恢复人物的方法是。
( T7 U# t! \* [  g  ?) ^$ a/ r( ^bbs.mocwww.com在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
* V6 L& i# n$ z( ]魔力私服,最新魔力宝贝私服技术交流tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表$ x$ c1 l) G9 N  F/ N: t0 v% h9 S9 o
这个RegistNumber 在tbl_skill的第二个字段也一样。
& g& |/ B8 A2 p5 W( ?' A& n: T. R决定了该人物的技能
8 \! K. s% v* I, [  {bbs.mocwww.com那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~5 S0 U! b& d% x. s/ F5 E

5 a' _  J' J5 W- r) gbbs.mocwww.com小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート# V8 O$ y8 U* J/ w1 |" t$ A4 h
方法如下 打开注册网站的注册页  V2 \, l3 D6 J1 P) s2 ^
找到这一行SQl语句:bbs.mocwww.com9 d' U8 j: t) t9 e( ~4 K% H4 E5 e8 @

. ]& I) u+ t7 z9 P2 O魔力私服,最新魔力宝贝私服技术交流$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 ?, f1 k; A" Rbbs.mocwww.com
$ x: L$ a2 |0 i% X+ o9 Kbbs.mocwww.com后字段的 '100'就是 创建人物序号bbs.mocwww.com! {, G7 O1 Z& ]6 K( e
自己更改即可造成重复也不会消失的人物。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( B6 p$ L/ Z/ t( a

1 v' v( S- U2 u) g5 m/ @. ^4 X( C1 q—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート给高手们的建议:' c$ L: s+ B8 b7 ?
由于本人的汇编很烂(我搞C++的)
# K3 g& A4 o% h2 }7 A/ X4 r魔力私服,最新魔力宝贝私服技术交流所以不想研究gmsv或者cg_190的 IDA反汇编编译。
9 n2 U& a# I5 A  b' o7 X妖城在线论坛
; a" t" C) c8 b% h' Y懂这方面的朋友可以进行以下操作:—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 F8 @% ?8 B6 h  ^8 C/ @
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
& Y3 ~& W8 j9 `6 @魔力私服,最新魔力宝贝私服技术交流2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断妖城在线论坛% i5 Y4 r7 o! v( }9 ]: u
这样的话还是允许重名,但至少不会再删除。
* X" f; w% D" j/ g% ?- O3 S- d' _魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
7 e) t3 J. a$ \6 V0 X魔力私服,最新魔力宝贝私服技术交流PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
! m) B, U% @1 H: Xbbs.mocwww.com我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
( [: Y( V7 P( i) [bbs.mocwww.com希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为魔力私服,最新魔力宝贝私服技术交流: t& R( i/ O0 [3 h
REPLACE tbl_character VALUES……妖城在线论坛) ]1 Z. _3 V! s. X, b
查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表" I( T! W- C4 E' {) J: z+ I
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート4 n. y+ m; j: c! w( i) M( w
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
0 W5 y; W/ E  w2 k6 c! Z妖城在线论坛
7 A* p9 `4 I* {/ i4 Pbbs.mocwww.com不过这样不删除数据,但是还会有重名的角色存在—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 Y; g8 o8 q5 b1 L. W( ~
完善的解决方法可以从2方面考虑
6 e9 F! A: U' g9 C$ D魔力私服,最新魔力宝贝私服技术交流gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)9 X, ]4 [" Z4 z+ l
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
4 {) o* q. W# X) s—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート和Name一样 就一定会被删除

TOP

发新话题