发新话题
打印

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

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

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート* l2 K6 k" B; O* G- V( i4 Y
bbs.mocwww.com- Q# I8 p' ]$ @5 U! M
相信现在很多人的数据库都会出现重名角色被替换的情况。
( ^7 X' R* A; y( G0 Z2 i3 l6 qbbs.mocwww.com这种情况实际上是由数据库中的几个字段造成的,—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート4 H8 s* s" [8 l& \! q
首先我们来分析一下数据库表3 T% R0 w6 h- e  B% p" C6 t
bbs.mocwww.com" Y2 y: i/ ~9 P# k# s0 A
tbl_user 这个 是存放角色登入账号的。其中包括:
" P1 C$ V7 l1 ]$ Y; I) i+ pbbs.mocwww.comAccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
: [; J7 c0 C& @/ D0 g. w魔力私服,最新魔力宝贝私服技术交流妖城在线论坛  f% X6 ^6 `$ b2 G
这里基本英文大家也明白了 —魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート; I9 |3 y& O) c5 [) ?
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
2 u: S. }9 Y5 P/ l/ j+ {2 L! ^SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
7 x  c6 R. Y9 H# A妖城在线论坛这个字段直接影响到
( H) N' N7 K$ O) v+ B8 s魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
3 Y0 l# ?7 J( Z$ H4 }& O—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
! M& y- T" ~, f/ y" X妖城在线论坛就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式bbs.mocwww.com3 W3 O! t$ j8 T2 T

2 K. |4 O1 J; s5 F; @bbs.mocwww.com即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
; B, E2 ~7 u$ @+ J6 B+ a! n) |/ K$ {  l, M0 T  @

* q& I% V$ z1 B5 B( h# i—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートtbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
. C/ Z: K3 J& N; s+ C魔力私服,最新魔力宝贝私服技术交流所以—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート* [) ~; v/ _$ Q* l  ^
恢复人物的方法是。
: }" \7 L5 \6 x& g& F' X0 z妖城在线论坛在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
7 g+ h* H% a  p/ s妖城在线论坛tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
2 t9 m) }8 N) \: _8 M这个RegistNumber 在tbl_skill的第二个字段也一样。
; u3 k$ N' `+ b/ F" X—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート决定了该人物的技能 魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表; [" C0 r$ c$ E( l. V2 |: s
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~妖城在线论坛1 W- s$ S* Q. p; ]0 H1 X

2 P- H/ v; @; k5 _' t" g/ B—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
& _. e' W" N! v+ c. Y—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート方法如下 打开注册网站的注册页
: h, e( ~# Y6 N$ t魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表找到这一行SQl语句:妖城在线论坛; L' ^+ x3 e% K2 Q. C& y
妖城在线论坛2 K/ Q2 A1 C! e
$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')";妖城在线论坛9 V* |7 s( x5 L+ E2 q  {6 ], y

0 O1 [: o3 Y) w- M8 Q% N# f" [魔力私服,最新魔力宝贝私服技术交流后字段的 '100'就是 创建人物序号魔力私服,最新魔力宝贝私服技术交流6 M; H1 t1 w4 O" C8 T) s& R
自己更改即可造成重复也不会消失的人物。
; O$ ?+ r( Y  W5 T* \8 @3 s, c% a妖城在线论坛魔力私服,最新魔力宝贝私服技术交流. W4 H) x+ Z: \9 ~8 W3 z0 g
给高手们的建议:
: I2 T* S& `+ F6 h3 z妖城在线论坛由于本人的汇编很烂(我搞C++的)
& a/ w4 k" t+ X" y8 m' J魔力私服,最新魔力宝贝私服技术交流所以不想研究gmsv或者cg_190的 IDA反汇编编译。妖城在线论坛3 m0 z$ z0 U$ K6 x' D7 L

! e) M+ V- I3 `& \! C0 {/ O魔力私服,最新魔力宝贝私服技术交流懂这方面的朋友可以进行以下操作:- R( z/ A$ Y+ n* H. p' M* c4 ?
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。妖城在线论坛( K- r: c) i) d) `7 ~
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
) x, I& P  o* C+ e这样的话还是允许重名,但至少不会再删除。  w; w8 o3 d4 G- Y

! F2 s- U$ ]. v7 Dbbs.mocwww.comPS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
, [% S4 n* c2 ~$ `9 u魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的妖城在线论坛: l, ]5 V$ b& E+ B. n9 V
希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为魔力私服,最新魔力宝贝私服技术交流( }9 W5 o1 i6 Q) q/ ]8 L5 I2 m
REPLACE tbl_character VALUES……
& @' Q) p# _. B! {0 q3 @—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート查mysql手册可知3 d/ m4 A8 \. V
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
* `# r. q5 t9 o* F: x: O' M妖城在线论坛嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……
" ?2 _- W% D! M, C2 Jbbs.mocwww.com魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表; O- [1 H& j5 {: o! N
不过这样不删除数据,但是还会有重名的角色存在
( ~$ Q% U: E% v—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート完善的解决方法可以从2方面考虑魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表: D, m' {2 i& U3 @
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
$ K1 o* s- }) S. Y妖城在线论坛cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

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

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
7 D( D4 x0 G8 Y& j魔力私服,最新魔力宝贝私服技术交流和Name一样 就一定会被删除

TOP

发新话题