JAVA根据0~9、A~Z生成流水码
最近项目中要生成7位流水码+前缀字母,以前系统用的自增长,最近自增长的长度已经不太够用了,再用段时间估计就得归0了,所以现在想着来修改一下生成规则,借鉴了一下CSDN上面大佬的代码,然后稍微修改了一下,更符合我的使用规则 ,原文参考:JAVA流水号生成规则,5位字符串,生成上千万uuid,使用0-9,A-Z36位来计算,按默认规则递增
直接上代码
@GetMapping("/insertNo")
public ApiResponseResult<String> insertNo(@Param("code") String code){
//String code="0000A";
//遍历1万条数据查看规则是否正确
String listcode="";String currcode=code;
for (int i = 0; i < 10000; i++) {
currcode=sn(7, 9999999, currcode);
if (currcode.contains("位数"))
break;;
listcode+=currcode+",\n";
}
return new ApiResponseResult<>(ApiResultCode.SUCCESS,listcode);
}
/**
*
* @param len 位数
* @param i 若位数为5,则输入99999,若位数为3,则输入999,
* @param driver 生成id的前一位 0000A
* @return
*/
public static String sn(int len,Integer i,String driver){
//首先判断位数是否超出
if (len>=driver.length()){
String dr = "";
AtomicInteger z = new AtomicInteger(i);
z.getAndIncrement();
if(z.toString().length()>(len-(driver!=null?driver.length():0))){
dr = driverCheck(driver,len);
if(dr.equals(".N")){//如超出限定长度并字母都为Z的时候,限定长度加1,dr重新开始,默认为空
len++;
dr = "";
}else{
z.set(1);
}
}else{
dr = driver;
}
if(dr.length()==len){
System.out.println(dr);
return dr;
}else{
System.out.println(String.format("%0"+(len-(dr.length()))+"d",0)+dr);
return String.format("%0"+(len-(dr.length()))+"d",0)+dr;
}
}else {
return "位数超出";
}
}
/**
* 字母有效检查
* 1.检查字母是否都为Z
* 2.检查字母长度
* @param driver
* @param len
* @return
*/
public static String driverCheck(String driver,int len){
char[] charArray = driver.toCharArray();
AtomicInteger z = new AtomicInteger(0);
for (char c : charArray) {
if(c=='Z'){
z.getAndIncrement();
}
}
if(z.intValue()==driver.length() && z.intValue()==len){//如所有字母都为Z,并且长度达到限定长度,返回.N
return ".N";
}else if(z.intValue()==driver.length() && z.intValue()<len){//如果所有字母都为Z,但长度未达到限定长度,则在调用字母递增方法之前加入@用以递增A
return driver("@"+driver);
}else{//以上两个条件都不满足,则直接递增
return driver(driver);
}
}
/**
* 字母递增
* @param driver
* @return
*/
public static String driver(String driver){
if(driver!=null && driver.length()>0){
char[] charArray = driver.toCharArray();
AtomicInteger z = new AtomicInteger(1);
for(int i = charArray.length-1;i>-1;i--){
if(charArray[i]=='Z'){
//最后一位A-Z
if (i==charArray.length-1) {//判断是否是最后一位
charArray[i]='0';
z.set(z.incrementAndGet());
} else if (z.intValue() > 0) {
//有前进位,其他位转为0
charArray[i] = '0';
}
}else if(charArray[i]=='9'){
//如果有前进位,9进1,变A
if (z.intValue()>0) {
charArray[i] = 'A';
z.set(0);
}
}
else{
if(z.intValue()>0 || i==charArray.length-1){
AtomicInteger atomic = new AtomicInteger(charArray[i]);
charArray[i]=(char) atomic.incrementAndGet();
z.set(0);
}
}
}
return String.valueOf(charArray);
}else{
return "A";
}
}