支持的版本:当前 (17) / 16 / 15 / 14 / 13
开发版本:devel
不支持的版本:12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2 / 7.1

8.9. 网络地址类型 #

PostgreSQL 提供了存储 IPv4、IPv6 和 MAC 地址的数据类型,如表 8.21所示。最好使用这些类型而不是纯文本类型来存储网络地址,因为这些类型提供了输入错误检查以及专门的操作符和函数(请参见第 9.12 节)。

表 8.21. 网络地址类型

名称 存储大小 描述
cidr 7 或 19 字节 IPv4 和 IPv6 网络
inet 7 或 19 字节 IPv4 和 IPv6 主机和网络
macaddr 6 字节 MAC 地址
macaddr8 8 字节 MAC 地址(EUI-64 格式)

当对 inetcidr 数据类型进行排序时,IPv4 地址将始终在 IPv6 地址之前排序,包括封装或映射到 IPv6 地址的 IPv4 地址,例如 ::10.2.3.4 或 ::ffff:10.4.3.2。

8.9.1. inet #

inet 类型保存 IPv4 或 IPv6 主机地址,以及可选的子网,全部在一个字段中。子网由主机地址中存在的网络地址位数表示(即网络掩码)。如果网络掩码为 32 并且地址为 IPv4,则该值不表示子网,仅表示单个主机。在 IPv6 中,地址长度为 128 位,因此 128 位指定一个唯一的主机地址。请注意,如果要仅接受网络,则应使用 cidr 类型而不是 inet

此类型的输入格式为 address/y,其中 address 是 IPv4 或 IPv6 地址,y 是网络掩码中的位数。如果省略 /y 部分,则 IPv4 的网络掩码为 32,IPv6 的网络掩码为 128,因此该值仅表示单个主机。在显示时,如果网络掩码指定单个主机,则会抑制 /y 部分。

8.9.2. cidr #

cidr 类型保存 IPv4 或 IPv6 网络规范。输入和输出格式遵循无类别域间路由约定。指定网络的格式为 address/y,其中 address 是网络的最低地址,表示为 IPv4 或 IPv6 地址,y 是网络掩码中的位数。如果省略 y,则使用旧的分类网络编号系统中的假设进行计算,但它至少要足够大才能包含输入中编写的所有八位字节。指定网络地址时,在指定的网络掩码右侧设置了位的地址是错误的。

表 8.22 显示了一些示例。

表 8.22. cidr 类型输入示例

cidr 输入 cidr 输出 abbrev(cidr)
192.168.100.128/25 192.168.100.128/25 192.168.100.128/25
192.168/24 192.168.0.0/24 192.168.0/24
192.168/25 192.168.0.0/25 192.168.0.0/25
192.168.1 192.168.1.0/24 192.168.1/24
192.168 192.168.0.0/24 192.168.0/24
128.1 128.1.0.0/16 128.1/16
128 128.0.0.0/16 128.0/16
128.1.2 128.1.2.0/24 128.1.2/24
10.1.2 10.1.2.0/24 10.1.2/24
10.1 10.1.0.0/16 10.1/16
10 10.0.0.0/8 10/8
10.1.2.3/32 10.1.2.3/32 10.1.2.3/32
2001:4f8:3:ba::/64 2001:4f8:3:ba::/64 2001:4f8:3:ba/64
2001:4f8:3:ba:​2e0:81ff:fe22:d1f1/128 2001:4f8:3:ba:​2e0:81ff:fe22:d1f1/128 2001:4f8:3:ba:​2e0:81ff:fe22:d1f1/128
::ffff:1.2.3.0/120 ::ffff:1.2.3.0/120 ::ffff:1.2.3/120
::ffff:1.2.3.0/128 ::ffff:1.2.3.0/128 ::ffff:1.2.3.0/128

8.9.3. inet vs. cidr #

inetcidr 数据类型之间的本质区别在于,inet 接受网络掩码右侧具有非零位的值,而 cidr 则不接受。例如,192.168.0.1/24 对于 inet 有效,但对于 cidr 无效。

提示

如果您不喜欢 inetcidr 值的输出格式,请尝试函数 hosttextabbrev

8.9.4. macaddr #

macaddr 类型存储 MAC 地址,例如从以太网卡硬件地址(尽管 MAC 地址也用于其他目的)中得知。接受以下格式的输入

'08:00:2b:01:02:03'
'08-00-2b-01-02-03'
'08002b:010203'
'08002b-010203'
'0800.2b01.0203'
'0800-2b01-0203'
'08002b010203'

这些示例都指定了相同的地址。对于数字 af,接受大写和小写形式。输出始终采用所示的第一种形式。

IEEE 标准 802-2001 指定所示的第二种形式(带有连字符)作为 MAC 地址的规范形式,并指定第一种形式(带有冒号)用于位反转的、MSB-first 表示法,因此 08-00-2b-01-02-03 = 10:00:D4:80:40:C0。如今,这种约定被广泛忽略,它仅与过时的网络协议(如令牌环)相关。PostgreSQL 不提供位反转;所有接受的格式都使用规范的 LSB 顺序。

其余五种输入格式不属于任何标准。

8.9.5. macaddr8 #

macaddr8 类型以 EUI-64 格式存储 MAC 地址,例如从以太网卡硬件地址(尽管 MAC 地址也用于其他目的)中得知。此类型可以接受 6 字节和 8 字节长度的 MAC 地址,并将它们存储为 8 字节长度的格式。以 6 字节格式给出的 MAC 地址将以 8 字节长度格式存储,其中第 4 个和第 5 个字节分别设置为 FF 和 FE。请注意,IPv6 使用修改后的 EUI-64 格式,其中从 EUI-48 转换后,第 7 位应设置为 1。提供了函数 macaddr8_set7bit 来进行此更改。一般来说,接受任何由成对的十六进制数字(在字节边界上)组成的输入,可以选择一致地由 ':''-''.' 中的一个分隔。十六进制数字的数量必须为 16(8 字节)或 12(6 字节)。忽略前导和尾随空格。以下是接受的输入格式示例

'08:00:2b:01:02:03:04:05'
'08-00-2b-01-02-03-04-05'
'08002b:0102030405'
'08002b-0102030405'
'0800.2b01.0203.0405'
'0800-2b01-0203-0405'
'08002b01:02030405'
'08002b0102030405'

这些示例都指定了相同的地址。对于数字 af,接受大写和小写形式。输出始终采用所示的第一种形式。

上面显示的最后六种输入格式不属于任何标准。

要将 EUI-48 格式的传统 48 位 MAC 地址转换为修改后的 EUI-64 格式以作为 IPv6 地址的主机部分包含,请使用 macaddr8_set7bit,如下所示

SELECT macaddr8_set7bit('08:00:2b:01:02:03');

    macaddr8_set7bit
-------------------------
 0a:00:2b:ff:fe:01:02:03
(1 row)

提交更正

如果您在文档中看到任何不正确、与特定功能的使用体验不符或需要进一步澄清的内容,请使用此表单报告文档问题。