绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
函数和操作符-网络地址函数和操作符
2020-01-15 15:24:24

cidr和inet操作符

操作符<<,<<=,>>,>>=对子网进行测试。它们只考虑两个地址的网络部分(忽略任何主机部分),然后判断其中一个网络是等于另外一个网络,还是另外一个网络的子网。

  • <

    描述:小于

    示例:

    SELECT inet '192.168.1.5' < inet '192.168.1.6' AS RESULT;
    result
    --------
    t
    (1 row)
  • <=

    描述:小于或等于

    示例:

    SELECT inet '192.168.1.5' <= inet '192.168.1.5' AS RESULT;
    result
    --------
    t
    (1 row)
  • =

    描述:等于

    示例:

    SELECT inet '192.168.1.5' = inet '192.168.1.5' AS RESULT;
    result
    --------
    t
    (1 row)
  • >=

    描述:大于或等于

    示例:

    SELECT inet '192.168.1.5' >= inet '192.168.1.5' AS RESULT;
    result
    --------
    t
    (1 row)
  • >

    描述:大于

    示例:

    SELECT inet '192.168.1.5' > inet '192.168.1.4' AS RESULT;
    result
    --------
    t
    (1 row)
  • <>

    描述:不等于

    示例:

    SELECT inet '192.168.1.5' <> inet '192.168.1.4' AS RESULT;
    result
    --------
    t
    (1 row)
  • <<

    描述:包含于

    示例:

    SELECT inet '192.168.1.5' << inet '192.168.1/24' AS RESULT;
    result
    --------
    t
    (1 row)
  • <<=

    描述:包含于或等于

    示例:

    SELECT inet '192.168.1/24' <<= inet '192.168.1/24' AS RESULT;
    result
    --------
    t
    (1 row)
  • >>

    描述:包含

    示例:

    SELECT inet '192.168.1/24' >> inet '192.168.1.5' AS RESULT;
    result
    --------
    t
    (1 row)
  • >>=

    描述:包含或等于

    示例:

    SELECT inet '192.168.1/24' >>= inet '192.168.1/24' AS RESULT;
    result
    --------
    t
    (1 row)
  • ~

    描述:位非

    示例:

    SELECT ~ inet '192.168.1.6' AS RESULT; 
    result
    ---------------
    63.87.254.249
    (1 row)
  • &

    描述:两个网络地址的每一位都进行“与”操作。

    示例:

    SELECT inet '192.168.1.6' & inet '10.0.0.0' AS RESULT;
    result
    ---------
    0.0.0.0
    (1 row)
  • |

    描述:两个网络地址的每一位都进行“或”操作。

    示例:

    SELECT inet '192.168.1.6' | inet '10.0.0.0' AS RESULT;
    result
    -------------
    202.168.1.6
    (1 row)
  • +

    描述:加

    示例:

    SELECT inet '192.168.1.6' + 25 AS RESULT;
    result
    --------------
    192.168.1.31
    (1 row)
  • -

    描述:减

    示例:

    SELECT inet '192.168.1.43' - 36 AS RESULT;
    result
    -------------
    192.168.1.7
    (1 row)
  • -

    描述:减

    示例:

    SELECT inet '192.168.1.43' - inet '192.168.1.19' AS RESULT;
    result
    --------
    24
    (1 row)

cidr和inet函数

函数abbrev,host,text主要是为了提供可选的显示格式。

  • abbrev(inet)

    描述:缩写显示格式文本。

    返回类型:text

    示例:

    SELECT abbrev(inet '10.1.0.0/16') AS RESULT;
    result
    -------------
    10.1.0.0/16
    (1 row)
  • abbrev(cidr)

    描述:缩写显示格式文本。

    返回类型:text

    示例:

    SELECT abbrev(cidr '10.1.0.0/16') AS RESULT;
    result
    ---------
    10.1/16
    (1 row)
  • broadcast(inet)

    描述:网络广播地址。

    返回类型:inet

    示例:

    SELECT broadcast('192.168.1.5/24') AS RESULT;
    result
    ------------------
    192.168.1.255/24
    (1 row)
  • family(inet)

    描述:抽取地址族,4为IPv4,6为IPv6。

    返回类型:int

    示例:

    SELECT family('::1') AS RESULT;
    result
    --------
    6
    (1 row)
  • host(inet)

    描述:将主机地址类型抽出为文本。

    返回类型:text

    示例:

    SELECT host('192.168.1.5/24') AS RESULT;
    result
    -------------
    192.168.1.5
    (1 row)
  • hostmask(inet)

    描述:为网络构造主机掩码。

    返回类型:inet

    示例:

    SELECT hostmask('192.168.23.20/30') AS RESULT;
    result
    ---------
    0.0.0.3
    (1 row)
  • masklen(inet)

    描述:抽取子网掩码长度。

    返回类型:int

    示例:

    SELECT masklen('192.168.1.5/24') AS RESULT;
    result
    --------
    24
    (1 row)
  • netmask(inet)

    描述:为网络构造子网掩码。

    返回类型:inet

    示例:

    SELECT netmask('192.168.1.5/24') AS RESULT;
    result
    ---------------
    255.255.255.0
    (1 row)
  • network(inet)

    描述:抽取地址的网络部分。

    返回类型:cidr

    示例:

    SELECT network('192.168.1.5/24') AS RESULT;
    result
    ----------------
    192.168.1.0/24
    (1 row)
  • set_masklen(inet, int)

    描述:为inet数值设置子网掩码长度。

    返回类型:inet

    示例:

    SELECT set_masklen('192.168.1.5/24', 16) AS RESULT;
    result
    ----------------
    192.168.1.5/16
    (1 row)
  • set_masklen(cidr, int)

    描述:为cidr数值设置子网掩码长度。

    返回类型:cidr

    示例:

    SELECT set_masklen('192.168.1.0/24'::cidr, 16) AS RESULT;
    result
    ----------------
    192.168.0.0/16
    (1 row)
  • text(inet)

    描述:把IP地址和掩码长度抽取为文本。

    返回类型:text

    示例:

    SELECT text(inet '192.168.1.5') AS RESULT;
    result
    ----------------
    192.168.1.5/32
    (1 row)

任何cidr值都能显式或者隐式的方式转换为inet值,因此上述能够操作inet值的函数也同样能够操作cidr值。inet值也可以转换为cidr值,此时inet子网掩码右侧的所有位都将转换为零,以创建一个有效的cidr值。另外,用户还可以使用常规的类型转换语法将一个文本字符串转换为inet或cidr值。例如:inet(expression)或colname::cidr。

macaddr函数

函数trunc(macaddr)返回一个MAC地址,该地址的后三个字节设置为零。

trunc(macaddr)

描述:把后三个字节置为零。

返回类型:macaddr

示例:

SELECT trunc(macaddr '12:34:56:78:90:ab') AS RESULT;
result
-------------------
12:34:56:00:00:00
(1 row)

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

分享好友

分享这个小栈给你的朋友们,一起进步吧。

GaussDB_数据库
创建时间:2020-01-06 16:21:44
华为GaussDB数据库小栈
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • GaussDB_数据库
    专家
戳我,来吐槽~