表 9.36展示了可以用于cidr
和
inet
类型的操作符。 操作符<<
、<<=
、
>>
、>>=
和
&&
测试用于子网包含。它们只考虑两个地址的网
络部分(忽略任何主机部分),然后判断其中一个网络部分是等于另外一个或者是
另外一个的子网。
表 9.36. 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' |
表 9.37展示了所有可以用于cidr
和inet
类型的函数。函数abbrev
、host
和text
主要是为了提供可选的显示格式用的。
表 9.37. cidr
和inet
函数
任何cidr
值都能够被隐式或显式地转换为inet
值, 因此上述能够操作inet
值的函数也同样能够操作cidr
值(也有独立的用于inet
和cidr
的函数,因为它的行为应当和这两种情况不同)。inet
值也可以转换为cidr
值。完成时,该网络掩码右侧的任何位都将无声地转换为零以获得一个有效的cidr
值。另外,你还可以使用常规的造型语法将一个文本字符串转换为inet
或cidr
值:例如,inet(
或expression
)
。
colname
::cidr
表 9.38展示了可以用于macaddr
类型的函数。 函数
返回一个 MAC 地址,该地址的最后三个字节设置为零。这样可以把剩下的前缀与一个制造商相关联。
trunc(
macaddr
)
表 9.38. macaddr
函数
macaddr
类型还支持标准关系操作符 (>
、<=
等) 用于编辑次序,并且按位算术操作符(~
、&
和|
)用于 NOT、AND 和 OR。
表 9.39显示了可用于macaddr8
类型的函数。
返回一个 MAC 地址,并将最后5个字节设置为零。这可以用来将剩余的前缀与制造商相关联。
trunc(
macaddr8
)
表 9.39. macaddr8
函数
macaddr8
类型也支持标准的用于排序的关系操作符
(>
、<=
等),
和用于NOT、AND和OR的按位运算符(~
、
&
和|
)。