uuid-ossp模块提供一些函数,可使用几种标准算法之一生成通用唯一标识符(UUID)。 它还提供一些函数,用于生成某些特殊的 UUID 常量。 只有在需要核心PostgreSQL未提供的特殊功能时,才需要此模块。 关于生成 UUID 的内置方式,见Section 9.14。
该模块被认为是“受信任的”,也就是说,它可以由在当前数据库上具有 CREATE权限的非超级用户安装。
uuid-ossp 函数 #Table F.33展示了可用于生成 UUID 的函数。 相关标准 ITU-T Rec. X.667、ISO/IEC 9834-8:2005 以及 RFC 4122 规定了四种生成 UUID 的算法,分别由版本号 1、3、4 和 5 标识。 (没有版本 2 算法。)这些算法中的每一种都可能适用于不同的一类应用。
Table F.33. 用于生成 UUID 的函数
|
函数 描述 |
|---|
|
生成一个版本 1 UUID。这会用到计算机的 MAC 地址和时间戳。 注意,这类 UUID 会暴露创建该标识符的计算机身份以及创建时间, 因而可能不适合某些对安全较为敏感的应用。 |
|
生成一个版本 1 UUID,但会使用随机的组播 MAC 地址, 而不是计算机的真实 MAC 地址。 |
|
使用指定的输入名称,在给定的名字空间中生成一个版本 3 UUID。 该名字空间应当是由 例如: SELECT uuid_generate_v3(uuid_ns_url(), 'http://www.postgresql.org'); 名称参数会先做 MD5 哈希,因此无法从生成的 UUID 中反推出明文内容。 通过这种方法生成 UUID 不包含随机因素,也不依赖于环境,因此结果可重现。 |
|
生成一个版本 4 UUID,它完全来源于随机数。 |
|
生成一个版本 5 UUID,它的工作方式与版本 3 UUID 类似, 只是使用 SHA-1 作为哈希方法。由于 SHA-1 被认为比 MD5 更安全, 因此通常应优先使用版本 5 而不是版本 3。 |
Table F.34. 返回 UUID 常量的函数
|
函数 描述 |
|---|
|
返回一个“nil” UUID 常量,它不会作为真正的 UUID 出现。 |
|
返回一个表示 UUID 的 DNS 名字空间的常量。 |
|
返回一个表示 UUID 的 URL 名字空间的常量。 |
|
返回一个表示 UUID 的 ISO 对象标识符(OID)名字空间的常量。 (这里指的是 ASN.1 OID,与PostgreSQL中使用的 OID 无关。) |
|
返回一个表示 UUID 的 X.500 可分辨名称(DN)名字空间的常量。 |
uuid-ossp #历史上,此模块依赖 OSSP UUID 库,这也是该模块名称的由来。 虽然在 http://www.ossp.org/pkg/lib/uuid/ 仍然可以找到 OSSP UUID 库, 但它维护得并不好,而且移植到较新的平台上正变得越来越困难。 如今,在某些平台上,uuid-ossp已可在不依赖 OSSP 库的情况下构建。 在 FreeBSD 和其他一些 BSD 派生平台上,合适的 UUID 生成功能包含在核心 libc库中。在 Linux、macOS 和其他一些平台上, 相应功能由libuuid库提供,该库最初来自 e2fsprogs项目(不过在现代 Linux 上,它被视为 util-linux-ng的一部分)。 调用configure时,可指定 --with-uuid=bsd以使用 BSD 函数, 或指定--with-uuid=e2fs以使用 e2fsprogs 的libuuid, 或指定--with-uuid=ossp以使用 OSSP UUID 库。 某台机器上可能同时具备多个这样的库,因此configure不会自动选择其一。
Peter Eisentraut <peter_e@gmx.net>
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。