发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
1 q. ]5 g/ k" k3 Qbbs.mocwww.com0 G) s% _1 i/ H* c7 ?3 ~6 Q
相信现在很多人的数据库都会出现重名角色被替换的情况。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) t# k3 j& Y& B1 [  h! k
这种情况实际上是由数据库中的几个字段造成的,bbs.mocwww.com8 l! T; \) ?- J/ J( l
首先我们来分析一下数据库表魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表0 q) |( Z. g7 W- B

- H& a9 L6 T0 B) l8 k0 A$ u5 y9 ztbl_user 这个 是存放角色登入账号的。其中包括:
' C1 M+ |1 E1 {5 r: T* _% I妖城在线论坛AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
* u" S5 W) y- [$ P. l妖城在线论坛魔力私服,最新魔力宝贝私服技术交流; O/ \6 I. m9 M+ W$ s) l' V* s! z! Y
这里基本英文大家也明白了
9 F4 O, j' f7 [& w魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
7 L: Q$ x/ i& R4 g+ I4 t魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
; |0 J! ^: j/ L+ h—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这个字段直接影响到
, t. b2 C1 j; y3 |" V5 _' _魔力私服,最新魔力宝贝私服技术交流tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
3 r3 o+ f$ D. c5 U' |1 @bbs.mocwww.com实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
- K1 G' r9 S/ w5 u- i就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
) n$ U' X; b+ o6 l0 P+ a1 [# ~bbs.mocwww.com—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート: M  l5 Q+ j  p! B% t. E- l0 r
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
- n0 T+ I- z+ N4 g魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
; N  y- S3 Z3 K: B$ a3 {妖城在线论坛* y1 V" b8 q1 Z/ y& y
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
/ J, X. s) u3 o魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表所以妖城在线论坛* K! e! T1 o3 v0 h
恢复人物的方法是。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート8 k/ k; z  u' M8 ^2 b! G. V5 |
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和妖城在线论坛5 q7 V3 N0 b; U% P$ r
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表4 H% j; U3 m! X& h( y  d
这个RegistNumber 在tbl_skill的第二个字段也一样。
2 V& C2 k5 Z. H6 I/ Gbbs.mocwww.com决定了该人物的技能
) E3 A- H+ a0 U6 A魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
, t8 l/ ~# s( Y2 S2 o( h' b—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
' t. M9 m5 `- {妖城在线论坛小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
( n8 k+ c" v& z3 B9 B5 f—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート方法如下 打开注册网站的注册页bbs.mocwww.com: {; U) y2 a# p9 }9 R+ o1 o
找到这一行SQl语句:
8 w0 m# P# ]3 U* i1 g( g! z- O妖城在线论坛魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) x% b, `# T+ _% h
$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')";
2 s! e: w  V+ d# h5 n! t; c0 _# p! [魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 |* p2 d$ q+ }- @* e- \
后字段的 '100'就是 创建人物序号魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( l! u7 i. ^# E1 D9 g. \; L
自己更改即可造成重复也不会消失的人物。妖城在线论坛# ^/ E& c2 N% j
妖城在线论坛1 m4 R& I5 i$ ~1 N
给高手们的建议:
, N. b  I) `; k+ v8 X" E魔力私服,最新魔力宝贝私服技术交流由于本人的汇编很烂(我搞C++的)妖城在线论坛7 N# T7 t1 G: ^3 Y' G* Y
所以不想研究gmsv或者cg_190的 IDA反汇编编译。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 a! S3 i& `$ X3 L4 f) E; Y  ^0 R' t
魔力私服,最新魔力宝贝私服技术交流2 K  P9 m- I' u( v, A
懂这方面的朋友可以进行以下操作:
  L4 o8 G% d+ l7 T9 K3 f0 D3 c魔力私服,最新魔力宝贝私服技术交流1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
6 b" b4 g- Y. R# s) b/ \! X; `  Cbbs.mocwww.com2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% z5 q: a7 {8 S3 S
这样的话还是允许重名,但至少不会再删除。
# z- s* I. o/ b+ Z2 `2 ]1 \+ o妖城在线论坛" H7 j+ R; b. e! A
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
& O- l2 _" e% y$ F0 h, q我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート0 h. J+ Q+ o5 R; S# @
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
* @# f/ l& }( W5 g2 ?bbs.mocwww.comREPLACE tbl_character VALUES……3 N6 R3 ^1 X3 Y$ g( \: J
查mysql手册可知
. B! B* m: d' N* J/ D; F+ h# w& _魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
2 `% ?) S; F8 y3 ^$ B* H5 W妖城在线论坛嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 f" @, ^! j& U6 J( d, E

1 E; {6 e3 @4 z不过这样不删除数据,但是还会有重名的角色存在
5 @( M, W! c0 n1 M  obbs.mocwww.com完善的解决方法可以从2方面考虑魔力私服,最新魔力宝贝私服技术交流& m6 h1 ^* J) T
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
. N* h, w4 n9 [cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber妖城在线论坛  C/ @" A! L( R7 L0 b
和Name一样 就一定会被删除

TOP

发新话题