当我们在做订单号的时候,可以发现我们使用订单号有个硬性条件,就是它最好的唯一性的,且最好是自增长。
在我们python中,系统自带了一个唯一的模块,就是uuid。但是我们使用uuid来生成订单号虽然也能使用,但是却有一个致命的缺点,就是无序。

关于UUID(univeral unique identifier)

uuid是128位的全局唯一标识符(univeral unique identifier),通常用32位的一个字符串的形式来表现。python中自带了uuid模块来进行uuid的生成和管理工作。在python中的uuid模块是基于MAC地址、时间戳、命名空间、随机数、伪随机数来生成的。

uuid.uuid1()

基于MAC地址,时间戳,随机数来生成唯一的uuid,可以保证全球范围内的唯一性。

1
2
3
4
import uuid
print(uuid.uuid1())

#b8200238-ae14-11ea-859b-68ecc5357e24
uuid.uuid2()

uuid.uuid2()算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。不过需要注意的是python中没有基于DCE的算法,所以python的uuid模块中没有uuid2这个方法。

uuid.uuid3()

通过计算一个命名空间和名字的md5散列值来给出一个uuid,所以可以保证命名空间中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。
namespace并不是一个自己手动指定的字符串或其他量,而是在uuid模块中本身给出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_OID这些值。这些值本身也是UUID对象,根据一定的规则计算得出。

1
2
3
4
5
6
7
import uuid

name = 'uuid_name'
namespace = uuid.NAMESPACE_URL
print(uuid.uuid3(namespace,name))

#5b4c833b-b8f0-36de-84d3-5ab20550d1c6
uuid.uuid4()

通过伪随机数得到uuid,是有一定概率重复的

1
2
3
4
5
import uuid

print(uuid.uuid4())

#1c0f445e-a357-4568-a9bc-25e0b4c07330
uuid.uuid5()

和uuid3基本相同,只不过采用的散列算法是sha1

1
2
3
4
5
6
7
import uuid

name = 'uuid_name'
namespace = uuid.NAMESPACE_URL
print(uuid.uuid5(namespace,name))

#87fec518-b116-571f-87e3-e40ab834ff45

评论





载入天数...载入时分秒...

Blog content follows the Attribution-NonCommercial-ShareAlike 4.0 International (CC BY-NC-SA 4.0) License

Use WZH as theme, total visits times