转:棋牌游戏服务器架构: 详细设计(三) 数据库设计

主要有3类Database: ServerInfoDB,UserInfoDB和GameDB。 ServerInfoDB主要存储的是游戏列表的信息,UserInfoDB存储玩家的全局信息,而GameDB就是积分以及积分变化情况。下面分别加以描述。

1. ServerInfoDB

      ServerInfoDB主要存储游戏列表信息。主要有以下几个表:

      1. GameTypeInfo,其主要字段为:

          TypeID:类型标识 ID

          TypeName:类型名字,例如棋牌类,休闲类

          Enable:控制游戏大厅是否显示该类型,默认为 1,即为默认显示

      2. GameKindInfo,其主要字段为:

          KindID: 游戏的唯一标识

          TypeID: 外键(GameTypeInfo的主键),该游戏所属类型

          KindName: 游戏名称, 比如德州扑克,斗地主等。

          ProcessName: 客户端进程名称

          MaxVersion: 客户端进程的最低版本,若是登录时发现客户端版本低于这个值,要求其更新。

          Enable: 控制游戏大厅是否显示该游戏,默认为1。

      3. GameStationInfo 站点信息表:

          StationID:  站点标识

          StationName: 站点名称

          Enable: 这个站点是玩家可以选择的,这个标识控制是否显示给玩家,默认为1

2 UserInfoDB

      这个数据库主要存储玩家的全局信息,有两个表: UserAccounts和ClubList:

      1. UserAccounts的主要字段:

          UserID:玩家的唯一标识,注册的时候自动生成,不能修改

          Accounts:帐户名字,具有唯一性,不能重复,能修改

          LogonPass:玩家帐户的密码,采用通用加密算法 MD5 加密记录

          Gender:性别

          LogonNullity:帐户禁止标志,影响玩家登录广场和登录游戏房间

          ServiceNullity:服务禁止标志,保留供网站系统使用或者将来系统扩展使用

          UserRight:玩家权限标志,每一位代表一种权限, 比如旁观权限,大厅公聊权限,私聊权限等。

          ManageRight:管理权限标志,第一位代表一种管理权限,比如踢出玩家,发布消息等。

          FaceID:玩家头像索引号码

          ClubID:外键(ClubList的主键),玩家社团 ID 号码

          MemberOrder:会员等级标识

          Experience:玩家经验数值,表示玩家游戏的总局数,可以通过修改每个游戏的经验数值增加方案得到策略的改变

          AllLogonTimes:玩家成功登陆的总次数

          RegisterDate:玩家的注册日期

          LastLogonDate:玩家最后登陆的日期

          RegisterIP:玩家帐户的注册所在的 IP 地址

          LastLogonIP:玩家最后使用此帐户登陆的 IP 地址

          Question:密码找回提示问题

          Answer:密码找回回答问题

          QQ:玩家注册QQ号码

          ConnectPerson:联系人姓名

          PhoneNO:电话号码

          Address:家庭住址

          Email:电子邮箱

      2. ClubList是用来存储社团列表的,主要字段包括:

          ClubID:社团的唯一标识号码,注册的时候自动生成,不能修改

          ClubName:社团名字

          ClubQQ:与社团对应的QQ群号码

          ClubAdmin:社团管理员(外键)

          ClubNotice:社团公告,预留字段

3 GameDB

      这个DB主要存储玩家的游戏相关信息,例如游戏积分,胜局,和局,逃局,登陆时间等信息。

      1. GameScore

          UserID:玩家标识号码

          Score:玩家的积分数值

          WinCount:游戏胜利局数

          LostCount:游戏输局局数

          DrawCount: 游戏和局局数

          FleeCount: 游戏逃跑局数

          UserRight:玩家在此游戏中的普通权限数值,在登陆房间的时候与玩家房间权限进行或操作

          ManageRight:玩家在此游戏中的管理权限数值,在登陆房间的时候与玩家房间权限进行或操作

          PlayTimeCount:玩家在此类游戏中的游戏时间

          AllLogonTimes:玩家进入此类游戏的总次数

          RegisterDate:玩家首次进入此类游戏的时间

          LastLogonDate:玩家最后一次进入此类游戏的时间

          RegisterIP:玩家首次进入此类游戏的 IP 地址

          LastLogonIP:玩家最后一次进入此类游戏的IP 地址

      2. GameLogonLog:

          ID:Log的索引ID,自增长。

          UserID:外键,玩家 ID 号码

          Score:玩家进入房间时刻的积分数值

          WinCount:玩家进入房间时刻的游戏胜利局数

          LostCount:玩家进入房间时刻的游戏输局局数

          DrawCount:玩家进入房间时刻的游戏和局局数

          FleeCount:玩家进入房间时刻的游戏逃跑局数

          KindID:玩家进入的房间的类型标识号码

          ServerID:玩家进入房间的房间标识号码

          ClientIP:玩家进入房间的连接IP地址

          LogonTime:玩家进入房间的时间

      3. GameScorelog:

          ID:LogID,自增长

          UserID:外键,玩家 ID 号码

          LeftTime:玩家离开房间的时间

          Score:玩家在游戏房间游戏所产生的积分改变的数值

          WinCount:玩家在游戏房间游戏所产生的胜利局数改变的数值

          LostCount:玩家在游戏房间游戏所产生的输局局数改变的数值

          DrawCount:玩家在游戏房间游戏所产生的和局局数改变的数值

          FleeCount:玩家在游戏房间游戏所产生的逃跑局数改变的数值

          Experience:玩家在游戏房间游戏所产生的经验数值改变的数值

          PlayTimeCount:玩家在游戏房间游戏所产生的游戏时间的数值

          OnLineTimeCount:玩家在游戏房间游戏所产生的在线时间的数值

          KindID:玩家进入的房间的类型标识号码

          ServerID:玩家进入房间的房间标识号码

          ClientIP:玩家进入房间的连接IP地址

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容