如何在我的网站上设计奖励系统

时间:2011-02-22 11:14:49

标签: database-design badge reward-system

我想尝试在我正在建设的新网站上设计一个奖励系统。例如(仅用于说明目的):

enter image description here enter image description here enter image description here

堆栈溢出的medals system是另一个例子。

我的问题是,您可以轻松地将每个徽章的描述和名称存储在数据库表中。

**tbl_Badges**
ID  |  Badge Name  |  canHaveMultiple   |  hasProgress  |  progressScale
----------------------------------------------------------------------------
1     Copy Editor     Yes                    No                null
2     The Mob         Yes                    No                null
3     Jquery          No                     Yes               100

然后将用户与这些徽章关联起来:

**tbl_UsersBadges**
ID  |  Badge ID  | User ID
---------------------------
1      1            5
2      1            5
3      2            5
4      2            12

(也许还有另一个通过比例徽章等来存储用户进度)

但困难在于编制奖励这些徽章的触发器。

这样的系统是否在网站上使用硬编码触发器构建?由于这些徽章的广泛性和灵活性,这是我能想到的唯一方法。但是,如果将触发器硬编码为徽章ID,则在更改任何内容时必须非常小心。

这样的系统是如何工作的呢?这违背了我所学到的。或者我是否错误地解决了这个问题?

2 个答案:

答案 0 :(得分:3)

首先,您需要确保清楚地列出“奖励”用户操作。然后,您必须创建一些代码,这些代码将在其中一个操作发生时触发。有多种方法可以查看解决方案:

  1. 保存可能导致数据库奖励的每个操作。然后,数据库中的实际触发器将根据这些操作属性授予标记,或者crontab作业可能会执行此操作。好处是,如果您更改奖励系统计算,您可以重播用户操作以获得新的奖励;
  2. 编写一些在调用任何其他方法之前自动调用的hub方法。根据操作,您可以随后授予奖励,然后重定向到真实方法;
  3. 使用您提到的硬编码操作,但这很乏味且容易出错;

答案 1 :(得分:1)

我只是从软件中抛出事件,甚至异步地从后端帮助程序中捕获它们,后端帮助程序将添加徽章,计划通知等。您可以使用消息传递系统(AMQP或类似的)来处理来自后端帮助程序的这些事件。