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.
| [1] |
A tabela de associação pode ser vista em http://standards.ieee.org/regauth/oui/oui.txt (N. do T.) |