获取不重复流水号(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);
				}
			}
		}
	}
相关推荐
计算机安禾9 分钟前
【数据结构与算法】第10篇:项目实战:学生信息管理系统(线性表版)
开发语言·数据结构·算法·visual studio
MyBFuture17 分钟前
Halcon模板匹配核心技术解析大全
开发语言·人工智能·计算机视觉·halcon·机器视觉
毕设源码-朱学姐22 分钟前
【开题答辩全过程】以 基于SSM的宜佳家具电商平台为例,包含答辩的问题和答案
java
精神小伙就是猛23 分钟前
使用go-zero快速搭建一个微服务(一)
开发语言·后端·微服务·golang
不会聊天真君64725 分钟前
基础语法·下(golang笔记第三期)
开发语言·笔记·golang
客卿12330 分钟前
最小生成树(贪心)--构造回文串(字符串 + 回文判断 + 构造)
java·开发语言·算法
Bert.Cai30 分钟前
Python input函数作用
开发语言·python
88号技师35 分钟前
2026年3月中科院一区SCI-赏金猎人优化算法Bounty Hunter Optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
天启HTTP42 分钟前
多线程环境下,动态IP怎么分配最合理
java·服务器·网络
weixin_4643076342 分钟前
QT宏、属性系统
开发语言·qt