简述
项目中,有种业务需要当前表中存个另外一个表中的主键ID字段,如果用数据库自增的话,容易出现重复
比如A表主键ID自增1、2、3.。。。。,B表主键ID自增1、2、3.。。。。,A表中有个字段是B_Id,会出现a_id=3、b_id=3的情况,傻傻分不清楚这边主要分享的是一个随机生成10位永不重复的随机字符串,不啰嗦了,下面上代码
随机数生成工具类
/** * MathUtils.java * com.prereadweb.utils * Copyright (c) 2019, 北京链天下科技有限公司版权所有. */ package com.prereadweb.utils; /** * @Description: 随机数生成工具类 * @author: Yangxf * @date: 2019/4/14 12:38 */ public class MathUtils { private static final String DEFAULT_DIGITS = "0"; private static final String FIRST_DEFAULT_DIGITS = "1"; /** * @param target 目标数字 * @param length 需要补充到的位数, 补充默认数字[0], 第一位默认补充[1] * @return 补充后的结果 */ public static String makeUpNewData(String target, int length){ return makeUpNewData(target, length, DEFAULT_DIGITS); } /** * @param target 目标数字 * @param length 需要补充到的位数 * @param add 需要补充的数字, 补充默认数字[0], 第一位默认补充[1] * @return 补充后的结果 */ 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(); } /** * 生产一个随机的指定位数的字符串数字 * @param length * @return */ 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工具类
/** * IdUtils.java * com.prereadweb.utils * Copyright (c) 2019, 北京链天下科技有限公司版权所有. */ package com.prereadweb.utils; /** * @Description: 生成ID工具类 * @author: Yangxf * @date: 2019/4/14 12:40 */ public class IdUtils { /** * 以毫微秒做基础计数, 返回唯一有序增长ID * <pre>System.nanoTime()</pre> * <pre> * 线程数量: 100 * 执行次数: 1000 * 平均耗时: 222 ms * 数组长度: 100000 * Map Size: 100000 * </pre> * @return ID长度32位 */ public static String getPrimaryKey(){ return MathUtils.makeUpNewData(Thread.currentThread().hashCode()+"", 3)+ MathUtils.randomDigitNumber(7); //随机7位数 } }
效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。