- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试解决复杂的问题(在我看来)。
我有下一个实体:
玩家(他们中的少数人,名字如“约翰”、“彼得”等)。每个都有唯一的ID。为简单起见,我们假设这是他们的名字。
GAME(其中很少有游戏名为“捉迷藏”、“跳跃与奔跑”等)。相同 - 每个都有唯一的 ID。为简单起见,暂时使用它的名称。
SCORE(它是数字)。
那么,它是如何工作的。
每个玩家都可以玩多个游戏。他在每场比赛中都会得分。
我需要建立评分表——而不是一个!
表 #1:玩得最多的游戏表 #2:所有比赛中的最佳球员(比如每场比赛的总得分)。表 #3:每场比赛的最佳球员(特别是那场比赛的得分)。
我可以立即构建一些东西,但这行不通。我将拥有超过10,000名玩家;和 15 场比赛,这肯定会增长。分数可以低至 0,最高可达 1,000,000(目前不确定是否可能更高)。所以我真的需要一些相关数据。
有什么建议吗?
我打算用 SQL 来做,但可能只是将它用于键值存储;任何 - 欢迎任何想法。
谢谢!
最佳答案
我想说两件事。
首先我回答你的问题。其次,我认为您应该改为做什么。
<强>1。答:
SQL,容易开发测试+生产一段时间。玩家表,具有 INT 或其他一些唯一值,而不是字符串。 (我知道你说它是一个样本,但是选择应该给你足够的唯一 ID 的“长字”整数游戏也是如此。现在,要将高分保持在一起,就需要在两者之间建立关系。
分数(表关系):
[Player ID][Game_ID][Score]
其中score是一个数值...不知道你们每款游戏的最高分,所以你自己弄清楚什么类型就够了。
现在,这应该很容易开始实现。让它工作。但不要每次都直接调用数据库。
制作一个 3 层架构。创建一个数据层和一个业务层,然后是“游戏”层。所以每个游戏都使用自己的“游戏 ID”调用业务层,例如:
PlayerSaveScore(int gameID, int playerID, int score)
然后,业务层会检查“参数”的大小是否正确以及 ID 是否有效,也许会验证该玩家实际是否在过去 5 分钟内参加过 session 等。
验证后,业务层调用数据层进行“更新表”,数据层首先查看记录是否存在。如果没有,则将其插入。
分层设计一旦你“在线”(在空中)并且游戏变得流行,那么你就可以开始“升级”,但你现在仍然可以使用“ future 可扩展的解决方案”。请记住,每个游戏都必须调用业务对象/层,而不是直接调用 - 绝不!
我一直处于同样的“想太多次了”,但我一直进入一个称为准备的简单循环,但这几乎从未让我进入一个快速启动和运行的现实解决方案。
所以先获得100000名玩家吧!然后当它超出范围时开始担心。
<强>2。部分到...如何缩放...建议:
所以这就是我构建“businesslayer/webservices”的所有麻烦的原因......最重要的是,您的速度问题现在可以得到很好的解决。
您可以非常简单地实现“缓存”。
你做一个额外的 table ,如果你只有 15 场比赛,你不需要 table pr。游戏,但你决定。那只保留每场比赛的前100名。每次您发布玩家的新记录时,您都会选择这个“前 100 名”并检查发布的值是否进入列表。如果是这样,则通过更新前 100 个表来处理它,以提高速度。
将 Top 100 的摘录构建为静态数据列表,例如。 XML 或类似的静态数据。根据您的平台,您可以选择适合您的“静态格式”。
您甚至可以进一步提高速度。只保留进入每场比赛前 100 名所需的最小值。那将是一个创纪录的公关。游戏。
然后将玩家分数与游戏的“前 100 名中的最低分数”进行匹配...如果高于此值,则您需要执行一些“缓存/索引”操作,然后调用“巨型排序”:o)
明白了吗?我知道这是一个很长的答案,但我想为您提供一个“完整”的解决方案。
希望您将此标记为您的答案:o)
关于sql - noSQL/SQL/RoR : Trying to build scalable ratings table for the game,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2520791/
Xcode 4 中的以下操作有什么作用? 为测试而构建 为运行而构建 为分析而构建 为存档而构建 我不确定何时使用这些(或是否使用其中任何一个)。 最佳答案 Running 用于运行您的应用(在 Ma
工具: Jenkins 版1.470 Maven 2 颠覆 环境 假设我的构建有许多项目 A-D。如图所示,依赖关系图存在。也就是说:B 依赖于 A 中的类,C 依赖于 B 中的类,D 依赖于 A 中
我正在创建一个软件项目,我想使用 autotools 为我生成 makefile 等脚本,我手动创建了 Makefile.am 和 configure.in 文件,我正在使用 autogen.sh 脚
什么yarn build命令做什么? 是 yarn build和 npm build相同?如果不是有什么区别? 最佳答案 yarn build和 npm build默认情况下不是现有的命令。我想你是说
如果我有一个包含许多相互依赖的项目的大型代码库,例如,projects/A、projects/B 和 projects/C ,其中 A 需要 B,B 需要 C,每个项目都有一个Cake 构建脚本,例如
我正在尝试使用 Wix/Detox 来测试我的 react-native 应用程序(iOS 版本)。我已成功遵循 https://github.com/wix/detox/blob/master/do
我们有许多编译 .NET 代码的 Nant 脚本。这些构建需要 5 到 10 分钟才能运行,我想找到一种方法来加速它们。 我们的 Nant 脚本看起来像
你好 当我在 windows 下使用 gnu 构建 ffmpeg-3.4.1 时,谁能帮我解决这个错误: /tmp/9747a756ee05ef34cc3fcf51eabde826/sysroot/u
构建解决方案/项目/程序意味着什么?我想确保我的定义是正确的(所以我在交谈时听起来不像个白痴)。在 IDE 中,您可以(如果我错了,请纠正我)编译源代码/编程代码为计算机可读的机器代码。您可以调试程序
为什么 Eclipse 在构建 Android 项目时会陷入无限循环,用于构建工作区...和(重新)构建工作区...和(重新)构建工作区... 这是一个已知的错误吗? 摆脱这个循环的正确方法是什么?
我的 Angular 项目是 @Angular4.3.3 ng build -prod 构建需要 77 秒 ng build --prod --build-optimizer=true 构建需要 19
所以我刚刚使用命令创建了一个 React Native 项目 react-native init "项目名称" 我进入应用程序级别的 build.gradle 以连接 firebase,但出现错误提示
我想弄清楚 TFS Online 2017 中的两个预定义变量之间是否存在差异:$(Build.Repository.LocalPath)和 $(Build.SourcesDirectory) .我有
编译项目时,当系统用户名匹配时,此脚本应将 Xcode 项目的构建版本递增 1。请记住,这些只是 Target->Build Phases->Run Script in Xcode 中脚本(不是 Ap
是否有一种工具可以在给定 MS Build 项目文件的情况下构建一个视觉对象,显示将在何时以及从哪个导入文件执行哪个目标? 如果给定一个解决方案文件,它会构建项目构建顺序的视觉效果? 最佳答案 是的,
我正在尝试使用 Bazel 进行以下设置。通过调用“bazel build”,Python 脚本应该生成未知数量的具有随机名称的 *.cc 文件,然后将这些文件编译成单个静态库(.a 文件),所有这些
我正在将我的 Cmake 项目迁移到 Bazel。我项目的根目录是 build我用来运行 Cmake 的文件夹。 迁移到 Bazel ,我需要创建一个 BUILD我的项目根目录下的文件。但是,在 ma
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 5 年前。 此帖子已于
当我的Dockerfile如下所示时,它运行良好。 ... RUN pip install git+https://user_name:my_password@github.com/repo_name
当前的自动构建功能集是否可以从存储库中添加新标签并标记生成的图像?还是我需要3party服务将新标签自动推送到Docker Registry? 最佳答案 目前不行。 当前(2014年10月)尚无Doc
我是一名优秀的程序员,十分优秀!