Expressões

From TaticView
Revision as of 17:23, 12 July 2017 by Jonathan (talk | contribs)
Jump to: navigation, search

Expressões permitem que você crie e edite regras de Filtros manualmente usando linguagem de programação.

Importante: Depois de editar manualmente a expressão, os operadores regulares não podem ser usados até que você Limpe todos os filtros;



Estruturas de Expressões Básicas

Operandos de Valor

Os operandos de valor são valores de um tipo de dado que são usados nas expressões como variáveis.


Operando de Valor

São valores numéricos do tipo float (domínio dos números Reais). Estes valores permitem o uso de um integer e uma parte fracionada, separada por um ponto (.) (separador decimal).

 Exemplos: 1, 1.05, 2.55;

Operando de Texto

São operandos de dados de cadeia literais. Estes valores permitem o uso de campos de sequência de caracteres(strings), sendo delimitados pela aspas simples (').

 Exemplos: 'André Moraes', 'São Paulo', 'Espaguete';

Operando de Data

São valores que expressam qualquer data. É possível representar a data como uma string, sendo delimitada pela aspa simples (') e separado pela barra (/). O formato padrão suportado é "dd/MM/aaaa".

 Exemplos: '01/01/2011', '29/02/2000';

Operando Booleano

São valores do tipo verdadeiro ou falso. Normalmente usados para validar, ou não, uma condição.

 Exemplos: true e false;

Operandos de Identificação

São valores que representam um campo ou variável na expressão. Usados para fazer referências para as colunas do arquivo de dados, delimitado por aspas duplas (").

 Exemplos: "Cidade.Cidade", "Produto.Produto";

Parênteses

Usados para agrupar e separar partes da expressão. Expressões dentro do parênteses são processadas antes.

 Exemplos: ("Lucro" / "Preço Total") + 10

Operando de variável de sistema

São variáveis pré-definidas do sistema. Estes valores são alterados em tempo de execução por valores pré determinados, delimitado por aspas duplas (") e precedido por cerquilha (#). Agora somente uma variável está disponível: "#null", que indica valores ou campos nulos.


Expressões Aritméticas

As relações aritméticas relacionam dois operandos (valor ou outra expressão) para compor a soma, subtração, multiplicação ou divisão.

Soma (+)

Soma dois operandos. Representado pelo caractere de soma (+).

  Sintaxe: <operando/expressão> + <operando/expressão>.
 Exemplos: "Impostos" + "Comissões";

Subtração (-)

Subtrai dois operandos. Representado pelo caractere de soma ou hífen (-).

  Sintaxe: <operando/expressão> - <operando/expressão>.
 Exemplos: "Preço" - "Impostos";

Multiplicação (*)

Multiplica dois operandos. Representado pelo caractere de multiplicação ou asterisco (*).

  Sintaxe: <operando/expressão> * <operando/expressão>.
 Exemplos: "Quantidade" * "Preço Unitário";

Divisão (/)

Divide dois operandos. Representada pelo caractere de divisão ou barra (/).

  Sintaxe: <operando/expressão> / <operando/expressão>.
 Exemplos: "Preço" ; "Quantidade".


Expressões Relacionais

As expressões relacionais comparam dois operandos (valor ou outra expressão) para avaliar se uma condição é verdadeira(true) ou falsa(false). Normalmente usada com funções de decisão, como IF.

Igual (==)

Executa a a comparação de igualdade entre dois operandos. Representado pelo operador de igualdade (==).

  Sintaxe: <expressão> == <expressão>.
 Exemplos: "Preço Unitário" == "Preço Total";

Diferente (!=)

Executa a comparação de diferença entre dois operandos. Representado pelo operador Diferente (!=).

  Sintaxe: <expressão> != <expressão>.
 Exemplos: "Cidade.Cidade" != 'São Paulo';

Maior que (>)

Retorna true (verdadeiro) se a primeira expressão é maior que a segunda expressão e false(falsa) caso contrário. Representado pelo operador maior (>).

  Sintaxe: <expressão> > <expressão>.
 Exemplos: "Data de Pedido" > '01/01/2011';

Maior ou igual que (>=)

Retorna true (verdadeiro) se a primeira expressão é maior ou igual que a segunda expressão e false(falsa) caso contrário. Representado pelo operador maior ou igual (>=).

  Sintaxe: <expressão> >= <expressão>.
 Exemplos: IF("Data de Pedido" >= '01/01/2011';"Data de Pedido";0);

Menor que (<)

Retorna true (verdadeiro) se a primeira expressão é menor que a segunda expressão e false(falsa) caso contrário. Representado pelo operador menor (<).

  Sintaxe: <expressão> < <expressão>.
 Exemplos: "Lucro" < '0';

Menor ou igual que (<=)

Retorna true (verdadeiro) se a primeira expressão é menor ou igual que a segunda expressão e false(falsa) caso contrário. Representado pelo operador menor ou igual (<=).

  Sintaxe: <expressão> <= <expressão>.
 Exemplos: IF("Data de Pedido" <= '01/01/2011';"Data de Pedido";0);


Expressões Lógicas

As expressões lógicas agrupam dois operandos (booleano ou outra expressão) para compor uma expressão lógica, com o objetivo de avaliar a relação de dois operadores booleanos em um resultado true(verdadeiro) ou false(falso). Normalmente usado com funções de decisão, como IF e com expressões relacionais.


E (&&)

Executa a operação lógica E entre dois valores booleanos. Ambos operadores devem ser true(verdadeiro) para que o resultado da operação seja true. Representado pelo operador E (&&).

  Sintaxe: <expressão> && <expressão>.
 Exemplos: IF((Preço > '0') && (Vendedor == 'André Moraes');'Vendido';'Não Vendido'), IF((Cidade!="#null") && (Date<DAY_FROM_TODAY(0));1;0);

Ou (||)

Executa a operação lógica OU entre dois valores booleanos. Um dos dois valores deve ser true para que o resultado da operação seja true. Representado pelo operador OU (||).

  Sintaxe: <expressão> || <expressão>.
 Exemplos: IF((Preço > '0') || (Vendido == 'true');'Vendido';'Não Vendido'), IF((Cidade!="#null") || (Date<DAY_FROM_TODAY(0));1;0);

Não (!)

Executa a operação lógica de negação para um valor booleano. Se o operando for true o NÃO converte ela para false e vice-versa. Representado pelo operador NÃO (").

  Sintaxe: ! <expressão>.
 Exemplos: IF(!BETWEEN("Data", '01/01/2013', '31/12/2013');'Não é 2013';'É 2013').


Funções Auxiliares

Funções Básicas

As funções básicas são funções padrão do sistema e implementam funcionalidades úteis.

Abs

Retorna o valor absoluto de um valor base.

  Sintaxe: ABS(<expression>). Aceita um parâmetro e processa dados numéricos.
 Exemplos: ABC(Lucro-Impostos);

Avg

Retorna a média dos valores de uma sequência de valores.

  Sintaxe: AVG(<expressão1>;<expressão2>[<expressão3>;...;<expressãoN>]). Aceita múltiplos parâmetros e processa dados do tipo numérico.

Pode ser utilizado para retornar a média de diferentes colunas de uma mesma linha da tabela.

 Exemplos: AVG(Impostos;Lucro; Custos);

Entre (Between)

Verifica se um valor está entre os limites dos valores de parâmetro.

  Sintaxe: BETWEEN(<expressão_para_testar>;<expressão_limite_inicial>;<expressão_limite_final>). São necessários três parâmetros (de qualquer tipo, mas os três devem ser do mesmo tipo) e retorna um valor booleano, true se os valores estão dentro dos limites definidos ou false se não estão nos limites.
 Exemplos: BETWEEN("Data";'01/01/2013';'31/12/2013'), BETWEEN("Preço";'0';'1000.00');

Se Não Então (If Then Else)

Testa uma expressão booleana e retorna um valor caso seja true e outro valor case seja false.

   Sintaxe: IF(<expressão_teste>;<expressão_para_verdadeiro>;<expressão_para_falso>). Precisa de três parâmetros, um booleano para testes e retornos de qualquer tipo de dados, desde que ambos sejam do mesmo tipo. Útil para testes de lógica onde duas execuções de expressões diferentes são necessárias.
 Exemplos: IF("Filial"=='Sul';'Sul';'Outra Filial')
                 IF("Lucro"==0;0;Lucro+Impostos);

Log

Retorna o logaritmo de um número em uma base definida.

  Sintaxe: LOG(<expressão_de_número>[;<expressão_de_base>]). Mínimo de um parâmetro e máximo de dois. Se somente um parâmetro é passado, é devolvido o logaritmo neperiano(natural). Se um segundo parâmetro é passado, retorna o logaritmo na base respectiva.
 Exemplos: LOG(Lucro);

Max

Retorna o maior valor entre dois números.

  Sintaxe: MAX(<expressão_de_valor1>;<expressão_de_valor2>). Precisa de dois parâmetros de valor e retorna dados do tipo valor.
 Exemplos: "Valor"/MAX("Quantidade";"1");

Min

Retorna o menor valor entre dois números.

  Sintaxe: MIN(<expressão_de_valor1>;<expressão_de_valor2>). Precisa de dois parâmetros de valor e retorna dados do tipo valor.
 Exemplos: "Valor"/MIN("Quantidade";"1");

Potência

Retorna a potência de um valor em um expoente definido.

  Sintaxe: POW(<expressão_de_número>[;<expressão_de_expoente>]). Mínimo de um parâmetro e máximo de dois. Se o valor do expoente não é dado, usa o valor dois (2) como padrão.
 Exemplos: POW(Valor1)+POW(Valor1-Valor2;3);

Random

Retorna um número aleatório dentro dos limites dos valores.

  Sintaxe: RANDOM(<expressão_limite_inicial>;<expressão_limite_final>). Precisa de dois parâmetros, os limites iniciais e finais do número aleatório a ser gerado.
 Exemplos: RANDOM(0.0;1.0);

Raiz Quadrada (SQRT)

Retorna a raiz quadrada de um valor.

  Sintaxe: SQRT(<expressão>). Precisa de um parâmetro, o valor a ser calculado.
 Exemplos: SQRT('36').


Funções de Data

As funções de data são operações que usam como parâmetro e retornam resultados do tipo Data

Lista de Constantes

    • 0: DATE_FIELD_YEAR (Parte do Ano);
    • 1: DATE_FIELD_MONTH (Parte do Mês);
    • 2: DATE_FIELD_DAY (Parte do Dia);
    • 3: DATE_FIELD_FORTNIGHT (Parte da Quinzena);
    • 5: DATE_FIELD_WEEK (Parte da Semana);


Parte da Data

Retorna parte de uma data.

  Sintaxe: DATE_PART(<expressão_de_data>;<constante>). Precisa de dois parâmetros, o primeiro é a data de referência e o segundo é uma constante representando a parte desejada da data: 0, 1, 2, 3, 4 ou 5 (veja a lista de constantes acima).
 Exemplos: DATE_PART("Data de Pedido";0) - retorna a parte do ano da "Data de Pedido";

Dias a partir de hoje

Retorna uma contagem de dias para trás (negativa) ou para frente (positiva) contando a partir de hoje.

  Sintaxe: DAY_FROM_TODAY(<expressão_de_número_de_dias>). Precisa de um parâmetro, o número de dias para adicionar ou subtrair.
 Exemplos: DAY_FROM_TODAY(-1) - retorna a data de ontem;

Primeiro dia de

Retorna o primeiro dia de um agrupamento. Esta função possui duas variações:

  • Primeira maneira:
  Sintaxe: FIRST_DAY_OF(<agrupamento_constante>;<expressão_de_data>). Precisa de dois parâmetros, o primeiro é uma constante de agrupamento da qual você quer obter a primeira data: 0, 1, 2, 3 ou 5 (veja lista de constantes) e o segundo é o valor ancora de base.
 Exemplos: FIRST_DAY_OF(0;DAY_FROM_TODAY(0)) - primeiro dia do ano (0) a partir de hoje; (DAY_FROM_TODAY(0)); FIRST_DAY_OF(1;"Order Date") - primeiro dia do mês (1) baseado na "Ordem do Pedido";
  • Segunda maneira:
  Sintaxe: FIRST_DAY_OF(<agrupamento_constante>;<modificador_constante_de_data>;<valor_do_modificador_de_data>). Precisa de três parâmetros, o primeiro é a constante de agrupamento da qual você quer obter a primeira data: 0, 1, 2, 3 ou 5 (veja lista de constantes), a segunda é o modificador da base da data a partir de hoje: 0, 1, 2, 3 ou 5 (veja lista de constantes) e o terceiro é a quantidade para alterar o modificador.
 Exemplos: FIRST_DAY_OF(1;0;-1) - primeiro dia do mês atual (1) do último ano (0;-1);

Último dia de

Retorna o último dia de um agrupamento. Esta função possuí duas variações:

  • Primeira Maneira:
  Sintaxe: LAST_DAY_OF(<agrupamento_constante>;<expressão_de_data>). Precisa de dois parâmetros, o primeiro é uma constante de agrupamento da qual você quer obter a última data: 0, 1, 2, 3 ou 5 (veja lista de constantes) e o segundo é o valor ancora de base.
 Exemplos: LAST_DAY_OF(0;DAY_FROM_TODAY(0)) - último dia do ano (0) a partir de hoje; (DAY_FROM_TODAY(0)); LAST_DAY_OF(1;"Order Date") - último dia do mês (1) baseado na "Ordem do Pedido";
  • Segunda maneira:
  Sintaxe: LAST_DAY_OF(<agrupamento_constante>;<modificador_constante_de_data>;<valor_do_modificador_de_data>). Precisa de três parâmetros, o primeiro é a constante de agrupamento da qual você quer obter a última data: 0, 1, 2, 3 ou 5 (veja lista de constantes), a segunda é o modificador da base da data a partir de hoje: 0, 1, 2, 3 ou 5 (veja lista de constantes) e o terceiro é a quantidade para alterar o modificador.
 Exemplos: LAST_DAY_OF(1;0;-1) - último dia do mês atual (1) do último ano (0;-1);

Nova Data

Cria um objeto de uma data, mês e ano.

  Sintaxe: NEW_DATE(<expressão_dia>;<expressão_mês>;<expressão_ano>). Precisa de três parâmetros, o primeiro é um número de dia válido (1 a 31), o segundo um mês (1 a 12) e o terceiro é um ano. A data é criada do ano para o dia, ou seja, o dia deve ser válido para o mês e para o ano (considerando 29/02, o ano deve ser bissexto).
 Exemplos: (1;4;DATE_PART("Data de Pedido";0)) - Cria o primeiro dia de abril do ano determinado pela linha atual da coluna "Data de Pedido";

Número de dias

Retorna o número de dias entre duas datas.

  Sintaxe: NUM_OF_DAYS(<expressão_data1>;<expressão_data2>); Precisa de dois parâmetros do tipo data.
 Exemplos: NUM_OF_DAYS(FIRST_DAY_OF(0;"Data de Pedido");"Data de Pedido") - retorna o número de dias entre o primeiro dia do ano baseado na coluna "Ordem do Pedido" até o dia atual da coluna "Ordem do Pedido", NUM_OF_DAYS(FIRST_DAY_OF(1;"Pay Date"); LAST_DAY_OF(1;"Pay Date")) - retorna o número de dias do mês para a coluna "Entrega do Pedido";

Número de Meses

Retorna o número de meses entre duas datas.

  Sintaxe: NUM_OF_MONTHS(<expressão_data1>;<expressão_data2>); Precisa de dois parâmetros do tipo data.
 Exemplos: NUM_OF_MONTHS(FIRST_DAY_OF(0;"Data");"Data") - Retorna o número de meses entre o primeiro dia do ano da coluna "Data" e o mês atual da coluna "Data";

Data anterior

Retorna a data exata anterior mais próxima dado um dia e um mês.

  Sintaxe: PREVIOUS_DATE(<expressão_dia>;<expressão_mês>). Precisa de dois parâmetros, o primeiro é o dia do mês e o segundo é o mês.
 Exemplos: PREVIOUS_DATE(1;4) - retorna a data 01/04 mais próxima, em outras palavras, até 01/04/ano atual, retorna "01/04/último ano", depois retorna "01/04/ano atual".


Varíaveis especiais

Váriaveis especiais podem ser usadas com as expressões.

Importante: as variáveis abaixo devem ser escritas entre aspas duplas.

 "@count" - Número total de linhas que foram retornados para o componente. 
 "@row" - número da linha atual.
  "@sum[Coluna]" - Somatório da coluna indicada.
 "@avg[Coluna]" - Média da coluna semelhante a "@sum[Coluna]" / "@count"
 "@prev[coluna]" - Valor da linha anterior dessa coluna.
 "@accumCol[coluna]" - Valor acumulado da coluna até a linha corrente. Útil para calcular média variável. Ex.: "@accumCol[coluna]" / "@row"