用Java实现根据数据库中的数量,生成年月份+序号递增

发布时间:2023年12月18日

在日常开发中,经常会遇到根据年月日和第几号文件生成对应的编号,今天给大家提供一个简单的工具类

public static final Long CODE=1L;

    /**
     * @param select 数据库中数据总数
     * @return
     */
    public static String SubjectNo(Long select){
        // 在总数的基础上+1,用来标识新增数据的编号
        String code = sequenceCode(1000, select+CODE);
        Date date=new Date();
        SimpleDateFormat sf=new SimpleDateFormat("yyyy");  // 获取年份
        SimpleDateFormat sf1=new SimpleDateFormat("MM");   // 获取月份
        SimpleDateFormat sf2=new SimpleDateFormat("dd");   // 获取日期
        String year = sf.format(date);    // 取出年
        String month = sf1.format(date);  // 取出月份
        String day = sf2.format(date);    // 取出日期
        return year+month+day+"-"+code;
    }
sequenceCode方法的代码如下
/**
     * 生成001的编号
     * @param maxNum 最大数
     * @param count  累计的
     * @return
     */
    public static String sequenceCode(Integer maxNum, Long count) {  // 如生成001这种,maxNum为1000  0001的话maxNum则为10000,count则是我们从数据库中查询的总数

        String strNum = String.valueOf(maxNum + count);
        if (StringUtils.isEmpty(strNum) || 1 == strNum.length()) {
            return "";
        }
        return strNum.substring(1);
    }

测试一下吧

该示例 测试为年月日+序号递增,如果该业务要求实现按年份+序号递增 只需改一下图一代码即可

文章来源:https://blog.csdn.net/xiaoheihai666/article/details/134921406
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。