大继的基础级业务实战设计记录(三),充值

一,目的

提供一个扩展比较好的,积分充值设计路,每个字段都经过多种场景进行考虑。由于文笔不好,以下以代码形式展示设计思路.

兼容多种业务场景

现金、银行、支付宝,微信支付等...

二,依赖模块

积分:https://www.jianshu.com/p/e0748147c6c6 [可以参考我之前写的 ,不过写得差,大继的基础级业务实战设计记录(一),积分],
银行,alipay,wechat

三,实战代码

1.现金请求

Cent beforeCent = centsRest.findTypeAndTypeId("WALLET","0");
        if(beforeCent == null){
            beforeCent.setNumber(0.0);
        }

        //正经一点需要一个  cash 模块。简化可用,只需要随机给个UUID
        CentChargeRequest centChargeRequest = new CentChargeRequest();
        centChargeRequest.setChargeNumber(100.0);
        centChargeRequest.setFromType("cash");
        centChargeRequest.setFromTypeId(UUID.randomUUID().toString());
        centChargeRequest.setFromTypeIdName("test source");
        centChargeRequest.setFromTradeNo(UUID.randomUUID().toString());
        centChargeRequest.setSummary("充值测试");
        centChargeRequest.setFromUserId(0L);
        centChargeRequest.setCentType("WALLET");
        centChargeRequest.setCentTypeId("0");
        centChargeRequest.setFromResultCode("0");
        centChargeRequest.setCentUserId(0L);
        centsChargeRest.charge(centChargeRequest);

        Cent afterCent = centsRest.findTypeAndTypeId("WALLET","0");
        Assert.assertEquals(new Double(afterCent.getNumber() - 100.0),beforeCent.getNumber());

2.银行请求(注:此实现需要在业务级模块组合,不要让cent模块直接依赖bank模块)

Cent beforeCent = centsRest.findTypeAndTypeId("WALLET","0");
        if(beforeCent == null){
            beforeCent.setNumber(0.0);
        }

        /**
         * 依赖bank 模块
         */
        Bank bank = new Bank();
        bank.setId(UUID.randomUUID().toString());
        bank.setCreateTime(new Date());
        bank.setEnable(true);
        bank.setEnName("ICBC");
        bank.setImage("image");
        bank.setName("中国工商银行");
        bank.setUpdateTime(new Date());
        bank = banksRest.save(bank);

        BankCard bankCard = new BankCard();
        bankCard.setBankId(bank.getId());
        bankCard.setBranchId(null);
        bankCard.setBranchName("广州石牌支行");
        bankCard.setCreateTime(new Date());
        bankCard.setEnable(true);
        bankCard.setId(UUID.randomUUID().toString());
        bankCard.setMobile("+08615818733***");
        bankCard.setRealName("大继");
        bankCard.setType("储蓄卡");
        bankCard.setNo("6222023602030330***");
        bankCard.setUpdateTime(new Date());
        bankCard.setUserId(0L);

        bankCard = banksCardRest.save(bankCard);



        //正经一点需要一个  cash 模块。简化可用,只需要随机给个UUID
        CentChargeRequest centChargeRequest = new CentChargeRequest();
        centChargeRequest.setChargeNumber(100.0);
        centChargeRequest.setFromType("bankcard");
        centChargeRequest.setFromTypeId(bankCard.getId());
        centChargeRequest.setFromTypeIdName(bankCard.getRealName());
        centChargeRequest.setFromTradeNo(UUID.randomUUID().toString());
        //需要加入对bank name描述
        centChargeRequest.setSummary("充值测试");
        centChargeRequest.setFromUserId(0L);
        centChargeRequest.setCentType("WALLET");
        centChargeRequest.setCentTypeId("0");
        centChargeRequest.setCentUserId(0L);
        centChargeRequest.setFromResultCode("0");
        centsChargeRest.charge(centChargeRequest);

        Cent afterCent = centsRest.findTypeAndTypeId("WALLET","0");
        Assert.assertEquals(new Double(afterCent.getNumber() - 100.0),beforeCent.getNumber());

