On this page
9.12. 网络地址功能和运算符
Table 9.36显示可用于cidr
和inet
类型的运算符。运算符<<
,<<=
,>>
,>>=
和&&
测试子网包含。他们只考虑两个地址的网络部分(忽略任何主机部分),并确定一个网络与另一个网络相同还是一个子网。
表 9.36. cidr
和inet
运算符
Operator | Description | Example |
---|---|---|
< |
小于 | inet '192.168.1.5' < inet '192.168.1.6' |
<= |
小于或等于 | inet '192.168.1.5' <= inet '192.168.1.5' |
= |
equals | 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' |
>> |
contains | inet '192.168.1/24' >> inet '192.168.1.5' |
>>= |
包含或等于 | inet '192.168.1/24' >>= inet '192.168.1/24' |
&& |
包含或包含于 | inet '192.168.1/24' && inet '192.168.1.80/28' |
~ |
bitwise NOT | ~ inet '192.168.1.6' |
& |
bitwise AND | inet '192.168.1.6' & inet '0.0.0.255' |
| |
bitwise OR | inet '192.168.1.6' | inet '0.0.0.255' |
+ |
addition | inet '192.168.1.6' + 25 |
- |
subtraction | inet '192.168.1.43' - 36 |
- |
subtraction | inet '192.168.1.43' - inet '192.168.1.19' |
Table 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
。
Table 9.38显示可用于macaddr
类型的功能。函数trunc(macaddr)
返回最后 3 个字节设置为零的 MAC 地址。这可用于将剩余的前缀与制造商关联。
表 9.38. macaddr
功能
Function | Return Type | Description | Example | Result |
---|---|---|---|---|
trunc(macaddr) |
macaddr |
将最后 3 个字节设置为零 | trunc(macaddr '12:34:56:78:90:ab') |
12:34:56:00:00:00 |
macaddr
类型还支持字典 Sequences 的标准关系运算符(>
,<=
等),以及 NOT,AND 和 OR 的按位算术运算符(~
,&
和|
)。
Table 9.39显示可用于macaddr8
类型的功能。函数trunc(macaddr8)
返回最后 5 个字节设置为零的 MAC 地址。这可用于将剩余的前缀与制造商关联。
表 9.39. macaddr8
功能
macaddr8
类型还支持用于排序的标准关系运算符(>
,<=
等),以及用于 NOT,AND 和 OR 的按位算术运算符(~
,&
和|
)。