简述
项目中,有种业务需要当前表中存个另外一个表中的主键ID字段,如果用数据库自增的话,容易出现重复
比如A表主键ID自增1、2、3.。。。。,B表主键ID自增1、2、3.。。。。,A表中有个字段是B_Id,会出现a_id=3、b_id=3的情况,傻傻分不清楚这边主要分享的是一个随机生成10位永不重复的随机字符串,不啰嗦了,下面上代码
随机数生成工具类
package com.prereadweb.utils;
public class MathUtils {
private static final String DEFAULT_DIGITS = "0";
private static final String FIRST_DEFAULT_DIGITS = "1";
public static String makeUpNewData(String target, int length){
return makeUpNewData(target, length, DEFAULT_DIGITS);
}
public static String makeUpNewData(String target, int length, String add){
if(target.startsWith("-")) target.replace("-", "");
if(target.length() >= length) return target.substring(0, length);
StringBuffer sb = new StringBuffer(FIRST_DEFAULT_DIGITS);
for (int i = 0; i < length - (1 + target.length()); i++) {
sb.append(add);
}
return sb.append(target).toString();
}
public static String randomDigitNumber(int length){
int start = Integer.parseInt(makeUpNewData("", length));//1000+8999=9999
int end = Integer.parseInt(makeUpNewData("", length + 1)) - start;//9000
return (int)(Math.random() * end) + start + "";
}
}
生成ID工具类
package com.prereadweb.utils;
public class IdUtils {
public static String getPrimaryKey(){
return MathUtils.makeUpNewData(Thread.currentThread().hashCode()+"", 3)+ MathUtils.randomDigitNumber(7); //随机7位数
}
}
效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。



