Postgres 提供用于存储 IP 和 MAC 地址的数据类型. 用这些数据类型比用纯文本类型好,因为这些类型提供输入错误检查 和好些种特殊的操作和功能.
名字 | 存储 | 描述 | 范围 |
---|---|---|---|
cidr | 12 字节 | IP 网络 | 有效的IPv4网络 |
inet | 12 字节 | IP 网络和主机 | 有效的IPv4主机 |
macaddr | 6 字节 | MAC 地址 | 客户化格式 |
还不支持 Ip v6.
inet保存一个主机 IP 地址, 以及一个可选的它所处的等效的子网. 子网是用地址的网络地址部分的二进制位的数量来表示的( “网络掩码”). 如果网络掩码是 32,那么不表示任何子网,只是一台主机. 请注意如果你想只接受网络地址,你应该使用 cidr 类型而不是 inet.
该类型的输入格式是 x.x.x.x/y 这里 x.x.x.x 是 是互联网主机,y 是网络掩码的位数. 如果 /y 部分未填, 则网络掩码是 /32,表示只有一台主机. 显示时,如果 /y 部分是 /32,将不会显示出来.
cidr 保存一个 IP 网络地址声明. 其输入和输出遵循无类的互联网域路由 (Classless Internet Domain Routing)习惯. 声明一个无类(classless)的网络的格式是 x.x.x.x/y 这里 x.x.x.x 是 网络地址而 /y 是 网络掩码的二进制位数. 如果省略 /y, 那么掩码部分用旧的有类的网络分类假设进行计 算,但要求输入的数据已经包括了确定掩码的所需的所有8进制位.
下面是些例子:
Table 3-18. 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 |
inet 和 cidr 类型之间的基本区别是 inet 接受右边有非零位的网络掩码, 而 cidr 不接受.
技巧: 如果你不喜欢 inet 或 cidr 值的输出 格式,请试一下 host() 和 text() 函数.
macaddr 类型存储 MAC 地址,也就是以太网卡硬件地址 (尽管 MAC 地址还用于其它用途).可以接受多种客户化的格式, 包括 '08002b:010203','08002b-010203', '0800.2b01.0203','08-00-2b-01-02-03', 和'08:00:2b:01:02:03',它们都声明的是同一个地址. 对于数据位 a 到 f,大小写都行. 输出总是我们上面给出的最后一种形式.
在 Postgres 源代码发布的 contrib/mac 目录里有一些可以将 MAC 地址映射为硬件制造商的名字的工具.