美文网首页
有过期时间的积分系统表设计

有过期时间的积分系统表设计

作者: EnumaElish666 | 来源:发表于2020-04-08 09:27 被阅读0次

营销积分表设计

表结构设计

积分记录表 integral_record

此表对应的是业务操作引起的积分变化记录

字段名 类型 长度 说明
id bigint 20 主键id
type smallint 11 积分记录类型
original_id varchar 40 原始记录id
value int 11 积分值
expire_time datetime 3 过期时间
reason varchar 255 积分增减原因
user_id varchar 40 用户id
deleted tinyint 4 删除标记
create_time datetime 3 创建时间
update_time datetime 3 修改时间

可用积分表 usable_integral

此表对应的是可用的积分记录,当前积分根据此表值计算得出

字段名 类型 长度 说明
id bigint 20 主键id
record_id bigint 20 积分表中积分记录id
value int 11 积分值
expire_time datetime 3 过期时间
user_id varchar 40 用户id
deleted tinyint 4 删除标记
create_time datetime 3 创建时间
update_time datetime 3 修改时间

扣减积分详情表 reduce_integral_detail

字段名 类型 长度 说明
id bigint 20 主键id
reduce_id bigint 20 积分表中扣减积分记录id
add_id bigint 20 积分表中新增的积分记录id
used_value int 11 扣减的积分值
expire_time datetime 3 原新增的积分记录的过期时间
user_id varchar 40 用户id
deleted tinyint 4 删除标记
create_time datetime 3 创建时间
update_time datetime 3 修改时间

场景模拟

2020-04-01当天记录

某用户积分记录表如下,其他额外信息暂时忽略

积分记录表id 用户id 积分值 添加时间 过期时间 类型 备注
1 1 50 2019-04-02 2020-04-02 扫码获取 新增积分
2 1 50 2019-04-04 2020-04-04 扫码获取 新增积分
3 1 100 2019-04-04 2020-04-04 扫码获取 新增积分
4 1 -30 2020-04-01 2020-04-01 积分兑换 使用积分

可用积分表

可用积分表id 用户id record_id 可用积分值 修改时间 过期时间 deleted
1 1 1 20 2020-04-01 2020-04-02 未删除
2 1 2 50 2019-04-04 2020-04-04 未删除
3 1 3 100 2019-04-04 2020-04-04 未删除

扣减积分详情表

记录id 用户id add_id
新增积分id
reduce_id
扣减积分id
used_value
使用积分
创建时间 过期时间
1 1 1 4 30 2020-04-01 2020-04-01

2020-04-03当天记录

某用户积分记录表如下,其他额外信息暂时忽略

积分记录表id 用户id 积分值 添加时间 过期时间 类型 备注
1 1 50 2019-04-02 2020-04-02 1(扫码获取) 新增积分
2 1 50 2019-04-04 2020-04-04 1(扫码获取) 新增积分
3 1 100 2019-04-04 2020-04-04 1(扫码获取) 新增积分
4 1 -30 2020-04-01 2020-04-01 2(积分兑换) 使用积分
5 1 -20 2020-04-01 2020-04-01 3(积分过期) 积分过期

可用积分表

可用积分表id 用户id record_id 可用积分值 修改时间 过期时间 deleted
1 1 1 0 2020-04-02 2020-04-02 删除
2 1 2 50 2019-04-04 2020-04-04 未删除
3 1 3 100 2019-04-04 2020-04-04 未删除

扣减积分详情表

记录id 用户id add_id
新增积分id
reduce_id
扣减积分id
used_value
使用积分
创建时间 过期时间
1 1 1 4 30 2020-04-01 2020-04-01
2 1 1 5 20 2020-04-02 2020-04-02

2020-04-03 积分兑换80后

