发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~妖城在线论坛7 r+ U5 @$ @, }9 n3 a

  W" h! x. L7 s+ A& r" W5 G相信现在很多人的数据库都会出现重名角色被替换的情况。
" M0 N0 O  u  _  k$ B妖城在线论坛这种情况实际上是由数据库中的几个字段造成的,魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) l. q( s. t( R4 M# O, p# W& {2 c
首先我们来分析一下数据库表
% l. }5 A4 [! W( \/ J8 l6 R, i* m
# z+ G/ l6 X3 Y0 c& o# Rbbs.mocwww.comtbl_user 这个 是存放角色登入账号的。其中包括:
- f, ?! n, T3 \* Y—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートAccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
6 B$ A3 t) D/ h# r. x; V魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表0 l. S1 Q9 C  b3 E0 L
这里基本英文大家也明白了 bbs.mocwww.com- j% I/ N1 O2 E5 Q3 ~
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
& W% b( F; n4 |  O" \& J魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
2 }& C( t8 _7 [. {4 N/ f3 D妖城在线论坛这个字段直接影响到
/ A2 G" W2 h0 K; F7 i妖城在线论坛tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
) g! `* H& K1 K6 ~魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート' p' k6 f# `7 z1 k/ F+ P
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
4 ]3 ^' h6 q9 Y" @  ?! \! S—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
# K. ~/ C: g$ o+ P4 _bbs.mocwww.com即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
8 t0 k* P+ Z0 A妖城在线论坛
3 k3 k$ k* _. h0 W魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
/ Q8 n" Y0 L  V% a, @/ U: k* }bbs.mocwww.comtbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
8 L, X# Y6 W! m' }, t) M魔力私服,最新魔力宝贝私服技术交流所以
; e6 Q2 G: r% Y: J4 h9 D; Ibbs.mocwww.com恢复人物的方法是。
3 o% V0 U2 d" F# T, ?) k魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和; H, R. F2 d: R+ c. ~: b
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表& n! j* k! P2 Q. M+ t4 \
这个RegistNumber 在tbl_skill的第二个字段也一样。
* n: k8 A0 ~& n) b6 }7 T) `; Q魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表决定了该人物的技能 bbs.mocwww.com, Y/ H% _7 b+ z" K+ K
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 B0 T* M% _: G5 v* J
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" q, Z0 s# \) m9 ?( q% w
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
7 _$ D! W/ I7 c魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表方法如下 打开注册网站的注册页
* D6 `" H' g2 n+ h! k' Q妖城在线论坛找到这一行SQl语句:
3 s- h  W, F4 e4 ]' V妖城在线论坛8 w) G7 D" K7 U/ l" h. z
$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')";
0 ^# P0 D2 ?9 _6 N妖城在线论坛
% q$ I; _% B, O: v2 |妖城在线论坛后字段的 '100'就是 创建人物序号
2 N6 m& Z( _8 j( h- V' ]7 B妖城在线论坛自己更改即可造成重复也不会消失的人物。
$ W9 C" Z4 i+ `# j5 v% P魔力私服,最新魔力宝贝私服技术交流
3 N5 ]* |9 K* o, cbbs.mocwww.com给高手们的建议:妖城在线论坛8 u8 x  ^1 ~0 B/ y5 h5 d
由于本人的汇编很烂(我搞C++的)
% E6 _. b  S0 c( T, g4 a7 b; b魔力私服,最新魔力宝贝私服技术交流所以不想研究gmsv或者cg_190的 IDA反汇编编译。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$ `5 e6 Z" t4 d: ]
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$ J2 L1 z* x2 d0 q
懂这方面的朋友可以进行以下操作:
- T8 {* Z0 F' A$ b& v* X妖城在线论坛1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
7 l) H. F+ d8 H1 M+ X* M6 cbbs.mocwww.com2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
" u5 e- D7 b2 A. S" F1 k妖城在线论坛这样的话还是允许重名,但至少不会再删除。
0 W6 [) @0 f2 \8 z1 R6 `妖城在线论坛
! j4 M- Y1 O2 @+ P; f—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートPS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" Z! k. `% o3 |" ^4 a& Y
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的+ y5 }0 {; ~. g( N% P9 [. y
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
0 ?9 t3 A4 k, g5 V" v& BREPLACE tbl_character VALUES……
# y0 Y. [& O+ I. \  n. r1 o—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート查mysql手册可知, p3 ^- z( g5 o- y
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
6 f/ z6 x& a3 `—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……- ~% G5 r6 H$ H* g" h$ n
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  E  K3 n3 d) q, }! S. g! [4 x( @
不过这样不删除数据,但是还会有重名的角色存在魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 P( E9 C/ m% \8 o
完善的解决方法可以从2方面考虑—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート0 W$ `0 V/ K( A) P4 [' l
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)bbs.mocwww.com$ g* k! O9 S, ^
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
4 e1 o$ h& R5 m5 k妖城在线论坛和Name一样 就一定会被删除

TOP

发新话题