9.11. Funções e operadores para endereço de rede

A Tabela 9-33 mostra os operadores disponíveis para uso com os tipos cidr e inet. Os operadores <<, <<=, >> e >>= testam a inclusão na subrede: somente consideram a parte de rede dos dois endereços, ignorando qualquer parte de hospedeiro, determinando se a parte de rede é idêntica, ou se uma é subrede da outra.

Tabela 9-33. Operadores para os tipos cidr e inet

Operador Descrição Exemplo
< menor inet '192.168.1.5' < inet '192.168.1.6'
<= menor ou igual inet '192.168.1.5' <= inet '192.168.1.5'
= igual inet '192.168.1.5' = inet '192.168.1.5'
>= maior ou igual inet '192.168.1.5' >= inet '192.168.1.5'
> maior inet '192.168.1.5' > inet '192.168.1.4'
<> diferente inet '192.168.1.5' <> inet '192.168.1.4'
<< está contido em inet '192.168.1.5' << inet '192.168.1/24'
<<= está contido ou é igual inet '192.168.1/24' <<= inet '192.168.1/24'
>> contém inet '192.168.1/24' >> inet '192.168.1.5'
>>= contém ou é igual inet '192.168.1/24' >>= inet '192.168.1/24'

A Tabela 9-34 mostra as funções disponíveis para uso com os tipos de dado cidr e inet. As funções host(), text() e abbrev() se destinam, principalmente, a oferecer formatos de exibição alternativos. Um valor texto pode ser convertido em inet utilizando a sintaxe normal de conversão: inet(expressão) ou nome_da_coluna::inet.

Tabela 9-34. Funções para os tipos cidr e inet

Função Tipo retornado Descrição Exemplo Resultado
broadcast(inet) inet endereço de difusão da rede broadcast('192.168.1.5/24') 192.168.1.255/24
host(inet) text extrai o endereço de IP como texto host('192.168.1.5/24') 192.168.1.5
masklen(inet) integer extrai o comprimento da máscara de rede masklen('192.168.1.5/24') 24
set_masklen(inet, integer) inet define o comprimento da máscara de rede para o valor do tipo inet set_masklen('192.168.1.5/24', 16) 192.168.1.5/16
netmask(inet) inet constrói máscara de rede para a rede netmask('192.168.1.5/24') 255.255.255.0
hostmask(inet) inet constrói máscara de hospedeiro para a rede hostmask('192.168.23.20/30') 0.0.0.3
network(inet) cidr extrai do endereço a parte de rede network('192.168.1.5/24') 192.168.1.0/24
text(inet) text extrai o endereço de IP e o comprimento da máscara de rede como texto text(inet '192.168.1.5') 192.168.1.5/32
abbrev(inet) text formato de exibição abreviado como texto abbrev(cidr '10.1.0.0/16') 10.1/16
family(inet) integer extrai a família de endereços; 4 para IPv4, e 6 para IPv6 family('::1') 6

A Tabela 9-35 mostra as funções disponíveis para uso com o tipo macaddr. A função trunc(macaddr) retorna o endereço MAC com os últimos 3 bytes tornados zero, podendo ser utilizado para associar o prefixo remanescente com o fabricante. Na distribuição do código fonte o diretório contrib/mac contém alguns utilitários para criar e manter esta tabela de associação. [1]

Tabela 9-35. Funções para o tipo macaddr

Função Tipo retornado Descrição Exemplo Resultado
trunc(macaddr) macaddr torna os 3 últimos bytes iguais a zero trunc(macaddr '12:34:56:78:90:ab') 12:34:56:00:00:00

O tipo macaddr também suporta os operadores relacionais padrão (>, <=, etc.) para a ordenação lexicográfica.

Notas

[1]

A tabela de associação pode ser vista em http://standards.ieee.org/regauth/oui/oui.txt (N. do T.)

SourceForge.net Logo CSS válido!