Função TRUNC - Amazon Redshift

Função TRUNC

A função TRUNC trunca números para o inteiro ou decimal anterior.

A função TRUNC pode incluir opcionalmente um segundo argumento como um INTEGER para indicar o número de casas decimais para arredondamento, em qualquer direção. Quando você não fornece o segundo argumento, a função arredonda para o número inteiro mais próximo. Quando o segundo argumento inteiro é especificado, a função arredonda para o número mais próximo com inteiro casas decimais de precisão.

Essa função também pode truncar um TIMESTAMP e retornar um DATE. Para obter mais informações, consulte Função TRUNC.

Sintaxe

TRUNC(number [ , integer ])

Argumentos

número

Um número ou uma expressão avaliada como um número. Ele pode ser do tipo DECIMAL, FLOAT8 ou SUPER. O Amazon Redshift pode converter outros tipos de dados de acordo com as regras de conversão implícitas.

inteiro

(Opcional) Um INTEGER que indica o número de casas decimais de precisão, em um dos sentidos. Se nenhum inteiro for fornecido, o número será truncado como um número inteiro; se um inteiro for especificado, o número será truncado para a casa decimal especificada. Isso não é compatível com o tipo de dados SUPER.

Tipo de retorno

TRUNC retorna o mesmo tipo de dados que a entrada número.

Quando a entrada é do tipo SUPER, a saída mantém o mesmo tipo dinâmico que a entrada enquanto o tipo estático permanece o tipo SUPER. Quando o tipo dinâmico de SUPER não é um número, o Amazon Redshift retorna NULL.

Exemplos

Alguns dos exemplos a seguir usam o banco de dados de amostra de TICKIT. Para obter mais informações, consulte Banco de dados de exemplo.

Para truncar a comissão paga para determinada transação de vendas, use o exemplo a seguir.

SELECT commission, TRUNC(commission) FROM sales WHERE salesid=784; +------------+-------+ | commission | trunc | +------------+-------+ | 111.15 | 111 | +------------+-------+

Para truncar o mesmo valor de comissão para a primeira casa decimal, use o exemplo a seguir.

SELECT commission, TRUNC(commission,1) FROM sales WHERE salesid=784; +------------+-------+ | commission | trunc | +------------+-------+ | 111.15 | 111.1 | +------------+-------+

Para truncar a comissão com um valor negativo para o segundo argumento, use o exemplo a seguir. Observe que 111.15 é arredondado para 110.

SELECT commission, TRUNC(commission,-1) FROM sales WHERE salesid=784; +------------+-------+ | commission | trunc | +------------+-------+ | 111.15 | 110 | +------------+-------+