Writer:BYSocket(泥沙砖瓦浆木匠) 数据库
Reprint it anywhere u want 并发
项目在设计表的时候,要处理并发多的一些数据,相似订单号不能重复,要保持惟一。本来觉得来个时间戳,精确到毫秒应该不错了。后来以为是错了,测试环境下不少同样的ID,不能达到惟一标识。 app
JDK API 是这么说的:
“表示通用惟一标识符 (UUID) 的类。 UUID 表示一个 128 位的值。” dom
详细的说就是:
“UUID含义是通用惟一识别码 (Universally Unique Identifier),这 是一个软件建构的标准,也是被开源软件基金会 (Open Software Foundation, OSF) 的组织在分布式计算环境 (Distributed Computing Environment, DCE) 领域的一部份。UUID 的目的,是让分布式系统中的全部元素,都能有惟一的辨识资讯,而不须要透过中央控制端来作辨识资讯的指定。如此一来,每一个人均可以创建不与其它人冲突的 UUID。在这样的状况下,就不需考虑数据库创建时的名称重复问题。目前最普遍应用的 UUID,便是微软的 Microsoft’s Globally Unique Identifiers (GUIDs),而其余重要的应用,则有 Linux ext2/ext3 档案系统、LUKS 加密分割区、GNOME、KDE、Mac OS X 等等。” socket
UUID由如下几部分的组合: 分布式
(1)当前日期和时间,UUID的第一个部分与时间有关,若是你在生成一个UUID以后,过几秒又生成一个UUID,则第一个部分不一样,其他相同。 测试
(2)时钟序列 ui
(3)全局惟一的IEEE机器识别号,若是有网卡,从网卡MAC地址得到,没有网卡以其余方式得到。 加密
很方便的,直接调用UUID的randomUUID方法,便可得到UUID对象,而后就获取了这个惟一标识码。 spa
1
2
3
4
5
|
public static void main(String[] args)
{
UUID uuid = UUID.randomUUID();
System.out.println(uuid);
}
|
RUN一下,能够从控制台发现:
1
|
<fontsize="4"> 65752c66-bd3f-4564-b8d6-92d66796e007</font>
|
这就是惟一标志码。但显得冗长,不够友好。若是在URL后面作参数,更加不够友好。还有存储一个UUID要花费更多的空间。获取的时间倒没必要考虑太多。
仿着网上大牛代码,直接上代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<fontsize="4">public static String[] chars = new String[]
{
"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z",
"0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
"A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V","W", "X", "Y", "Z"
};
public static String getShortUuid()
{
StringBuffer stringBuffer = new StringBuffer();
String uuid = UUID.randomUUID().toString().replace("-", "");
for (int i = 0; i <
8; i++)
{
String
str =
uuid.substring(i * 4, i * 4 + 4);
int
strInteger = Integer.parseInt(str, 16);
stringBuffer.append(chars[strInteger % 0x3E]);
}
return stringBuffer.toString();
} </font>
|
用300个测试下,没问题。足够用了,能适应环境场景便可。
Writer:BYSocket(泥沙砖瓦浆木匠)
Reprint it anywhere u want