Expressões

From TaticView
Revision as of 14:19, 9 April 2014 by Artur (talk | contribs) (Created page with "==== Último dia de ==== Retorna o último dia de um agrupamento. Esta função possuí duas variações: * '''Primeira Maneira''': Sintaxe: ''LAST_DAY_OF(<agrupamento_cons...")
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 da fonte 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);

New date

Create an object from a day, month and year.

   Syntax: NEW_DATE(<expression_day>;<expression_month>;<expression_year>). Need three parameters, the first is a valid day number (1 to
           31), the second for a month (1 to 12) and the third is a year. The date is created from year to day, therefore, the day must be
           valid for the month and the year (considering 29/02, year must be bissextile). 
 Examples: NEW_DATE(1;4;DATE_PART("Order Date";0)) - create the first day of april from the year determined by the current row 
           "Order Date" column;

Num of days

Return the number of days between two dates.

   Syntax: NUM_OF_DAYS(<expression_date1>;<expression_date2>). Need two date data type parameters. 
 Examples: NUM_OF_DAYS(FIRST_DAY_OF(0;"Order Date");"Order Date") - returns the number of days between the first day of year based on
           the "Order Date" column to the current day of the "Order Date" column,
           NUM_OF_DAYS(FIRST_DAY_OF(1;"Pay Date"); LAST_DAY_OF(1;"Pay Date")) - returns the number of days of the month of the "Pay Date"
           column;

Num of months

Return the number of months between two dates.

   Syntax: NUM_OF_MONTHS(<expression_date1>;<expression_date2>). Need two date data type parameters. 
 Examples: NUM_OF_MONTHS(FIRST_DAY_OF(0;"Date");"Date") - Return the number of months between the first day of the year of the "Date"
           column and the current month of the "Date" column;

Previous date

Return the closest exact previous date given a day and month.

   Syntax: PREVIOUS_DATE(<expression_day>;<expression_month>). Need two parameters, the first is the day of month and the second the
           month. 
 Examples: PREVIOUS_DATE(1;4) - return the closest 01/04, in other words, until "01/04/current year", returns "01/04/last year",
           after that returns "01/04/current year".