平均分配订单方案

场景介绍

类似京东的售后有一个对应的跟进客服,我想在下单的时候就直接指定这个订单的跟进人,目前是均分策略,后续可能会按照其他方式分发。

方案一mysql+sort

利用mysql,建立一张中间表,关联用户idsort字段,当用户被分配订单时sort字段 = max(id) + 1.选取用户时则取min(sort)对应的用户,此流程可以让订单被均分到每个用户身上,但是比较重。

方案二redis+list

redis中维护一个list,里面存放了所有的用户,分配订单的时候从中出栈一个用户,当list中用户全部为空时,从db中再将用户列表拉入redislist中。此方案较灵活。list中的用户可以按照自定义规则进行排序,让某些用户优先分到订单。

代码demo如下

public String getNextUserId(){

    String userId = stringRedisTemplate.opsForList().leftPop(averageDispatchAppointmentkey);

    if(StringUtils.isBlank(userId)){
        UserParamDTO param = new UserParamDTO();
        //客户运营专员
        param.setRoleId(26L);
        //list中空了,再拉一批用户列表过来
        ClientResult<List<UserDTO>> feignResult = saAuthFeign.findUsersByRoleId(param);

        log.info("客户运营专员列表 feignResult:{}", feignResult);
        if(Objects.equals(feignResult.getCode(), ErrorCodeEnum.SUCCESS.getCode()) && Objects.nonNull(feignResult.getData())){
            List<UserDTO> data = feignResult.getData();
            stringRedisTemplate.opsForList().leftPushAll(
                    averageDispatchAppointmentkey,
                    data.stream().map(it -> it.getId().toString()).collect(Collectors.toList())
            );

            return stringRedisTemplate.opsForList().leftPop(averageDispatchAppointmentkey);
        }else {
            log.error("请求客户运营专员列表失败------failed\n");
        }
    }

    return userId;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值