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

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

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);
    }

测试一下吧

用Java实现根据数据库中的数量,生成年月份+序号递增_第1张图片

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

你可能感兴趣的:(数据库,java,jvm)