Context
Web 应用程序、PHP 5、MySQL 5.0.91
问题
我最近从使用自动递增整数改为使用 UUID 作为某些表的主键。通过 MySQL 生成 UUID 时UUID()功能,它们彼此非常相似:
| uuid |
----------------------------------------
| 1e5988da-afec-11e1-9877-5464f7aa6d24 |
| 408092aa-afad-11e1-9877-5464f7aa6d24 |
^------^ ^^
1 8 11-12
可以看到,只有前8个字符以及第11个和第12个字符不同。据我了解,UUID 版本 1 使用时间戳和硬件 MAC 地址来生成 UUID。然而,由于这些相似之处(以及在我的情况下 MAC 地址永远不会改变的事实),我对使用版本 1 犹豫不决。此外,如果 MAC 地址永远不会改变,则大部分 UUID 都是无用的并且浪费空间。
我的自定义 UUID 函数
作为实验,我用 PHP 编写了一个自定义 UUID 生成器:
public static function GenerateUUID()
{
return
substr(sha1(Account::GetUsername() . Account::GetUserID()), 18, 8) . "-" .
substr(md5(time()), rand() % 28, 4) . "-" .
substr(md5(date("Y")), rand() % 28, 4) . "-" .
substr(sha1(rand()), 20, 4) . "-" .
substr(sha1(rand() % PHP_INT_MAX), 17, 12);
}
结果示例:
| uuid |
----------------------------------------
| 574d18c2-5080-bac9-5597-45435f363ea1 |
| 574d18c2-30d4-8b5b-4ffd-001744d3d287 |
此处,对于同一用户,前 8 个字符是相同的。这是有意的,但不是必需的。
问题
是否有首选/推荐的方法来生成版本 4 或版本 5 UUID在 MySQL 查询中?
如果不是,是否可以在 PHP 中生成不符合规范的自定义 UUID(如上所述)?
限制
- 我正在使用具有命令行访问权限的共享托管计划,但无法修改现有的 MySQL 安装。
- 我宁愿避免第三方包/库。
Notes
- 我现在不会也不会执行合并、同步或其他需要包含 MAC 地址的 GUID 的操作。这不是这里的问题。