3.其它可按上两个例子进行扩展

4.充值实体,及积分变更记录

  • 改进了,之前设计过的积分设计
/**
 * 积分充值
 */
@Entity
@Table(name = "cent_charge_log",
        indexes = {@Index(columnList = "fromType,fromTradeNo",unique = true)})
public class CentChargeLog {
    @Id
    @Column(length = 37)
    private String id;
    /**
     * 充值的积分账号
     */
    @Column(length = 37)
    private String centId;
    /**
     * 充值的积分类型
     */
    @Column(length = 32)
    private String centType;
    /**
     * 充值的积分类型ID
     */
    @Column(length = 37)
    private String centTypeId;
    @Column
    private Long centUserId;
    /**
     * 充值数量
     */
    @Column
    private Double number;
    /**
     * 充值来源,可以是微信,支付宝,银行等第三方,或本系统现金
     */
    @Column(length = 64)
    private String fromType;
    /**
     * 充值来源ID ,微信支付有openId,现金使用管理员ID,银行使用银行卡号
     */
    @Column
    private String fromTypeId;
    /**
     * 充值来源ID名称
     */
    @Column
    private String fromTypeIdName;
    /**
     * 充值来源交易号
     * 需要事务保证唯一
     */
    @Column(length = 64)
    private String fromTradeNo;
    /**
     * 来源交易结果
     */
    @Column
    private String fromResultCode;
    /**
     * 所属于用户,需要对集合描述为空并用own进行描述
     */
    @Column
    private Long fromUserId;
    /**
     * 状态
     */
    @Column(length = 16)
    private String status;
    /**
     * 更新时间
     */
    @Column
    private Date updateTime;
    /**
     * 创建时间
     */
    @Column
    private Date createTime;
    ...
}
/**
 * 单体积分变更记录。
 * 所有积分账变化都需要记录到这个表。
 * 满足可查性需求.
 * 如A转账B,这里会产生两个记录。
 */
@Entity
@Table(name = "cent_changed_log",
        indexes = {@Index(columnList = "centId"),@Index(columnList = "fromType,fromTypeId")})
public class CentChangedLog {
    @Id
    @Column(length = 37)
    private String id;
    /**
     * 用设计简化,积分账号直接光联查询.
     */
    @Column(length = 37)
    private String centId;
    /**
     * 变更主体
     * 用设计简化,直接使用积分类别查询.
     */
    @Column(length = 37)
    private String centType;
    /**
     * 变更主体
     * 用设计简化,直接使用积分类别查询.
     */
    @Column
    private String centTypeId;
    /**
     * 变更描述
     */
    @Column
    private String summary;
    /**
     * 改变数量
     * 变更点数 正数,或负数来表达加或减.
     */
    @Column
    private Double changedNumber;
    /**
     * 手续费
     */
    @Column
    private Double changedFee;
    /**
     * 原交易数
     * 在需要手续费的情况下这个,原交易数来记录,支付全额
     * 例如: 100 -> b   扣掉2元手费, 在changeNumber里会写 98, 这个original则保留原始的数据。便于查询.
     */
    @Column
    private Double changedOriginalNumber;
    /**
     * 变更后最终余额
     */
    @Column
    private Double changedLeftNumber;
    /**
     * 变更类型,
     * 如果是转账积分号,充值等记录类型来源
     */
    @Column(length = 32)
    private String fromType;
    /**
     * 如果是充值就是充值 ID
     */
    @Column(length = 37)
    private String fromTypeId;
    @Column
    private String fromTypeIdName;
    @Column
    private Long fromUserId;
    @Column
    private Long userId;
    /**
     * 为以后特殊情况保留,正常都是 SUCCESS
     */
    @Column
    private String status;
    @Column
    private Date updateTime;
    @Column
    private Date createTime;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,657评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,889评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,057评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,509评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,562评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,443评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,251评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,129评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,561评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,779评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,902评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,621评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,220评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,838评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,971评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,025评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,843评论 2 354

推荐阅读更多精彩内容