java uuid

 1.UUID 的目的,是让分布式系统中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。如此一来,每个人都可以建立不与其它人冲突的 UUID。

2.用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字

UUID由以下几部分的组合:
(1)当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。
(2)时钟序列。
(3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。

UUID的唯一缺陷在于生成的结果串会比较长。

UUID 来作为数据库数据表主键是非常不错的选择,保证每次生成的UUID 是唯一的。

a.生成 UUID
需要用到java 自带 JDk;

复制代码
import java.util.UUID;
public static void main(String[] args) {
for(int i=0;i<10;i++){
String uuid = UUID.randomUUID().toString().replaceAll("-", "");
System.out.println(uuid);
}
}





b.生成指定数目的 UUID

复制代码
/** 
* 获得指定数目的UUID 
* @param number int 需要获得的UUID数量 
* @return String[] UUID数组 
*/ 
public static String[] getUUID(int number){ 
if(number < 1){ 
return null; 
} 
String[] retArray = new String[number]; 
for(int i=0;i<number;i++){ 
retArray[i] = getUUID(); 
} 
return retArray; 
}

/** 
* 获得一个UUID 
* @return String UUID 
*/ 
public static String getUUID(){ 
String uuid = UUID.randomUUID().toString(); 
//去掉“-”符号 
return uuid.replaceAll("-", "");
}




为啥用uuid而不用自增长方式呢?

首先为什么要用uuid控制主键呢?

相比较自动增长的int类型的主键有什么好处?

当数据量多、登录用户量多、遇到高并发的时候,自增长不利于维护,也不利于拓展,而且也有可能出现几个人同时插入自增长的同一个id 比如自增长到了100,ABC三个用户同时插入的时候会不会出现同时插入101?或者覆盖101数据呢?这就是弊端。

为啥用uuid而不用自增长方式呢?

首先为什么要用uuid控制主键呢?

相比较自动增长的int类型的主键有什么好处?

当数据量多、登录用户量多、遇到高并发的时候,自增长不利于维护,也不利于拓展,而且也有可能出现几个人同时插入自增长的同一个id 比如自增长到了100,ABC三个用户同时插入的时候会不会出现同时插入101?或者覆盖101数据呢?这就是弊端。

uuid是string,不是int数值

uuid是string,不是int数值,

uuid是string,不是int数值,

uuid是string,不是int数值,

uuid = uuid.replace("-", "");               //因为UUID本身为32位只是生成时多了“-”,所以将它们去点就可  

uuid = uuid.replace("-", "");               //因为UUID本身为32位只是生成时多了“-”,所以将它们去点就可  

uuid = uuid.replace("-", "");               //因为UUID本身为32位只是生成时多了“-”,所以将它们去点就可  

输出结果:

1 fd61384b-05a5-4030-885e-a6bd3b60ef1a

下面是去除UUID中的"-"

输出结果:

1 fd61384b-05a5-4030-885e-a6bd3b60ef1a

下面是去除UUID中的"-"

输出结果:

1 fd61384b-05a5-4030-885e-a6bd3b60ef1a

下面是去除UUID中的"-"

原文地址:https://www.cnblogs.com/panxuejun/p/7715871.html