发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
' m6 U6 Y5 h' p, w$ ^—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表2 u1 c( d* N2 h
相信现在很多人的数据库都会出现重名角色被替换的情况。
. b) n- ]. G( a' q/ v魔力私服,最新魔力宝贝私服技术交流这种情况实际上是由数据库中的几个字段造成的,bbs.mocwww.com) s& k: X2 A- `# z# w  n
首先我们来分析一下数据库表
! L6 o1 [! O' U, D: d+ A—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート妖城在线论坛; q$ D- @& j% t
tbl_user 这个 是存放角色登入账号的。其中包括:魔力私服,最新魔力宝贝私服技术交流% d/ r4 E: n0 ^9 J) R! x& Q2 _% s, w
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
/ Z" z6 p( I2 V% D8 P+ e+ Y) v魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表魔力私服,最新魔力宝贝私服技术交流. o/ R* A4 Q# W% ^2 X/ X9 j
这里基本英文大家也明白了 —魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 ?' j) j' [/ I1 x
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
/ l! D0 t" J1 U+ ~魔力私服,最新魔力宝贝私服技术交流SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表* ]  {3 U2 D8 |' Y  R# ]* W
这个字段直接影响到' K9 G' {) {- `8 O
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
9 M: w5 D; q, ]6 H  [: z' d3 Kbbs.mocwww.com实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
, D9 ]* Z2 y4 y( K" ~魔力私服,最新魔力宝贝私服技术交流就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式魔力私服,最新魔力宝贝私服技术交流3 W6 }5 e  q" ^$ ^

8 B" R" q/ U7 ~- q- E/ ?" C1 M魔力私服,最新魔力宝贝私服技术交流即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
' @( \3 t# J3 R( F魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
* K1 f# ?9 l; j7 h6 C. H$ F—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
& w0 c0 c" i% u! o" a妖城在线论坛tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
. @6 o. w: r9 A) E2 L7 t2 `0 g" `妖城在线论坛所以
) m) _; J2 M$ d; u5 p1 ^* ^) D2 f$ P—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート恢复人物的方法是。妖城在线论坛+ a. F9 j" L6 T5 ?
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和妖城在线论坛4 k1 ]5 L% R7 e
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 B' e' _& R7 a! h5 ]
这个RegistNumber 在tbl_skill的第二个字段也一样。
, N- u$ L  U( S; u  {" I8 @& M; v决定了该人物的技能
, V. o" s1 h6 i% |8 [魔力私服,最新魔力宝贝私服技术交流那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, R0 v9 V6 K6 T) g7 }

' \0 C/ S! b9 W2 K$ m& v/ |—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
. I+ S4 y4 W$ ?3 K5 C—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート方法如下 打开注册网站的注册页妖城在线论坛$ c  N9 t( U* x
找到这一行SQl语句:魔力私服,最新魔力宝贝私服技术交流3 W) V& R9 k* \' B* c' _% @- i
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表6 ?5 X! h/ V. V; E& [# w. t& J
$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')";魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表* i) p; e7 Y: Q" U# j
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 t8 _: x% O+ u+ j' }1 x
后字段的 '100'就是 创建人物序号
) x; {4 H8 h. r5 K- C4 T自己更改即可造成重复也不会消失的人物。
: n6 B" o* J$ M& t% zbbs.mocwww.com妖城在线论坛% D( m; \5 K0 z( g+ F# g4 X
给高手们的建议:
0 u! K) Y  \$ ?  A: |妖城在线论坛由于本人的汇编很烂(我搞C++的)—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート; t7 ?8 Z% p+ T5 N
所以不想研究gmsv或者cg_190的 IDA反汇编编译。妖城在线论坛  J* d) L( _: D, }& w& |' p6 |& v8 f

/ Z5 ?5 H7 d6 U# b  B: j0 y6 rbbs.mocwww.com懂这方面的朋友可以进行以下操作:
: F) K6 s+ {! l6 }bbs.mocwww.com1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。魔力私服,最新魔力宝贝私服技术交流  a( C  k0 M* U
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断妖城在线论坛9 |3 y7 G) O7 A3 H3 r& [( e( |! t
这样的话还是允许重名,但至少不会再删除。
" h- C* t  _0 E' Z# e0 v妖城在线论坛魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 K1 f" C; u; p2 d% k) A9 M$ H
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
0 m" F, \. W* V5 ybbs.mocwww.com我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
0 U  h" b1 x; D* l" ^4 M; M8 [5 `% T魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
* \1 B) R4 }6 v魔力私服,最新魔力宝贝私服技术交流REPLACE tbl_character VALUES……魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表$ V- L* B% a% m3 b+ O( v4 N
查mysql手册可知
( n# ^3 U5 u+ ~5 }  T7 }bbs.mocwww.comREPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
4 C; g8 {: b/ f) o# A7 {—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……: O9 N( Q+ G7 b* i- Z' P
bbs.mocwww.com* |+ X% g, I/ N! p2 I
不过这样不删除数据,但是还会有重名的角色存在妖城在线论坛6 ?) C) N" m( S9 b* [, R! i1 X  s
完善的解决方法可以从2方面考虑魔力私服,最新魔力宝贝私服技术交流( Y3 c+ A( J- f& M8 Y; w
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% q+ ?0 K2 W1 ]/ W/ y
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber3 ~& K/ W1 j( P- d$ L) Z+ F  p7 t
和Name一样 就一定会被删除

TOP

发新话题