主要有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地址

转载于:https://www.cnblogs.com/li_shugan/archive/2012/09/16/2687155.html

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

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

    主要有3类Database: ServerInfoDB,UserInfoDB和GameDB. ServerInfoDB主要存储的是游戏列表的信息,UserInfoDB存储玩家的全局信息,而GameDB ...

  2. 棋牌游戏服务器架构: 详细设计(3) 数据库设计

    2019独角兽企业重金招聘Python工程师标准>>> 主要有3类Database: ServerInfoDB,UserInfoDB和GameDB. ServerInfoDB主要存储 ...

  3. 棋牌游戏服务器架构: 详细设计(二) 应用层设计

    这里的应用层,指的是CenterServer.LogonServer.LogServer.RoomServer等几个服务器,另外还包括游戏模块的设计.不过游戏模块和前4个服务器的设计很不相同.这里先说 ...

  4. 棋牌游戏服务器架构: 详细设计(一) 内核设计

    内核的几个组件被设计成Service,也就是说这几个模块都要实现如下接口: 图1  IService接口 Start方法用来启动服务. Stop 方法用来关闭服务. IsService 方法用于查询当 ...

  5. 棋牌游戏服务器架构: 总体设计

    首先要说明的是, 这个棋牌游戏的服务器架构参考了网狐棋牌的架构.网狐棋牌最令人印象深刻的是其稳定性和高网络负载.它的一份压力测试报告上指出:一台双核r的INTEL Xeon 2.8CPU加上2G内存和 ...

  6. 网络棋牌游戏服务器架构

    一.物理架构说明 游戏系统组件包括: 服务器系统(中心服务器的控制系统,服务器登陆控制的系统,游戏登陆服务器,游戏房间控制的系统,游戏组件系统),游戏客户端(游戏大厅,游戏组件). 数据库系统:用于保 ...

  7. 棋牌游戏服务器架构: 部署

    先看一下,下面这张可能的部署图吧. 图1  系统布署图 在这个图中,可以看到,客户端的形式多种多样,可能是pc上的一个可执行文件,也可能是通过浏览器打开的一个网页,甚至于手机客户端.它们都通过inte ...

  8. 如何设计大型游戏服务器架构?

    一.游戏服务器特征 游戏服务器,是一个会长期运行程序,并且它还要服务于多个不定时,不定点的网络请求.所以这类服务的特点是要特别关注稳定性和性能.这类程序如果需要多个协作来提高承载能力,则还要关注部署和 ...

  9. 高性能游戏服务器架构设计,一种高性能大型多人在线角色扮演游戏服务器架构设计.doc...

    一种高性能大型多人在线角色扮演游戏服务器架构设计 一种高性能大型多人在线角色扮演游戏服务器架构设计摘要:大型多人在线角色扮演游戏(Massively Multiplayer Online Role P ...

最新文章

  1. JVM基本架构及生命周期
  2. linux temp文件夹在哪_Win10系统下使用linux命令的方法
  3. 青龙羊毛——狸猫十堰
  4. java学习笔记之折半查找法(二分法)
  5. 【UNIX网络编程(二)】基本TCP套接字编程函数
  6. Spring集成MyBatis框架
  7. 透过现象看本质,如何设计一款病毒式裂变产品?
  8. 本地计算机绑定域名访问
  9. webpack打包vue2.0项目时必现问题
  10. Java动态代理之JDK实现和CGlib实现
  11. Delphi Sockets.pas单元中TIpSocket的Bug
  12. 手撸反向传播算法(附代码)
  13. Android Design 1: Back键和Up键在App导航中的表现
  14. APICS与AX的Master Planning(一)--Phantom bill of Material 虚项
  15. 4.文件读取操作_read函数
  16. 移远 M26 GSM模组(2G通信模组)AT指令测试 TCP 通信过程
  17. 新手网管的升级之路 一
  18. 上汽赛可携手几维安全 赋能移动出行安全新业态
  19. 回收站里的文件都清空了应该怎么恢复?
  20. d610网络计算机,尼康D610评测:机身细节

热门文章

  1. 整数返回poj1005——I Think I Need a Houseboat
  2. [读书笔记]TCP/IP详解V1读书笔记-4 5
  3. 在自定义HttpHandler中如何使用Session
  4. java date加一天_Java日期时间API系列15-----Jdk8中API类,java日期计算2,年月日时分秒的加减等...
  5. LeetCode--single-number复杂度
  6. fopen php 乱码,如何解决php fgets读取文件乱码的问题
  7. 四川高职计算机二本线学校,全网首发!四川省本科二批次2019年对口高职投档录取线出炉...
  8. 手机 服务器 推送消息推送消息,推送信息到手机的pushover使用方法及sample code
  9. mysql中逗号前的字符串_MySql逗号拼接字符串查询的两种方法
  10. flow 静态类型检查 js