发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
& ~5 S" i8 Z! q, m, g; A0 L0 D—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
7 p4 P! J( O1 z* [3 G7 M魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表相信现在很多人的数据库都会出现重名角色被替换的情况。妖城在线论坛6 w6 Y7 V, K5 \- o
这种情况实际上是由数据库中的几个字段造成的,
4 s# F  U' g  d8 o1 F首先我们来分析一下数据库表
- m1 v7 f$ O7 A$ M
4 l) n- j  w- |, z/ N, Z魔力私服,最新魔力宝贝私服技术交流tbl_user 这个 是存放角色登入账号的。其中包括:
$ n( @0 P! p+ _% {/ A7 f3 G" Z; O( F妖城在线论坛AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
* [' F2 H; S) G: ]" |bbs.mocwww.com妖城在线论坛3 b4 w2 P2 z/ M% {$ m% V1 F
这里基本英文大家也明白了
0 \* W1 p" D# D" k( \2 h( h* p, P妖城在线论坛EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
5 C: o5 C6 v' Z: f% F  I魔力私服,最新魔力宝贝私服技术交流SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
1 {$ q9 [! J4 }3 M—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这个字段直接影响到* ^- I$ z) D) i! F2 Q
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
5 Q/ [# o3 f. K( x0 U3 M—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
+ U7 O9 y3 d6 A4 S8 `4 s魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
+ ]5 V. D! E7 b6 |魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表- X+ L: e" E. S( Y$ ?6 P" z2 J
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。魔力私服,最新魔力宝贝私服技术交流% {0 y! [' Q& K+ T
魔力私服,最新魔力宝贝私服技术交流  e2 w8 I/ P6 V) s$ l
3 j4 u6 _; h; ~4 j) {, G! d% C9 q/ ?
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
" a6 ~- w9 H# K4 P8 A0 }' v$ a, G妖城在线论坛所以bbs.mocwww.com  [0 P! B: X/ h$ b* w8 a( m! l2 N
恢复人物的方法是。
- D! Y( D9 V) v0 r5 @: N1 V$ l魔力私服,最新魔力宝贝私服技术交流在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
5 Y6 ]- \$ e/ {: f1 m+ e魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可妖城在线论坛; x2 h7 ]4 w- G" ~6 A& z$ a
这个RegistNumber 在tbl_skill的第二个字段也一样。
4 ^( U" Z, h6 K' Z" i7 E) T8 L妖城在线论坛决定了该人物的技能 6 x- q5 W2 T; Q' W
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~妖城在线论坛/ g" p  ~  K  z! P4 q  ?7 r

) ?# s5 C( a( z1 }妖城在线论坛小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了魔力私服,最新魔力宝贝私服技术交流% C) E, p: `7 m+ t( Q3 M0 A* z
方法如下 打开注册网站的注册页
# y( \/ E1 K. w4 ^0 y8 F9 \. I妖城在线论坛找到这一行SQl语句:
" s& o4 L4 [# M3 _魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表0 @6 ^6 T0 S* A- ^9 d$ u) L
$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')";
- S9 {+ D2 y9 L3 b! F: c% G2 V魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
+ _: |8 p- n) x/ H8 _" e& l魔力私服,最新魔力宝贝私服技术交流后字段的 '100'就是 创建人物序号魔力私服,最新魔力宝贝私服技术交流% ~, j, s, h/ ]% J2 L! Z9 |
自己更改即可造成重复也不会消失的人物。
) b, a" l, R$ n2 ?! y+ D2 N/ u魔力私服,最新魔力宝贝私服技术交流
" P  j1 e# o' Q7 {2 L6 X给高手们的建议:: M) D, Q- n1 `) ~/ V
由于本人的汇编很烂(我搞C++的)
- h: N5 s8 v) G# {9 G2 ~8 C妖城在线论坛所以不想研究gmsv或者cg_190的 IDA反汇编编译。妖城在线论坛2 j- R1 T, h( d( {& _& J( |; Q

  Q; ~( P: z7 U5 R3 W0 j# E# F0 pbbs.mocwww.com懂这方面的朋友可以进行以下操作:魔力私服,最新魔力宝贝私服技术交流* d0 k1 o. l8 g1 J+ S+ @  V+ f
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
  v3 S% g# l4 \# c& L" ]—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  T9 c$ [  M& _  u: j1 A' V) F
这样的话还是允许重名,但至少不会再删除。
  X$ R/ L- T/ Y8 @0 S; `& F—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
! a; w8 U) Z, i1 A1 i6 h妖城在线论坛PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
% I: A, o2 r0 m7 F魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表. e7 ^( t1 ]# l3 }, x
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表4 U2 g6 M0 g4 F7 |2 v# X
REPLACE tbl_character VALUES……
1 V. T" G9 ]$ q魔力私服,最新魔力宝贝私服技术交流查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表8 a& D& l# G# z4 w. E$ C
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
: Z. j2 l/ T% o8 ^$ [妖城在线论坛嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
( f1 }$ G$ Y  {5 Q9 Ubbs.mocwww.com魔力私服,最新魔力宝贝私服技术交流5 E& @( I* x% a. b- _3 y
不过这样不删除数据,但是还会有重名的角色存在- }8 i, T% ]& U0 C; O1 m1 O; E" [
完善的解决方法可以从2方面考虑
1 p. Z" n! |/ {" X3 W+ P& w; q& w4 v魔力私服,最新魔力宝贝私服技术交流gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート; b. l: E5 N; R8 h; @0 w% }
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumberbbs.mocwww.com2 d" @* f- g7 l. K
和Name一样 就一定会被删除

TOP

发新话题