Board logo

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表& w# d. M- @$ j0 e4 `
妖城在线论坛* u5 i5 @- e5 t8 ~3 \$ ]
相信现在很多人的数据库都会出现重名角色被替换的情况。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 K) z" w" |* A. A* E" M
这种情况实际上是由数据库中的几个字段造成的,
- K8 b7 \  ]0 h4 A妖城在线论坛首先我们来分析一下数据库表魔力私服,最新魔力宝贝私服技术交流6 r  L: n$ U6 E" o

+ y& \" @& x# {5 C* M. b/ K& p, k6 \魔力私服,最新魔力宝贝私服技术交流tbl_user 这个 是存放角色登入账号的。其中包括:魔力私服,最新魔力宝贝私服技术交流- F/ ^. a1 k4 J% x+ a
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
( h* ~  X) w( r$ V  J! b& G5 X—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートbbs.mocwww.com( L7 g2 \& a) u" @% U
这里基本英文大家也明白了 bbs.mocwww.com% g9 N. _$ r7 `
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是妖城在线论坛  o; {# D4 l$ N
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 5 ?% @/ l7 E, `6 u* [( F
这个字段直接影响到魔力私服,最新魔力宝贝私服技术交流, q% K7 G- B/ o9 Z- Y7 ^5 I) M
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表- v8 c* C2 A+ P/ Z# [+ V
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
6 J" C+ P3 R3 r5 X—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
& M' L2 h0 i7 K0 F魔力私服,最新魔力宝贝私服技术交流
$ j1 Y% f- e8 H' ?7 @1 W即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。妖城在线论坛5 s4 y8 p! m# R5 w6 F3 k
bbs.mocwww.com" O" h2 Q7 c% |( j
妖城在线论坛& U1 W1 Q5 N' B& A+ ~3 V
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
0 z# S$ U: K+ A( s8 x9 i$ ~魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表所以妖城在线论坛/ |6 V5 @0 g3 @9 f$ I% B  s2 h
恢复人物的方法是。1 t7 D. k6 f6 ~* ~5 b
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和9 r2 f9 u2 v; N0 K" t
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
; |" c5 [  j. v6 W. |% U. `bbs.mocwww.com这个RegistNumber 在tbl_skill的第二个字段也一样。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表# g8 l* T+ `. B7 g( |5 v
决定了该人物的技能 —魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 h* {# c8 m0 D; A
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
+ V" V+ c" s2 w! ]: y) \, t! ^妖城在线论坛
8 v8 p; \2 m7 b6 U2 j) D魔力私服,最新魔力宝贝私服技术交流小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート# B' `$ m! K4 x, Z0 Y6 ^' l
方法如下 打开注册网站的注册页
" A  W% C& o% M9 {8 N妖城在线论坛找到这一行SQl语句:妖城在线论坛1 a" J1 j3 f% c" c% b, \( M

" j, F2 d  w4 M2 D魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表$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')";bbs.mocwww.com( h" f1 X. C. U" z# j0 x( ?
魔力私服,最新魔力宝贝私服技术交流8 J8 P6 Q4 w9 Y8 d8 a8 J9 K
后字段的 '100'就是 创建人物序号—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート# H+ w+ o% ]: k* |
自己更改即可造成重复也不会消失的人物。
6 [' M* K) |" B8 w) N妖城在线论坛
  [9 }" P6 p1 E4 q! ?—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート给高手们的建议:—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$ b! I7 w$ d5 l3 v: J* Z) I' d# u1 \
由于本人的汇编很烂(我搞C++的)
- _4 \8 G2 Y& X3 q/ E/ D魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表所以不想研究gmsv或者cg_190的 IDA反汇编编译。妖城在线论坛5 Q; s/ m# s6 k" S- P" j0 G
魔力私服,最新魔力宝贝私服技术交流  ~, o$ Z) ~" m, p$ d# q
懂这方面的朋友可以进行以下操作:
$ f+ T! p4 D" [' H—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
: j7 ?) f" h$ v8 v+ P妖城在线论坛2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
) }5 O' h, F% E魔力私服,最新魔力宝贝私服技术交流这样的话还是允许重名,但至少不会再删除。bbs.mocwww.com$ x; [; E; V2 Y: G- O. O) H2 Q6 T8 V
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  _0 i; K& H1 b9 A+ b
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。4 ?  l4 K. o. R" M5 a8 D
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
& L% d& B1 \' _/ x+ ^魔力私服,最新魔力宝贝私服技术交流希望能共享一下 谢谢。
作者: 黄昏    时间: 2009-4-29 19:08

嗯 之所以会删除是因为创建角色的语句为
3 S" k% [3 ~& Y; V魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表REPLACE tbl_character VALUES……
7 a4 y8 M  O- [2 ~* ]1 d魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表查mysql手册可知
$ J, T5 t7 T9 e( K# a8 N# H4 U" Lbbs.mocwww.comREPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
8 y/ i2 M7 k$ K5 P1 H7 [* ]bbs.mocwww.com嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
8 }, L7 f  g+ v魔力私服,最新魔力宝贝私服技术交流bbs.mocwww.com: l4 B2 q7 m2 i' G% K& G6 a6 q5 X
不过这样不删除数据,但是还会有重名的角色存在魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表: S0 p, l/ Q/ r5 {
完善的解决方法可以从2方面考虑
# ^: h( |. f- n' w- }* x; O魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( F$ ]+ ?0 w) L+ C; _& \! m
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者: 逆灵    时间: 2009-4-30 01:40

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
; Q# d% I4 S$ y6 C: M1 ]) T  u魔力私服,最新魔力宝贝私服技术交流和Name一样 就一定会被删除




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