UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写,是一种软件建构的标准,亦为开放软件基金会组织在分布式计算环境领域的一部分。其目的,是让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。如此一来,每个人都可以创建不与其它人冲突的UUID。在这样的情况下,就不需考虑数据库创建时的名称重复问题。
UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的API。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和随机数。
UUID由以下几部分的组合:
(1)UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。
(2)时钟序列。
(3)全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。
9de7bb31d0644e7393039222babfed10
在数据库表字段设计中,不可避免要使用UUID。本篇介绍MySQL使用UUID的注意事项等等。 欢迎关注收藏备用。
UUID做主键时需要注意的两个坑
通常推荐使用自增bigint类型作为主键,如果在 InnoDB 中使用 UUID 作为主键需要考虑两个问题:
- UUID 的返回值通常是随机的,而 InnoDB 的表实质是以主键组织存储的索引,插入新的记录会造成表的再平衡
- 主键包含在每个二级索引中,过长的主键会浪费磁盘和内存的空间