SpringBoot生成顺序规则编号-查询数据库方式实现

先说编号规则:

前缀+yyyyMMdd+5位序号(00001,00002.......)

首先说说思路:

首先是查询数据库中编号的最大值是多少**----->** 没有数据直接生成一个新的从00001开始**----->** 存在编号就直接截取编号的后5位**----->**序号+1

为了可以实现多种编号规则和涉及到多个表的数据直接使用动态SQL的方式实现

第一步:是创建动态SQL查询的方法

在Service中定义接口

java 复制代码
    /**
     * 执行本数据库查询的动态SQL
     * @param sql
     * @return
     */
    List<Map<String,Object>> executeSql(String sql);

在service的实现类中实现接口

java 复制代码
    @Override
    public List<Map<String, Object>> executeSql(String sql) {
        return dataSourceMapper.executeSql(sql);
    }

在Mapper接口中定义接口

java 复制代码
    List<Map<String, Object>> executeSql(@Param("sql") String sql);

在Mapper的xml写sql配置

java 复制代码
    <!--自定义sql -->
    <select id="executeSql" resultType="map">
        ${sql}
    </select>
第二步:创建配置类及实现的方法
java 复制代码
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
import org.apache.commons.lang3.StringUtils;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Map;

/**
 * YNK 20241127修改
 * 配置生成唯一编号
 * 生成规则:前缀+yyyyMMdd+5位序号
 */
public class CodeConfig {
    public static SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd"); // 指定日期格式
    public static String INIT_CODE = "00001";
    /**
     * 表名3编号前缀和查询最大的SQL静态变量
     */
    public static String CODE_DB = "DBAPI";
    public static String CODE_DB_SQL = "select 编号字段 as code from 表名3 where DATE_FORMAT(create_time,'%Y-%m-%d') = DATE_FORMAT(SYSDATE(),'%Y-%m-%d') order by id desc limit 1";
    /**
     * 表名2编号前缀和查询最大的SQL静态变量
     */
    public static String CODE_DATASET = "DATA";
    public static String CODE_DATASET_SQL = "select 编号字段 as code from 表名2 where DATE_FORMAT(create_time,'%Y-%m-%d') = DATE_FORMAT(SYSDATE(),'%Y-%m-%d') order by id desc limit 1";
    /**
     * 表名1编号前缀和查询最大的SQL静态变量
     */
    public static String CODE_REPORT = "REPORT";
    public static String CODE_REPORT_SQL = "select 编号字段 as code from 表名1 where DATE_FORMAT(create_time,'%Y-%m-%d') = DATE_FORMAT(SYSDATE(),'%Y-%m-%d') order by id desc limit 1";
    /**
     * 返回最大编码方法
     * @param q 编码前缀
     * @param sql 查询最大编码SQL语句
     * @return 返回编号
     */
    public static String RETURN_CODE(String q,String sql){
        //查询数据 静态方法参考上一篇文章
        List<Map<String,Object>> list = StaticService.staticDataSourceService.executeSql(sql);
        if(CollectionUtils.isNotEmpty(list)){
           //获取第一条数据
            Map<String,Object> map = list.get(0);
            String code = map.get("code").toString();
            //截取最后5位 + 1
            int i = Integer.parseInt(StringUtils.substring(code, -5) ) + 1;
            return q + sdf.format(new Date()) + String.format("%05d",i);
        }else{
            return q + sdf.format(new Date()) + INIT_CODE; // 格式化日期
        }
    }

}
第三步:调用
java 复制代码
//生成唯一编码
String code = CodeConfig.RETURN_CODE(CodeConfig.CODE_DB,CodeConfig.CODE_DB_SQL);
相关推荐
+VX:Fegn08951 分钟前
计算机毕业设计|基于springboot + vue零食商城管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
哈哈哈笑什么10 分钟前
蜜雪冰城1分钱奶茶秒杀活动下,使用分片锁替代分布式锁去做秒杀系统
redis·分布式·后端
雨中飘荡的记忆14 分钟前
Redis_实战指南
数据库·redis·缓存
WZTTMoon25 分钟前
Spring Boot 4.0 迁移核心注意点总结
java·spring boot·后端
寻kiki25 分钟前
scala 函数类?
后端
('-')30 分钟前
《从根上理解MySQL是怎样运行的》第二十五章笔记
数据库·笔记·mysql
尽兴-33 分钟前
问题记录:数据库字段 `CHAR(n)` 导致前端返回值带空格的排查与修复
前端·数据库·mysql·oracle·达梦·varchar·char
Cat God 00735 分钟前
MySQL-查漏补缺版(六:MySQL-优化)
android·数据库·mysql
疯狂的程序猴36 分钟前
iOS App 混淆的真实世界指南,从构建到成品 IPA 的安全链路重塑
后端
超龄超能程序猿43 分钟前
提升文本转SQL(Text-to-SQL)精准度的实践指南
数据库·人工智能·sql