9.3 9.4 9.5 9.6 10 11 12 13 14 15
阿里云PostgreSQL 问题报告 纠错本页面

9.12. 网络地址函数和操作符

表 9-34显示了可以用于cidrinet的操作符。操作符<<, <<=, >>, >>=&&用于测试子网包含: 它们只考虑两个地址的网络部分,忽略任何主机部分, 然后判断其中一个网络是等于另外一个还是另外一个的子网。

表 9-34. cidrinet 操作符

操作符描述例子
< 小于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'
&& 包含或包含于inet '192.168.1/24' && inet '192.168.1.80/28'
~ 位非~ inet '192.168.1.6'
& 位与inet '192.168.1.6' & inet '0.0.0.255'
| 位或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-35显示了所有可以用于cidrinet的函数。函数abbrev, host, text主要是为了提供可选的显示格式用的。

表 9-35. cidrinet 函数

函数返回类型描述例子结果
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 为 IPv6family('::1')6
host(inet) text将主机地址类型抽出为文本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) inetinet数值设置子网掩码长度set_masklen('192.168.1.5/24', 16)192.168.1.5/16
set_masklen(cidr, int)cidrcidr数值设置子网掩码长度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

任何cidr值都能够被隐含或明确的转换为inet值, 因此上述能够操作inet值的函数也同样能够操作cidr值。 而将某些操作inetcidr的函数单独分隔开是因为它们的行为不同。 inet值也可以转换为cidr值, 此时子网掩码右侧的所有位都将无声的转换为零以获得一个有效的cidr值。 另外,你还可以使用常规的类型转换语法将一个文本字符串转换为inetcidr值。 例如:inet(expression)colname::cidr

表 9-36显示了可以用于macaddr类型的函数。 函数trunc(macaddr)返回一个 MAC 地址, 该地址的最后三个字节设置为零。这样可以把剩下的前缀与一个制造商相关联。

表 9-36. macaddr 函数

函数返回类型描述例子结果
trunc(macaddr) macaddr把后三个字节置为零trunc(macaddr '12:34:56:78:90:ab')12:34:56:00:00:00

macaddr类型还支持标准关系操作符(>, <= 等)用于词法排序,和按位运算符(~, &|)非,与和或。

<
/BODY >