发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
% z0 f3 C; ^: Q" Z—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
/ w+ l5 [$ @. s( k4 L9 l) `bbs.mocwww.com相信现在很多人的数据库都会出现重名角色被替换的情况。
. a. w& I+ d! r. t这种情况实际上是由数据库中的几个字段造成的,魔力私服,最新魔力宝贝私服技术交流. A" F) [9 J* a
首先我们来分析一下数据库表
6 O2 p) ?" ~/ U+ c' q7 T$ ]6 K- |妖城在线论坛魔力私服,最新魔力宝贝私服技术交流6 D; I% }+ }9 j/ B' s2 r3 b; \, l
tbl_user 这个 是存放角色登入账号的。其中包括:魔力私服,最新魔力宝贝私服技术交流! v$ D3 Z% K* v% I
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore魔力私服,最新魔力宝贝私服技术交流- n2 l& m0 I* B

! l5 F, v6 w2 N  G  _5 q  r魔力私服,最新魔力宝贝私服技术交流这里基本英文大家也明白了
+ R6 W7 Y+ L' r4 y' a" K魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
* Q8 E) z8 Q; m! I& A8 a- _% \魔力私服,最新魔力宝贝私服技术交流SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
: U" ^) ]6 \& _' J这个字段直接影响到—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート* E, F) ]. e# O, l, g6 _7 q
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号bbs.mocwww.com5 m. y8 j8 h/ \0 w
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表. c  H- ~! i5 b$ H3 d
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式魔力私服,最新魔力宝贝私服技术交流- V1 _+ ?) v. D& ]
魔力私服,最新魔力宝贝私服技术交流6 d7 t* K6 \$ e3 P
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
- @# t7 e1 B- [3 }妖城在线论坛
: H" ?' K! p  e' o妖城在线论坛
" A$ z0 h4 z8 R& y# `8 Tbbs.mocwww.comtbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
+ v/ J6 k' v9 k! |—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート所以% t- J) ^( ?6 M: N: G& n
恢复人物的方法是。bbs.mocwww.com$ P* V' q4 e& ~) t3 ]2 z
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
8 Z. m' _3 A5 U8 otbl_item 中的 该账号原来角色的 RegistNumber 相同 即可妖城在线论坛8 i" E! ]' ?8 p. K9 j: A6 L
这个RegistNumber 在tbl_skill的第二个字段也一样。
/ h" u2 \3 K- r0 P妖城在线论坛决定了该人物的技能 魔力私服,最新魔力宝贝私服技术交流( g4 S9 h: }( {$ X0 n# j$ V5 B
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~魔力私服,最新魔力宝贝私服技术交流( C4 k: p$ K1 l. n

7 Q* t7 E5 {7 I& l小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了bbs.mocwww.com: T; f+ y0 Q' w0 ~1 R
方法如下 打开注册网站的注册页
1 P$ _! |: s) A$ c7 R! B0 F0 @: z—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート找到这一行SQl语句:
% F) J& h4 Y9 Q) Y: {. W9 `魔力私服,最新魔力宝贝私服技术交流
. K. Z6 S4 Q% j—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$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')";
7 p; {; ?4 }6 V7 D妖城在线论坛bbs.mocwww.com' o. @, L5 S4 k$ ^  V8 ]; T' z# m+ Q6 ?
后字段的 '100'就是 创建人物序号魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表8 z1 C( b! n" n4 a3 n' [
自己更改即可造成重复也不会消失的人物。
$ L; M4 B: T& T, {妖城在线论坛
( u: x9 s# C7 N8 Z* N2 [魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表给高手们的建议:
( r- q& ]; T- {, o7 X4 ~: I! n. J魔力私服,最新魔力宝贝私服技术交流由于本人的汇编很烂(我搞C++的)
6 d( j1 L3 n8 j! E& u# K( `魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表所以不想研究gmsv或者cg_190的 IDA反汇编编译。魔力私服,最新魔力宝贝私服技术交流" u) q6 X& x6 P% V, X+ M* x8 m& Y( r2 b4 J
bbs.mocwww.com( M8 @* Y# k* Q* A# P) s
懂这方面的朋友可以进行以下操作:7 x; h3 A% p, A2 l8 g
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。) V: Q3 A6 h/ Z' A
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート& f1 H+ W" \" r# ^& E
这样的话还是允许重名,但至少不会再删除。
3 `* s, Z& F+ g7 S( F( G" b- `妖城在线论坛—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" A1 q% E5 ?3 Y7 ]
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。6 H9 g: p% w! O- h6 y5 l
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
0 u6 V! \4 K3 K( [5 q8 Q& u—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
& c/ I* @' Y, |" ZREPLACE tbl_character VALUES……
8 ~+ ~4 K% T1 `. i* R魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表查mysql手册可知
  x* P7 c" [3 h! ~魔力私服,最新魔力宝贝私服技术交流REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" M9 g( W' Z1 m. k
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……魔力私服,最新魔力宝贝私服技术交流8 d8 o2 u9 h2 i
魔力私服,最新魔力宝贝私服技术交流8 ]& ~9 v( ]. V5 W1 E& ]% |9 v
不过这样不删除数据,但是还会有重名的角色存在
) c: l+ M# g' M3 t/ n4 f! r完善的解决方法可以从2方面考虑
" v0 {, W: t. c+ o6 {bbs.mocwww.comgmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
% d* H" H/ q1 O1 J: J# E; Qcg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber% z! G* w+ {  {! `4 Q5 w
和Name一样 就一定会被删除

TOP

发新话题