Board logo

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

作者: 逆灵    时间: 2009-4-29 16:46     标题: 【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
. }3 O) S. J; F6 b" p魔力私服,最新魔力宝贝私服技术交流
3 L, R& Q" I- ~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート相信现在很多人的数据库都会出现重名角色被替换的情况。
: P. V- \  s( a魔力私服,最新魔力宝贝私服技术交流这种情况实际上是由数据库中的几个字段造成的,
" W, c, V$ a7 e; a% @) H魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表首先我们来分析一下数据库表
" L# {9 X% N0 P+ V7 X, H+ z% p* [魔力私服,最新魔力宝贝私服技术交流
+ Q$ q  I8 t$ c! o: E—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートtbl_user 这个 是存放角色登入账号的。其中包括:—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート8 h( n7 }4 U; u6 L
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
. I* Z& u# @% J+ m魔力私服,最新魔力宝贝私服技术交流
! ]# U! ]( N& O+ A1 R2 ~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这里基本英文大家也明白了
. o, @! @1 ]4 Y, z" u' A2 m& J. a8 |—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートEnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
# \* _3 l; d; G, A9 C) d5 M9 g7 x—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートSequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 b& f8 I2 E- b& `1 I' x4 w
这个字段直接影响到
% f8 Y+ b1 x5 D' G+ w5 x; z魔力私服,最新魔力宝贝私服技术交流tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号魔力私服,最新魔力宝贝私服技术交流# J, z0 p+ P. u! f+ Q: ~2 e' r4 L4 X
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
* {+ X/ q# a- m" ~; e5 h妖城在线论坛就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
6 W, O. I7 M  b+ T( z妖城在线论坛魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表; _- L6 O# [1 M1 G  S
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
2 r, c" b. r6 F( hbbs.mocwww.com; L( M8 l$ A% v6 ~5 S1 I

7 C0 M, F1 i1 v: f5 |5 I" N: G$ `魔力私服,最新魔力宝贝私服技术交流tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
- W$ R5 ]0 k( i) m$ \4 [bbs.mocwww.com所以
1 H1 C& P4 e# P$ R) w: \/ t% c& hbbs.mocwww.com恢复人物的方法是。
) y. C' x7 f( X6 t$ z* C魔力私服,最新魔力宝贝私服技术交流在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
) Z" ^+ j: `7 {魔力私服,最新魔力宝贝私服技术交流tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
4 m6 D+ p0 v  u$ [3 e# X—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这个RegistNumber 在tbl_skill的第二个字段也一样。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表* F" [0 ~' |; d9 S/ b* T
决定了该人物的技能
4 a1 w( I* c5 I( K那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
8 F! r& [' r% M—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
- C' x, d, M, v7 c  k1 O+ |bbs.mocwww.com小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了魔力私服,最新魔力宝贝私服技术交流+ Q% l6 r  r0 V5 m* q% Z0 c
方法如下 打开注册网站的注册页
  o: G. y# F9 h. V3 kbbs.mocwww.com找到这一行SQl语句:
( y  ^2 A! m' y' a5 ]魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
# h+ j. {# f0 l6 N3 a. 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')";
  A/ D  B1 k5 s妖城在线论坛—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート/ ?; B) n) Y& ?5 A3 A2 F
后字段的 '100'就是 创建人物序号
4 g( S4 J8 u8 p3 c; @自己更改即可造成重复也不会消失的人物。. L! }- B, r1 u

  A" E) n9 B0 r# C; t9 B( ]魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表给高手们的建议:
, _* P& ]: a0 T* @* a- }* M由于本人的汇编很烂(我搞C++的)
4 n' N, q1 x/ M  d- O魔力私服,最新魔力宝贝私服技术交流所以不想研究gmsv或者cg_190的 IDA反汇编编译。
1 p9 n' `; O+ Z) `5 o" g8 S. k. F魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
; V# f% z3 F7 Q, `! ]魔力私服,最新魔力宝贝私服技术交流懂这方面的朋友可以进行以下操作:
1 N/ Q3 m0 J% b魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。bbs.mocwww.com2 L7 t$ [$ I, N6 [- x% Q1 u. A+ e
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断bbs.mocwww.com8 S( _! R7 Q6 ~! P  n, _
这样的话还是允许重名,但至少不会再删除。0 q. g+ {% r/ @3 a7 G7 X& f' E$ p
妖城在线论坛0 Z4 S$ Q2 A* |$ h# v' d  T( L: Q% q
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
( w( X5 g, O4 v9 v# T9 ]0 P魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的bbs.mocwww.com  \; u0 ~" e9 Y; Q$ C" Y6 U
希望能共享一下 谢谢。
作者: 黄昏    时间: 2009-4-29 19:08

嗯 之所以会删除是因为创建角色的语句为
  |7 C6 L% @, Y—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートREPLACE tbl_character VALUES……
6 ]: l, W" `( E7 p* n; T7 W魔力私服,最新魔力宝贝私服技术交流查mysql手册可知
" w' \! ]0 R+ G妖城在线论坛REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。" M  Z+ a% s: q4 n, u
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……魔力私服,最新魔力宝贝私服技术交流  n+ P7 D# s4 m  M4 D
bbs.mocwww.com0 N: ?9 i- J' V) h; A
不过这样不删除数据,但是还会有重名的角色存在魔力私服,最新魔力宝贝私服技术交流5 j" h2 E0 ^1 f* R0 F- m8 F9 Y7 T; o6 ~
完善的解决方法可以从2方面考虑—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート. r$ }2 ~2 I  P) x) w1 _, X
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)妖城在线论坛3 p. R3 W2 D& K
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者: 逆灵    时间: 2009-4-30 01:40

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber, f. M9 v- D; M% e9 _; w" C% H
和Name一样 就一定会被删除




欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/) Powered by Discuz! 6.0.0