发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
( a8 G& H2 }7 d
7 M# W& D& ^" p, A- A* ~' ]9 A4 K相信现在很多人的数据库都会出现重名角色被替换的情况。
1 p& m* M1 d1 w) P' U- z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这种情况实际上是由数据库中的几个字段造成的,
. g3 |' P" d, N, T! |! k# y魔力私服,最新魔力宝贝私服技术交流首先我们来分析一下数据库表
2 ]( }9 R. d8 b4 d* E妖城在线论坛
/ P% |, T6 V% Obbs.mocwww.comtbl_user 这个 是存放角色登入账号的。其中包括:妖城在线论坛9 R  f4 h& _/ p* k/ Y  J
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore魔力私服,最新魔力宝贝私服技术交流; o# c2 z2 L7 g; b( m

9 {, q! v" k: A% Y& J魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这里基本英文大家也明白了
; M. ]& e- W8 o—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートEnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是魔力私服,最新魔力宝贝私服技术交流( p% G- k: d9 n8 B* k3 O& f  X
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
. J# O5 U* Q* x5 _# B2 x0 R: }$ Y  l* Tbbs.mocwww.com这个字段直接影响到—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート% h- Z" c' p) m4 q8 u  x. Y3 T: c
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート1 a. \" _0 Y& W" u5 ?& @' P
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
9 j% ~& ^: E4 q% ebbs.mocwww.com就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  X# z- ?7 l  s

' h5 a' G- @+ e- I: o" y4 Pbbs.mocwww.com即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
' S+ p9 L, f/ Z) q. e/ _9 _2 U+ F—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
7 F5 ~- ~$ t# f—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表& q. z% c; D3 r1 ]6 l
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
9 h' |; D% C8 _& F, U2 r' C7 f& U魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表所以
/ i2 F9 ?7 \3 {/ J* i恢复人物的方法是。妖城在线论坛; W8 {0 }& {. Y0 ?0 H, `+ e
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和bbs.mocwww.com2 V- H; w/ B5 c% X! ~
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
, W; c' z4 m- F这个RegistNumber 在tbl_skill的第二个字段也一样。
+ M) I- m- D% M7 T4 e& l决定了该人物的技能
  ], Y+ j. Y* @0 L: H% B* S+ _' p7 K& M那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~妖城在线论坛4 `4 R% g1 h* s

; Q' j$ `" l2 A3 ~4 N2 Z妖城在线论坛小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了妖城在线论坛/ v- L) S6 K" B: ]. S6 W: O9 p5 m; D
方法如下 打开注册网站的注册页
3 x5 U4 l6 N5 u; E; k魔力私服,最新魔力宝贝私服技术交流找到这一行SQl语句:
8 p$ {0 q# Y% w; @妖城在线论坛魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ R7 l; d- n0 Y5 ^
$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')";
  p- x3 f6 O3 y' D7 w5 b- l魔力私服,最新魔力宝贝私服技术交流
; u2 c8 D* H* R2 @8 m* A: \& cbbs.mocwww.com后字段的 '100'就是 创建人物序号- `! }% R% w" P. B, D  v6 m9 K2 y( b
自己更改即可造成重复也不会消失的人物。妖城在线论坛, j. p- |2 P6 R
bbs.mocwww.com8 ?) Q: j6 U! F6 h4 R5 h0 d
给高手们的建议:
& j6 e$ w* N& X9 ?) T( h5 G& Q- [& r7 x—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート由于本人的汇编很烂(我搞C++的)
3 v7 Y' Z' ~0 r; i9 M  E魔力私服,最新魔力宝贝私服技术交流所以不想研究gmsv或者cg_190的 IDA反汇编编译。
7 g6 |+ v# L7 [5 b# a
" W2 ?- N& _) ]9 R; g魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表懂这方面的朋友可以进行以下操作:
  O2 X& b# z! ?7 s1 h1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
1 B4 @& W0 y. ?0 J2 g—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
$ L+ g1 t( ^$ _0 U5 `魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表这样的话还是允许重名,但至少不会再删除。
4 \' k: A- X6 b! p魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表魔力私服,最新魔力宝贝私服技术交流! {; L0 P4 G% h6 x9 l+ |0 Q
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
* a6 z) T( g+ I2 |" X  U9 g妖城在线论坛我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
4 o" _! C1 S! ~1 ]bbs.mocwww.com希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为妖城在线论坛# h: d3 \% i& V) u0 T! M
REPLACE tbl_character VALUES……bbs.mocwww.com5 K7 n3 U  Q0 o2 o6 \* k/ w8 O
查mysql手册可知—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 |  y4 e' B( J9 v
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。bbs.mocwww.com2 c( ^. a; K- i
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……魔力私服,最新魔力宝贝私服技术交流0 K& u" J/ q: c) m8 r! N

3 @* l4 X* u$ s. L# i: a! j魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表不过这样不删除数据,但是还会有重名的角色存在3 v$ b7 [' b' _  _# y
完善的解决方法可以从2方面考虑魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表: s. _; @9 t) ?) E9 N) b6 t
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
4 u5 h8 w1 n; V! {# u6 s3 v妖城在线论坛cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber妖城在线论坛2 P0 s$ S# U. G: O5 u( P
和Name一样 就一定会被删除

TOP

发新话题