返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

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

发布于 2019-09-30 03:06:23 字数 6105 浏览 912 评论 0 收藏 0

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

表9-31. 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.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-32显示了所有可以用于 cidrinet 的函数。函数 host, text, abbrev 主要是为了提供可选的显示格式用的。

表9-32. 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 为IPv6)family('::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-33显示了可以用于 macaddr 类型的函数。函数 trunc(macaddr) 返回一个 MAC 地址,该地址的最后三个字节设置为零。这样可以把剩下的前缀与一个制造商相关联。

表9-33. macaddr 函数

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

macaddr 类型还支持标准关系操作符(>, <= 等)用于词法排序。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文