获取不重复流水号(java)

一:概述

很多业务场景都需要获取不重复的业务流水号,当微服务项目或服务多节点部署时,获取流水号场景使用分布式锁性能低下,可以基于数据库行锁实现获取不重复流水号。

二:创建流水号数据库

sql 复制代码
CREATE TABLE `serial` (
  `id` varchar(32) NOT NULL COMMENT '唯一标识',
  `prefix` varchar(32) DEFAULT NULL COMMENT '流水前缀',
  `num` int(11) DEFAULT NULL COMMENT '流水序号',
  PRIMARY KEY (`id`),
  UNIQUE KEY `serial_prefix_IDX` (`prefix`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='流水号';

三:获取流水工具

3.1:创建mapper方法及对应xml文件

xml 复制代码
## mapper文件创建两个方法
/**
     * 根据前缀获取流水号
     * @param prefix
     * @return
     */
    Serial getByPrefix(@Param("prefix")String prefix);

    /**
     * 更新流水号
     * @return
     */
    Integer updSerial(@Param("id")String id,@Param("num")Integer num);
    ## 对应 xml文件方法
    <select id="getByPrefix" resultType="。。。Serial">
        select * from serial sde where prefix = #{prefix}
    </select>

    <update id="updSerial">
        update serial set num=#{num}+1 where id=#{id} and num =#{num}
    </update>

3.2:获取流水号方法

java 复制代码
@Resource
	private SerialMapper mapper;


	@Override
	public String getNum(String prefix) {
		while (true){
			Serial num = mapper.getByPrefix(prefix);
			if(num==null){
				this.insert(new Serial(prefix,1));
				return String.format("%05d",1);
			}else {
				if(mapper.updSerial(num.getId(),num.getNum())>0){
					return String.format("%05d",num.getNum()+1);
				}
			}
		}
	}
相关推荐
百锦再1 天前
[特殊字符] Python在CentOS系统执行深度指南
开发语言·python·plotly·django·centos·virtualenv·pygame
Anson Jiang1 天前
浏览器标签页管理:使用chrome.tabs API实现新建、切换、抓取内容——Chrome插件开发从入门到精通系列教程06
开发语言·前端·javascript·chrome·ecmascript·chrome devtools·chrome插件
tellmewhoisi1 天前
前置配置1:nacos 基本配置(注册与发现)
java
会开花的二叉树1 天前
继承与组合:C++面向对象的核心
java·开发语言·c++
长河1 天前
Java开发者LLM实战——LangChain4j最新版教学知识库实战
java·开发语言
Cyan_RA91 天前
SpringMVC @RequestMapping的使用演示和细节 详解
java·开发语言·后端·spring·mvc·ssm·springmvc
喵手1 天前
玩转Java网络编程:基于Socket的服务器和客户端开发!
java·服务器·网络
再见晴天*_*1 天前
SpringBoot 中单独一个类中运行main方法报错:找不到或无法加载主类
java·开发语言·intellij idea
lqjun08271 天前
Qt程序单独运行报错问题
开发语言·qt
hdsoft_huge1 天前
Java & Spring Boot常见异常全解析:原因、危害、处理与防范
java·开发语言·spring boot