下表展示了可以用于cidr
和?inet
类型的操作符。 操作符<<
、<<=
、?>>
、>>=
和?&&
测试用于子网包含。它们只考虑两个地址的网 络部分(忽略任何主机部分),然后判断其中一个网络部分是等于另外一个或者是 另外一个的子网。
cidr
和?inet
类型的操作符操作符 | 描述 | 例子 |
---|---|---|
< | 小于 | inet '192.168.1.5' < inet '192.168.1.6' |
<= | 小于等于 | inet '192.168.1.5' <= inet '192.168.1.5' |
= | 等于 | inet '192.168.1.5' = inet '192.168.1.5' |
>= | 大于等于 | inet '192.168.1.5' >= inet '192.168.1.5' |
> | 大于 | inet '192.168.1.5' > inet '192.168.1.4' |
<> | 不等于 | inet '192.168.1.5' <> inet '192.168.1.4' |
<< | 被包含在内 | inet '192.168.1.5' << inet '192.168.1/24' |
<<= | 被包含在内或等于 | inet '192.168.1/24' <<= inet '192.168.1/24' |
>> | 包含 | inet '192.168.1/24' >> inet '192.168.1.5' |
>>= | 包含或等于 | inet '192.168.1/24' >>= inet '192.168.1/24' |
&& | 包含或者被包含contains or is contained by | inet '192.168.1/24' && inet '192.168.1.80/28' |
~ | 按位 NOT | ~ inet '192.168.1.6' |
& | 按位 AND | inet '192.168.1.6' & inet '0.0.0.255' |
| | 按位 OR | inet '192.168.1.6' | inet '0.0.0.255' |
+ | 加 | inet '192.168.1.6' + 25 |
- | 减 | inet '192.168.1.43' - 36 |
- | 减 | inet '192.168.1.43' - inet '192.168.1.19' |
?下表展示了所有可以用于cidr
和inet
类型的函数。函数abbrev
、host
和text
主要是为了提供可选的显示格式用的。
cidr
和inet
函数函数 | 返回类型 | 描述 | 例子 | 结果 |
---|---|---|---|---|
abbrev(inet) | text | 缩写显示格式文本 | abbrev(inet '10.1.0.0/16') | 10.1.0.0/16 |
abbrev(cidr) | text | 缩写显示格式文本 | abbrev(cidr '10.1.0.0/16') | 10.1/16 |
broadcast(inet) | inet | 网络广播地址 | broadcast('192.168.1.5/24') | 192.168.1.255/24 |
family(inet) | int | 抽取地址族;4为 IPv4, 6为 IPv6 | family('::1') | 6 |
host(inet) | text | 抽取 IP 地址为文本 | host('192.168.1.5/24') | 192.168.1.5 |
hostmask(inet) | inet | 为网络构造主机掩码 | hostmask('192.168.23.20/30') | 0.0.0.3 |
masklen(inet) | int | 抽取网络掩码长度 | masklen('192.168.1.5/24') | 24 |
netmask(inet) | inet | 为网络构造网络掩码 | netmask('192.168.1.5/24') | 255.255.255.0 |
network(inet) | cidr | 抽取地址的网络部分 | network('192.168.1.5/24') | 192.168.1.0/24 |
set_masklen(inet, int) | inet | 为inet值设置网络掩码长度 | set_masklen('192.168.1.5/24', 16) | 192.168.1.5/16 |
set_masklen(cidr, int) | cidr | 为cidr值设置网络掩码长度 | set_masklen('192.168.1.0/24'::cidr, 16) | 192.168.0.0/16 |
text(inet) | text | 抽取 IP 地址和网络掩码长度为文本 | text(inet '192.168.1.5') | 192.168.1.5/32 |
inet_same_family(inet, inet) | boolean | 地址是来自于同一个家族吗? | inet_same_family('192.168.1.5/24', '::1') | FALSE |
inet_merge(inet, inet) | cidr | 包括给定网络的最小网络 | inet_merge('192.168.1.5/24', '192.168.2.5/24') | 192.168.0.0/22 |
?任何cidr
值都能够被隐式或显式地转换为inet
值, 因此上述能够操作inet
值的函数也同样能够操作cidr
值(也有独立的用于inet
和cidr
的函数,因为它的行为应当和这两种情况不同)。inet
值也可以转换为cidr
值。完成时,该网络掩码右侧的任何位都将无声地转换为零以获得一个有效的cidr
值。另外,你还可以使用常规的造型语法将一个文本字符串转换为inet
或cidr
值:例如,inet(
或expression
)
。colname
::cidr
下表展示了可以用于macaddr
类型的函数。 函数
返回一个 MAC 地址,该地址的最后三个字节设置为零。这样可以把剩下的前缀与一个制造商相关联。trunc(
macaddr
)
macaddr
函数函数 | 返回类型 | 描述 | 例子 | 结果 |
---|---|---|---|---|
trunc(macaddr) | macaddr | 设置最后3个字节为零 | trunc(macaddr '12:34:56:78:90:ab') | 12:34:56:00:00:00 |
?macaddr
类型还支持标准关系操作符 (>
、<=
等) 用于编辑次序,并且按位算术操作符(~
、&
和|
)用于 NOT、AND 和 OR。
下表中展示了可以用于macaddr8
类型的函数。函数
返回一个后五个字节设置为零的MAC地址。这可以被用来为一个制造商关联一个前缀。trunc(
macaddr8
)
macaddr8
函数函数 | 返回类型 | 描述 | 例子 | 结果 |
---|---|---|---|---|
trunc(macaddr8) | macaddr8 | 设置最后五个字节为零 | trunc(macaddr8 '12:34:56:78:90:ab:cd:ef') | 12:34:56:00:00:00:00:00 |
macaddr8_set7bit(macaddr8) | macaddr8 | 设置第7位为一,也被称为修改版的EUI-64,用于内含在IPv6地址中 | macaddr8_set7bit(macaddr8 '00:34:56:ab:cd:ef') | 02:34:56:ff:fe:ab:cd:ef |
?macaddr8
类型也支持用于排序的标准关系操作符(>
、<=
等)以及用于NOT、AND和OR的位运算操作符(~
、&
和|
)。