积分记录表id 用户id 积分值 添加时间 过期时间 类型 备注
1 1 50 2019-04-02 2020-04-02 1(扫码获取) 新增积分
2 1 50 2019-04-04 2020-04-04 1(扫码获取) 新增积分
3 1 100 2019-04-04 2020-04-04 1(扫码获取) 新增积分
4 1 -30 2020-04-01 2020-04-01 2(积分兑换) 使用积分
5 1 -20 2020-04-01 2020-04-01 3(积分过期) 积分过期
6 1 -80 2020-04-01 2020-04-01 3(积分兑换) 积分兑换

可用积分表

可用积分表id 用户id record_id 可用积分值 修改时间 过期时间 deleted
1 1 1 0 2020-04-02 2020-04-02 删除
2 1 2 0 2020-04-03 2020-04-04 删除
3 1 3 70 2020-04-03 2020-04-04 未删除

扣减积分详情表

记录id 用户id add_id
新增积分id
reduce_id
扣减积分id
used_value
使用积分
创建时间 过期时间
1 1 1 4 30 2020-04-01 2020-04-01
2 1 1 5 20 2020-04-02 2020-04-02
3 1 2 6 50 2020-04-03 2020-04-04
4 1 3 6 30 2020-04-03 2020-04-04

额外说明

  1. 积分优先扣除最早过期的且小面值的积分

  2. 每天需要定时扫码可用积分表,将过期积分删除,并在积分记录表标注好过期记录以及扣减积分详情表记录扣减值

  3. 积分总额可直接根据可用积分值计算(即使过期积分没即使删除,也可以通过计算过滤来实现)

  4. 校验等式: 扣减积分表中add_id为a的所有使用积分和 + 可用积分表中record_id为a的可用积分值 = 积分记录表id为a的积分值

    例如:扣减积分表 add_id=1的使用积分为(30 + 20) + 可用积分表record_id=1的可用积分值(0) = 积分记录表id为1的积分值50

思路参考: https://my.oschina.net/funcy/blog/1975523

相关文章

  • 有过期时间的积分系统表设计

    营销积分表设计 表结构设计 积分记录表 integral_record 此表对应的是业务操作引起的积分变化记录 ...

  • 可怜的、即将过期的积分

    今天是3月份的最后一天,积分马上要过期了,开始提醒的时候有17万多积分即将过期,每天90积分一次的积分转盘次数达到...

  • 每周阅读(8/15/2016)

    基于Event Sourcing和DSL的积分规则引擎设计实现案例对于积分系统有借鉴意义,特别是基于事件的可回退的...

  • Ifoods Chain2019年5月第二个工作双周报

    上两周,Ifoods Chain完成了检测系统后端设计、检测App流程、UI设计以及积分系统的组件。 Ifoods...

  • 快过期的积分

    前两天刷到一个视频说怎么把一、两千块的工资,过出四、五千块的日子,其中提到了要擅于利用积分,其中举例,话费积分可以...

  • 复盘积分系统的设计

    一、选题来源 时隔一年,复盘在之前做校园信息化项目的积分系统时,对积分的设计以及运营。 二、积分是个啥 早期积分,...

  • 高并发下的下单功能设计

    功能需求:设计一个秒杀系统 初始方案 商品表设计:热销商品提供给用户秒杀,有初始库存。 秒杀订单表设计:记录秒杀成...

  • 架构成长之路:高并发下的下单功能设计

    功能需求:设计一个秒杀系统 初始方案 商品表设计:热销商品提供给用户秒杀,有初始库存。 秒杀订单表设计:记录秒杀成...

  • 面试实战考核:设计一个高并发下的下单功能

    功能需求:设计一个秒杀系统 初始方案 商品表设计:热销商品提供给用户秒杀,有初始库存。 秒杀订单表设计:记录秒杀成...

  • MySQL Binlog

    过期时间 通过设置日志的过期时间,系统会自动清理过期的日志文件,默认0永不过期。 刷新日志 每次数据库服务启动时,...

网友评论

      本文标题:有过期时间的积分系统表设计

      本文链接:https://www.haomeiwen.com/subject/tjdzphtx.html