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中的"-"