Java: 生成自定义格式自增流水号

 Service

/**
 * 生成个数为size的流水号数组
 *    format: XXX20240124001 ...
 */
public String[] generateSerialNum(Integer size) {
    // 初始化一个定长为size的数组
    String[] nums = new String[size];
    // 初始值均为空串
    Arrays.fill(nums, "");
    // 定义流水号标准前缀
    String prefix = "XXX" + new SimpleDateFormat("yyyyMMdd").format(new Date());
    // 模糊查询当前库中的最新的流水号
    String newestNum = mapper.getNewestNum(prefix);
    // 定义起始序号
    int startNum = !StringUtils.hasText(newestNum) ? 1 : Integer.parseInt(newestNum .substring(prefix.length() - 1)) + 1;
    // 定义序号格式: 三位数
    DecimalFormat df = new DecimalFormat("000");
    // 循环处理
    int index = 1;
    // 如果序号超限, 此处不作额外处理. 上层需根据元素是否为初始的空串"" 作相应处理 (此处限制为三位数)
    while (index <= size && startNum <= 999) {
        nums[index] = prefix + df.format(startNum);
        index++;
        startNum++;
    }
    return nums;
}

Mapper.xml

<select id="getNewestNum">
    select max(xxx_num)
    from table_name
    where xxx_num like concat(#{prefix}, '%')
</select>

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值