A Tabela 6-23 mostra os operadores disponíveis para os tipos inet e cidr. Os operadores <<, <<=, >>, >>= testam a inclusão na subrede: somente consideram as partes de rede destes dois endereços, ignorando qualquer parte do hospedeiro, determinando se a parte de rede é idêntica ou uma subrede da outra.
Tabela 6-23. Operadores cidr e inet
| Operador | Descrição | Utilização |
|---|---|---|
| < | Menor que | inet '192.168.1.5' < inet '192.168.1.6' |
| <= | Maior que 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 em 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 6-24 mostra as funções
disponíveis para utilizar com os tipos de dado inet
e cidr. As funções host(),
text() e abbrev()
são voltadas principalmente para oferecer alternativas para o formato de
exibição. Um campo texto pode ser transformado em endereço de rede utilizando
a sintaxe habitual de conversão: inet(expressão) ou
nome_da_coluna::inet.
Tabela 6-24. Funções cidr e inet
| Função | Retorna | 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 |
network(inet) | cidr | extrai a parte de rede do endereço | 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 como texto | text(inet '192.168.1.5') | 192.168.1.5/32 |
abbrev(inet) | text | extrai a exibição abreviada como texto | abbrev(cidr '10.1.0.0/16') | 10.1/16 |
A Tabela 6-25 mostra as funções
disponíveis para utilizar com o tipo mac. A função
trunc(macaddr) retorna um endereço MAC
com os últimos 3 bytes feitos iguais a zero. Isto pode ser utilizado para
associar o prefixo remanescente com o fabricante. O diretório
contrib/mac da distribuição do fonte
contém alguns utilitários para criar e manter este tipo de tabela de
associação.
Tabela 6-25. Funções para o tipo macaddr
| Função | Retorna | 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 ordenação lexicográfica.