Difference between revisions of "Expressions/pt-br"

From TaticView
Jump to: navigation, search
(Created page with "==== Igualdade (==) ====")
(Created page with "Sintaxe: COUNT_DISTINCT(<expressão>) Exemplo: '''COUNT_DISTINCT("Produto")''' - Retorna o número de ocorrências únicas de produtos")
 
(175 intermediate revisions by 4 users not shown)
Line 19: Line 19:
  
 
* Se o componente possui as colunas ''Preço Total'' e ''Quantidade'', pode-se criar uma expressão para calcular o ''Preço Unitário''. Ficaria assim:
 
* Se o componente possui as colunas ''Preço Total'' e ''Quantidade'', pode-se criar uma expressão para calcular o ''Preço Unitário''. Ficaria assim:
** ''Preço Total'' / ''Quantidade''
+
** ''"Preço Total"'' / ''"Quantidade"''
 
* Além disso, pode-se utilizar valores fixos, como por exemplo:
 
* Além disso, pode-se utilizar valores fixos, como por exemplo:
** ''Preço Total'' / 10
+
** ''"Preço Total"'' / 10
  
  
 
Lembramos apenas que atualmente o TaticView suporta apenas expressões cujo retorno é numérico.
 
Lembramos apenas que atualmente o TaticView suporta apenas expressões cujo retorno é numérico.
  
 +
 +
As expressões suportam a barra inversa como [[EscapeChar|caractere de escape]] para que nomes possam conter os caracteres delimitadores.
  
 
Abaixo detalhes sobre o funcionamento das expressões.
 
Abaixo detalhes sobre o funcionamento das expressões.
Line 31: Line 33:
 
== Estrutura básica de uma expressão ==
 
== Estrutura básica de uma expressão ==
  
 +
==== Identificador ====
 +
 +
É o nome do campo ou coluna envolvido na expressão, deve ser delimitado por aspas duplas.
 +
 +
* Exemplos: "Preço médio", "Parafuso 1\" philips", "Vendedor"
  
 
==== Operando de Valor ====
 
==== Operando de Valor ====
Line 38: Line 45:
 
* Exemplos: 1, 1.05, 2.55
 
* Exemplos: 1, 1.05, 2.55
  
 +
* Importante: Não é permitido usar separador de milhar nos valores, assim como "," como separador decimal.
  
 
==== Operando de Texto ====
 
==== Operando de Texto ====
Line 72: Line 80:
  
 
* Exemplo: IF("Produto" == "#null";0;20)
 
* Exemplo: IF("Produto" == "#null";0;20)
 
  
 
== Expressões Aritméticas ==
 
== Expressões Aritméticas ==
Line 96: Line 103:
 
   <operando ou expressão> - <operando ou expressão>
 
   <operando ou expressão> - <operando ou expressão>
 
Exemplo:  
 
Exemplo:  
   '''"Preço" "Impostos"''' – Subtrai os valores dos campos ''Preço'' e ''Impostos''
+
   '''"Preço" - "Impostos"''' – Subtrai os valores dos campos ''Preço'' e ''Impostos''
  
  
Line 126: Line 133:
 
==== Igualdade (==) ====
 
==== Igualdade (==) ====
  
It compares if two operands are the same, returning true if they are the same or false if they are different. Represented by the equality operator ''==''.
+
Compara se dois operandos são iguais, retornando true se forem iguais ou false se diferentes. Representado pelo operador de igualdade '''=='''.
  
Syntax:
+
Sintaxe:
   <operating or expression result> '''==''' <operating or expression result>
+
   <operando ou expressão> == <operando ou expressão>
Example:
+
Exemplo:  
   '''IF("Product" == "#null";0;20)''' - If the ''Product'' is null, return the value ''0''. Otherwise return the value ''20''
+
   '''IF("Produto" == "#null";0;20)''' – Se o produto for nulo, considera o valor ''0''. Caso contrário considera o valor ''20''
  
  
==== Different (!=) ====
+
==== Diferente (!=) ====
  
It compare if two operands are different, returning true if they were different or false if equal. Represented by the differente operator ''!=''.
+
Compara se dois operandos são diferentes, retornando true se foram diferentes ou false se iguais. Representado pelo operador de diferença '''!='''.
  
Syntax:  
+
Sintaxe:
   <operating or expression result> '''!=''' <operating or expression result>
+
   <operando ou expressão> != <operando ou expressão>
Example:
+
Exemplo:
   '''IF("Product" != 'Lasagna';0;20)''' - If the ''Product'' is different from ''Lasagna'', return the value ''0''. Otherwise return the value ''20''
+
   '''IF("Produto" != 'LASANHA';0;20)''' – Se o produto for diferente de ''Lasanha'', considera o valor ''0''. Caso contrário considera o valor ''20''
  
  
==== Greater than (>) ====
+
==== Maior que (>) ====
  
Compares if the first operator (from the left) is greater than the second operator (from the right), returning true if it is greater and false if it is lesser or equal. Represented by the greater operator ''>''.
+
Compara se o primeiro operador (da esquerda) é maior que o segundo operador (da direita), retornando true se for maior e false se for menor ou igual. Representado pelo operador maior '''>'''.
  
Syntax:
+
Sintaxe:
    <operating or expression result> '''>''' <operating or expression result>
+
  <operando ou expressão> > <operando ou expressão>
Example:
+
Exemplo:
   '''IF("Gross Value" > 1000;1;0)''' - If the ''Gross Value'' is greater than ''1000'', returns the value ''1'', if not the value ''0''
+
   '''IF("Valor Bruto" > 1000;1;0)''' – Se o ''Valor Bruto'' for maior que ''1000'', retorna o valor ''1'', se não o valor ''0''
  
  
==== Greater or equal to (>=) ====
+
==== Maior ou igual a (>=) ====
  
Compares if the first operator (from the left) is greater or equal to the second operator (from the right), returning true if it is greater or equal and false if it is lesser. Represented by the greater or equal operator ''>=''.
+
Compara se o primeiro operador (da esquerda) é maior ou igual ao segundo operador (da direita), retornando true se for maior ou igual e false se for menor. Representado pelo operador maior '''>='''.
  
Syntax:
+
Sintaxe:
   <operating or expression result> '''>=''' <operating or expression result>
+
   <operando ou expressão> >= <operando ou expressão>
Example:
+
Exemplo:
   '''IF("Gross Value" >= 2500;100;0)''' - If ''Gross Value'' is greater than or equal to ''2500'' returns ''100'', otherwise returns ''0''
+
   '''IF("Valor Bruto" >= 2500;100;0)''' – Se o ''Valor Bruto'' for maior ou igual a ''2500'' retorna ''100'', caso contrário retorna ''0''
  
  
==== Less than (<) ====
+
==== Menor que (<) ====
  
Compares if teh first operator (from the left) is lesser than the second operator (from the right), returning true if it is lesser and false if it is greater or equal. Represented by the Lesser operator ''<''.
+
Compara se o primeiro operador (da esquerda) é menor que o segundo operador (da direita), retornando true se for menor e false se for maior ou igual. Representado pelo operador maior '''<'''.
  
Syntax:
+
Sintaxe:
   <operating or expression result> '''<''' <operating or expression result>
+
   <operando ou expressão> < <operando ou expressão>
Example:
+
Exemplo:
   '''IF("Gross Value" < 100;50;200)''' - If ''Gross Value'' is less than ''100'', returns ''50'' if not ''200''
+
   '''IF("Valor Bruto" < 100;50;200)''' – Se o ''Valor Bruto'' for menor que ''100'', retorna ''50'', se não retorna ''200''
  
  
==== Less or equal to (<=) ====
+
==== Menor ou igual a (<=) ====
  
Compares if the first operator (from the left) is lesser or equal to the second operator (from the right), returning true if it is lesser or equal and false if it is greater. Represented by the lesser or equal operator ''<=''.
+
Compara se o primeiro operador (da esquerda) é menor ou igual ao segundo operador (da direita), retornando true se for menor ou igual e false se for maior. Representado pelo operador maior '''<='''.
  
Syntax:
+
Sintaxe:
   <operating or expression result> '''<=''' <operating or expression result>
+
   <operando ou expressão> <= <operando ou expressão>
Example:
+
Exemplo:
   '''IF("Gross Value" <= 500;100;0)''' - If ''Gross Value'' is less than or equal to ''500'' returns ''100'', if not ''0''
+
   '''IF("Valor Bruto" <= 500;100;0)''' – Se o ''Valor Bruto'' for menor ou igual a ''500'' retorna ''100'', se não retorna ''0''
  
  
== Logical Expressions ==
+
== Expressões Lógicas ==
  
Logical expressions group together two operands (Boolean or other expression) to make up a logical expression, in order to evaluate the relationship of two Boolean operators to a true or false result. This type of expression is usually used for decision making, such as IF and with relational expressions.
+
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 verdadeiro (true) ou falso (false). Normalmente esse tipo de expressão é utilizada para tomadas de decisão, como o ''IF'' (Se) e com expressões relacionais.
  
  
==== And Operator (&&) ====
+
==== Operador E (&&) ====
  
Executes the logical operation ''AND'' between two Boolean values. Both values must return true so that the result of the operation is true. Represented by the ''&&'' operator.
+
Executa a operação lógica ''E'' entre dois valores booleanos. Ambos os valores devem retornar verdadeiro (true) para que o resultado da operação seja verdadeiro (true). Representado pelo operador '''&&'''.
  
Syntax:
+
Sintaxe:  
   <expression> && <expression>
+
   <expressão> && <expressão>
Examples:
+
Exemplos:
   '''IF(("Price" > 0) && ("Seller" == 'John Snow');450;0)''' - If ''Price'' is greater than ''0'' '''AND''' ''Seller'' is equal to ''John Snow'', returns ''450'' if not returns ''0''
+
   '''IF(("Preço" > 0) && ("Vendedor" == 'André Moraes');450;0)''' – Se o ''Preço'' for maior que ''0'' '''E''' o ''Vendedor'' for igual a ''André Moraes'', retorna ''450'', se não retorna ''0''
 
+
   '''IF(("Cidade" != "#null") && ("Produto" != 'Lasanha');1;0)''' – Se a ''Cidade'' for diferente de nula '''E''' o ''Produto'' for diferente de ''Lasanha'' retorna ''1'', se não retorna ''0''
   '''IF(("City" != "#null") && ("Product" != 'Lasagna');1;0)''' - If ''City'' is non-null '''AND''' ''Product'' is different from ''Lasagna'' returns ''1'' if it does not return ''0''
 
  
  
==== Or Operator (||) ====
+
==== Operador Ou (||) ====
  
Performs the logical ''OR'' operation between two Boolean values. A two values must be true so that the result of the operation is true. Represented by the operator ''||''.
+
Executa a operação lógica ''OU'' entre dois valores booleanos. Um dois dois valores deve ser verdadeiro (true) para que o resultado da operação seja verdadeiro (true). Representado pelo operador '''||'''.
  
Syntax:
+
Sintaxe:
   <expression> || <expression>
+
   <expressão> || <expressão>
Examples:
+
Exemplos:
   '''IF(("Price" > 1000) || ("Profit" >= 50);75;55)''' - If ''Price'' is greater than ''1000'' '''OR''' ''Profit'' is greater than or equal to ''50'' returns ''75'' if not ''55''
+
   '''IF(("Preço" > 1000) || ("Lucro" >= 50);75;55)''' – Se o ''Preço'' for maior que ''1000'' '''OU''' o ''Lucro'' for maior ou igual a ''50'' retorna ''75'', se não retorna ''55''
 +
  '''IF(("Cidade" != "#null") || ("Produto" != 'Lasanha');1;0)''' - Se ''Cidade'' não for null '''OU''' ''Produto'' deferente de ''Lasanha'' returna ''1'' senão retorna ''0''
  
  '''IF(("City" != "#null") || ("Product" != 'Lasagna');1;0)''' - If ''City'' is non-null '''OR''' ''Product'' is different from ''Lasagna'' returns ''1'' if it does not return ''0''
 
  
  
 +
==== Operador de Negação (!) ====
  
==== Denial Operator (!) ====
+
Executa a operação lógica de negação para um valor booleano. Se o resultado da operação for verdadeiro (true) o operador de negação converte para falso (false) e vice-versa. Representado pelo operador '''!'''.
  
Performs the logical negation operation for a boolean value. If the result of the operation is true the negation operator converts to false and vice versa. Represented by the operator ''!''.
+
Sintaxe:
 +
  !<expressão>
 +
Exemplo:
 +
  '''IF(!BETWEEN("Data Entrega"; '01/01/2015'; '31/12/2015');2016; 2015)''' – Se a ''Data Entrega'' não tiver entre ''01/01/2015'' e ''31/12/2015'' retorna ''2016''. Se estiver entre esse período retorna ''2015''
  
Syntax:
 
  !<expression>
 
Example:
 
  '''IF(!BETWEEN("Delivery Date"; '01/01/2015'; '31/12/2015');2016;2015)''' - If the ''Delivery Date'' is '''NOT''' between ''01/01/2015'' and ''12/31/2015'' returns ''2016''. If between this period returns ''2015''
 
  
 +
== Funções Auxiliares ==
  
== Auxiliary Functions ==
+
As funções auxiliares básicas são funções padrão do sistema e implementam funcionalidades úteis para compor expressões complexas.
  
Basic helper functions are standard system functions and implement useful features for composing complex expressions.
 
  
 +
==== Função ABS ====
  
==== ABS function ====
+
Função que retorna o valor numérico absoluto de um valor numérico base.
  
Function that returns the absolute numeric value of a base numeric value.
+
Sintaxe:
 +
  ABS(<expressão>)
 +
Exemplo:
 +
  '''ABS("Preço" / "Quantidade")''' – Retorna o valor absoluto do ''Preço'' divido pela ''Quantidade''
  
Syntax:
 
  ABS(<value operator or expression>)
 
Example:
 
  '''ABS("Price" / "Quantity")''' - Returns the absolute value of ''Price'' divided by ''Quantity''
 
  
 +
==== Função AVG ====
  
==== AVG function ====
+
Retorna a média dos valores de uma sequência de valores. Pode ser utilizado para retornar a média de diferentes valores de uma mesma linha das tabelas.
  
Returns the average of the values ​​of a sequence of values. It can be used to return the average of different values ​​of the same row of tables.
+
Sintaxe:
 +
  AVG(<expressão 1>; <expressão 2>; ...)
 +
Exemplo:
 +
  '''AVG("Impostos"; "Lucro"; "Custo")''' – Retorna a média entre a soma das colunas ''Impostos'', ''Lucro'' e ''Custo''
  
Syntax:
 
  AVG(<expression 1>; <expression 2>; ...)
 
Example:
 
  '''AVG("Taxes"; "Profit"; "Cost")''' - Returns the average between the sum of the ''Taxes'', ''Profit'' and ''Cost'' columns
 
  
 +
==== Função BETWEEN (Entre) ====
  
==== BETWEEN function ====
+
Verifica se um valor está estre os limites dos parâmetros utilizados.
  
Checks whether a value is within the limits of the parameters used. Return true or false.
+
Sintaxe:
 +
  BETWEEN(<expressão a ser testada>; <limite inicial>; <limite final>)
 +
Exemplo:
 +
  '''BETWEEN("Data Emissão"; '01/01/2019'; '31/12/2019')''' – Retorna true se a ''Data Emissão'' estiver entre ''01/01/2019'' e ''31/12/2019''. Caso contrário retorna false
  
Syntax:
+
==== Função COUNT ====
  BETWEEN(<expression to be tested>; <initial limit>; <end limit>)
 
Example:
 
  '''BETWEEN("Date Issued"; '01/01/2019'; '31/12/2019')''' - Returns true if ''Date Issued'' is between ''01/01/2019'' and ''12/31/2019''. Otherwise returns false
 
  
 +
Retorna o número de ocorrências (linhas) de uma coluna ou valor.
  
==== IF ELSE function (If .... Otherwise ...) ====
+
Por ora, esta função funciona apenas em expressões de Fontes de Dados
  
Tests a Boolean expression and applies a condition to true or another condition to false. You need three parameters, separated by semicolons (;). The first parameter is the expression to be tested, the second the value to be applied in case of true, and the third to be applied in case of false.
+
Sintaxe:
 +
  COUNT(<expressão>)  
 +
Exemplo:
 +
  '''COUNT("Produto")''' - Retorna o número de ocorrências (linhas) de produtos
  
Syntax:
+
==== Função COUNT_DISTINCT ====
  IF(<expression to be tested>; <expression if true>; <expression if false>)
 
Examples:
 
  '''IF(BETWEEN("Value";0;100);10;250)''' - If ''Value'' is between ''0'' and ''100'' returns ''10'', if not ''250''
 
  
  '''IF("Profit" == 0;0;"Profit" + "Taxes")''' - If ''Profit'' equals ''0'' returns ''0'', if it does not return the sum between ''Profit'' and ''Taxes''
+
Retorna o número de ocorrências únicas (linhas) de uma coluna ou valor.
  
 +
Por ora, esta função funciona apenas em expressões de Fontes de Dados
  
==== LOG function ====
+
Sintaxe:
 +
  COUNT_DISTINCT(<expressão>)
 +
Exemplo:
 +
  '''COUNT_DISTINCT("Produto")''' - Retorna o número de ocorrências únicas de produtos
  
Returns the logarithm of a number on a defined basis. It can be used with only one parameter, in this case the neperian (natural) logarithm is used . If two parameters are used, the second server to inform the base to be used by the logarithm.
+
==== Função IF ELSE (Se.... Senão...) ====
  
Syntax:
+
Testa uma expressão booleana e aplica uma condição em caso verdadeiro (true) ou outra condição nos casos de retornar falso (false). Precisa de três parâmetros, separados por ponto e virgula (;). O primeiro parâmetro é a expressão a ser testada, o segundo o valor a ser aplicado no caso de verdadeiro e o terceiro para ser aplicado no caso de falso.
  LOG(<expression>;<base>)
 
Examples:
 
  '''LOG("Profit")'''- Returns the logarithm of the field ''Profit''
 
  
   '''LOG("Price";2)''' - Returns the logarithm of the ''Price'' field in base ''2''
+
Sintaxe:
 +
   IF(<expressão a ser testada>; <expressão no caso de verdadeiro>; <expressão no caso de falso>)
 +
Exemplos:
 +
  '''IF(BETWEEN("Valor"; 0; 100); 10; 250)''' – Se o ''Valor'' estiver entre ''0'' e ''100'' retorna ''10'', se não retorna ''250''
 +
  '''IF("Lucro" == 0;0;"Lucro" + "Impostos")''' - Se ''Lucro'' igual a ''0'' retorna ''0'', senão retorna a soma de ''Lucro'' e ''Impostos''
 +
  '''IF("Código Produto" == 3231;0;"Quantidade" * 3;"Quantidade")''' - Se ''Código Produto'' igual a ''3231'' retorna ''Quantidade'' vezes 3
  
 +
==== Função LOG ====
  
==== MAX function ====
+
Retorna o logaritmo de um número em uma base definida. Pode ser utilizada com apenas um parâmetro, neste caso é utilizado o logaritmo na base 10. Caso seja utilizado dois parâmetros, o segundo serve para informar a base a ser utilizada pelo logaritmo.
  
Returns the largest value between two values.
+
Sintaxe:
 +
  LOG(<expressão>; <base>)
 +
Exemplos:
 +
  '''LOG("Lucro")''' – Retorna o logaritmo do campo ''Lucro''
 +
  '''LOG("Preço";2)''' - Retorna o logaritmo do campo ''Preço'' na base ''2''
  
Syntax:
 
  MAX(<expression 1>;<expression 2>)
 
Example:
 
  '''"Value" / MAX("Quantity";1)''' - Divides ''Value'' by the largest value between ''Quantity'' and ''1''
 
  
 +
==== Função MAX ====
  
==== MIN function ====
+
Retorna o maior valor entre dois valores.
  
Returns the smallest value between two values.
+
Sintaxe:
 +
  MAX(<expressão 1>; <expressão 2>)
 +
Exemplo:
 +
  '''"Valor" / MAX("Quantidade"; 1)''' – Divide o ''Valor'' pelo maior valor entre a ''Quantidade'' e ''1''
  
Syntax:
 
  MIN(<expression 1>; <expression 2>)
 
Example:
 
  '''"Value" / MIN("Cost"; 100)''' - Divides ''Value'' by the smallest value between ''Cost'' and ''100''
 
  
 +
==== Função MIN ====
  
==== POWER function ====
+
Retorna o menor valor entre dois valores.
  
Returns the power of a value in a defined exponent. It can be used with only one parameter, in this case it considers the default exponent 2. If a second parameter is passed, this will be the exponent.
+
Sintaxe:
 +
  MIN(<expressão 1>; <expressão 2>)
 +
Exemplo:
 +
  '''"Valor" / MIN("Custo"; 100)''' – Divide o ''Valor'' pelo menor valor entre ''Custo'' e ''100''
  
Syntax:
 
  POW(<expression>; <exponent>)
 
Examples:
 
  '''POW("Profit")''' - Returns the power of the ''Profit'' value.
 
  
  '''POW("Cost"; 3)''' - Returns the power of the ''Cost'' value, raised to ''3''
+
==== Função POTENCIA ====
  
 +
Retorna a potência de um valor em um expoente definido. Pode ser utilizada com apenas um parâmetro, neste caso considera o expoente padrão 2. Se um segundo parâmetro for passado, esse será o expoente.
  
==== RANDOM function ====
+
Sintaxe:
 +
  POW(<expressão>; <expoente>)
 +
Exemplos:
 +
  '''POW("Lucro")''' – Retorna a potência do valor ''Lucro''
 +
  '''POW("Custo"; 3)''' - Retorna a potência do calor ''Custo'' elevado na terceira
  
Returns a random number within the range of values ​​passed as arguments.
 
  
Syntax:
+
==== Função RANDOM ====
  RANDOM(<start limit>; <end limit>)
 
Example:
 
  '''RANDOM(10,100)''' - Returns a random number between ''10'' and ''100''
 
  
 +
Retorna um número aleatório dentro dos limites dos valores passados como argumentos.
  
==== SQRT function (Square Root) ====
+
Sintaxe:
 +
  RANDOM(<limite inicial>; <limite final>)
 +
Exemplo:
 +
  '''RANDOM(10; 100)''' – Retorna um número aleatório entre ''10'' e ''100''
  
Returns the square root of a value.
+
==== Função ROUND ====
  
Syntax:
+
Retorna o arredondamento de uma coluna de valor ou valor.
  SQRT(<value or expression>)
 
Examples:
 
  '''SQRT("Profit")''' - Returns the square root of the value ''Profit''
 
  
   '''SQRT(81)''' - Returns the square root of ''81''
+
Sintaxe:
 +
  ROUND(<valor>;<precisão>)
 +
Exemplo:
 +
   '''ROUND("Lucro")''' - Se lucro for 10.38 retorna 10.00
 +
  '''ROUND(15.65)''' - Retorna 16.00
 +
  '''ROUND(1.777;1)''' - Retorna 1.8
  
 +
==== Função SQRT (Raiz Quadrada) ====
  
==== LIKE function ====
+
Retorna a raiz quadrada de um valor.
  
Returns true if the desired content is found in the list and false otherwise. It needs two parameters, the first is the data to query and the second is the term to be found. Remembering that it is necessary to use the wildcard operator “%” and surround the term by single quotation mark.
+
Sintaxe:
 +
  SQRT(<valor ou expressão>)
 +
Exemplos:
 +
  '''SQRT("Lucro")''' – Retorna a raiz quadrada do valor ''Lucro''
 +
  '''SQRT(81)''' - Retorna a raiz quadrada de ''81''
  
Syntax:
 
  LIKE(< data>; <term>)
 
Example:
 
  '''LKE("Product"; '%anh%')''' - Returns true if the ''Product'' contains the term ''anh'' or false otherwise
 
  
 +
==== Função LIKE (Contém) ====
  
== Date Functions ==
+
Retorna verdadeiro (true) se o conteúdo desejado for encontrado na lista e falso (false) caso contrário. Precisa de dois parâmetros, o primeiro são os dados que serão consultados e o segundo é o termo a ser encontrado. Lembrando que é necessário utilizar o operador de curinga ''%'' e circundar o termo por aspa simples.
  
Date functions are operations that take a date as a parameter and also return a date. There are some constants to assist in using date functions, they are:
+
Sintaxe:
 +
  LIKE(<dados>; <termo>)
 +
Exemplo:
 +
  '''LIKE("Produto"; '%anh%')''' – Retorna true se o ''Produto'' contém o termo ''anh'' ou false caso contrário
 +
  '''LIKE("Produto"; '%anh%')''' - Retorna verdadeiro se o ''Produto'' conter a string ''anh'', caso contrário falso
  
* 0: ''DATE_FIELD_YEAR'' (Part of the year)
+
== Funções de Data ==
* 1: ''DATE_FIELD_MONTH'' (Month Part)
 
* 2: ''DATE_FIELD_DAY'' (Daypart)
 
* 3: ''DATE_FIELD_FORTNIGHT'' (Part of fortnight)
 
* 5: ''DATE_FIELD_WEEK'' (Part of the Week)
 
  
 +
As funções de data são operações que usam como parâmetro uma data e retornam também uma data. Existem algumas constantes para auxiliar na utilização das funções de data, são elas:
  
==== DATE_PART function (Date Part) ====
+
* 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)
  
Returns part of a date. It needs two parameters, the first is the reference date and the second is the constant that represents which part of the date we want to get.
 
  
Syntax:
+
==== Função DATE_PART (Parte da data) ====
  DATE_ PART(<date>; <constant representing which part>)
 
Example:
 
  '''DATE_ PART("Issued Date"; 0)''' - Returns the year portion of the ''Issued Date''
 
  
 +
Retorna parte de uma data. Precisa de dois parâmetros, o primeiro é a data de referência e o segundo é a constante que representa qual parte da data queremos obter.
  
==== DAY_FROM_TODAY function (Days from today) ====
+
Sintaxe:
 +
  DATE_PART(< data>; <constante que representa qual parte>)
 +
Exemplo:
 +
  '''DATE_PART("Data Emissão"; 0)'''  - retorna a parte do ano da ''Data Emissão''
  
Returns a days count backward (negative) or forward (positive) from today. You need a parameter that indicates the number of days to add or subtract.
 
  
Syntax:
+
==== Função DAY_FROM_TODAY (Dias a partir de hoje) ====
  DAY_FROM_TODAY(<number of days>)
 
Example:
 
  '''DAY_FROM_TODAY(-1)''' - Returns yesterday's date
 
  
 +
Retorna uma contagem de dias para trás (negativa) ou para frente (positiva) contando a partir de hoje. Precisa de um parâmetro que indica o número de dias para adicionar ou subtrair.
  
==== FIRST_DAY_OF function (First day of) ====
+
Sintaxe:
 +
  DAY_FROM_TODAY(<número de dias>)
 +
Exemplo:
 +
  '''DAY_FROM_TODAY(-1)''' - retorna a data de ontem
  
Returns the first day of a grouping. This function has two variations:
 
  
* With two parameters, the first is the grouping constant from which we want to get the first date (see list above), and the second is the base date.
+
==== Função FIRST_DAY_OF (Primeiro dia de) ====
  
Syntax:  
+
Retorna o primeiro dia de um agrupamento. Esta função possui duas variações:
  FIRST_DAY_OF(<date part>; <base date>)
 
Examples:
 
  '''FIRST_DAY_OF(0;DAY_FROM_TODAY(0))''' - Returns the first day of the year from today
 
  
  '''FIRST_DAY_OF(1;"Issue Date")''' - First Day of Month Based on ''Issue Date'' Column
+
* Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), e o segundo é a data base.
  
* With three parameters, the first is the grouping constant from which we want to get the first date (see list above), the second is the date base modifier from today, and the third is the amount to change the modifier.
+
Sintaxe:
 +
  FIRST_DAY_OF(<parte da data>; < data base>)
 +
Exemplos:
 +
  '''FIRST_DAY_OF(0; DAY_FROM_TODAY(0))''' – retorna o primeiro dia do ano a partir de hoje
 +
  '''FIRST_DAY_OF(1;"Data Problema")''' - retorna o primeiro dia baseado na coluna ''Data Problema''
  
Syntax:
+
* Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.
  FIRST_DAY_OF(<date part>;<date modifier>;<date modifier value>)
 
Example:
 
  '''FIRST_DAY_OF(1,0,-1)''' - first day of current month of last year
 
  
 +
Sintaxe:
 +
  FIRST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)
 +
Exemplo:
 +
  '''FIRST_DAY_OF(1; 0; -1)''' – primeiro dia do mês atual do último ano
  
==== LAST_DAY_OF function (Last day of) ====
 
  
Returns the last day of a date grouping. This function has two variations.
+
==== Função LAST_DAY_OF (Último dia de) ====
  
* With two parameters, the first is the grouping constant from which we want the last date (see list above), and the second is the base date.
+
Retorna o último dia de um agrupamento de data. Esta função possui duas variações.
  
Syntax:
+
* Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), e o segundo é a data base.
  LAST_DAY_OF(<date part>; <base date>)
 
Examples:
 
  '''LAST_DAY_OF(0;DAY_FROM_TODAY(0))''' - Returns the last day of the year from today.
 
  
   '''LAST_DAY_OF(1;"Date Issued")''' - Last day of month based on ''Date Issued'' column
+
Sintaxe:
 +
   LAST_DAY_OF(<parte da data>; < data base>)
 +
Exemplos:
 +
  '''LAST_DAY_OF(0; DAY_FROM_TODAY(0))''' – retorna o último dia do ano a partir de hoje
 +
'''LAST_DAY_OF(1;"Date Problema")''' - retorna o último dia do mês baseado na coluna ''Data Problema''
  
* With three parameters, the first is the grouping constant from which we want the last date (see list above), the second is the date base modifier from today, and the third is the amount to change the modifier.
+
* Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.
  
Syntax:  
+
Sintaxe:
   LAST_DAY_OF(<date part>;<date modifier>;<date modifier value>)
+
   LAST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)
Example:  
+
Exemplo:
   '''LAST_DAY_OF(1,0,-1)''' - last day of current month of last year
+
   '''LAST_DAY_OF(1; 0; -1)''' – último dia do mês atual do último ano
  
  
==== NEW_DATE function (New date) ====
+
==== Função NEW_DATE (Nova data) ====
  
Creates a new date. It needs three parameters, the first corresponds to the day (between 1 and 31), the second month (between 1 and 12) and the third the year. The date is created from year to day, ie the day must be valid for the month and year (considering 29/02, the year must be leap).
+
Cria uma nova data. Precisa de três parâmetros, o primeiro corresponde ao dia (entre 1 e 31), o segundo mês (entre 1 e 12) e o terceiro o ano. A data é criada do ano para o dia, ou seja, o dia deve ser válido para o mês e ano (considerando 29/02, o ano deve ser bissexto).
  
Syntax:  
+
Sintaxe:
   NEW_DATE(<day>;<month>;<year>)
+
   NEW_DATE(<dia>; <mês>; <ano>)
Example:  
+
Exemplo:
   '''NEW_DATE(1;4;DATE_PART("Issued Date";0))''' - Creates the first April day of the year determined by the current row in the ''Issued Date'' column.
+
   '''NEW_DATE(1; 4; DATE_PART("Data Emissão"; 0))''' – cria o primeiro dia de abril do ano determinado pela linha atual da coluna ''Data Emissão''
  
  
==== NUM_OF_DAYS function (Number of days) ====
+
==== Função NUM_OF_DAYS (Número de dias) ====
  
Returns the number of days between two dates. Therefore you need two dates.
+
Retorna o número de dias entre duas datas. Portanto necessita de duas datas.
  
Syntax:  
+
Sintaxe:
   NUM_OF_DAYS(<date 1>; <date 2>)
+
   NUM_OF_DAYS(< data 1>; < data 2>)
Examples:
+
Exemplos:
   '''NUM_OF_DAYS(FIRST_DAY_OF(0;"Issued Date");"Issued Date")''' - Returns the number of days from the first day of the year, based on the ''Issued Date'' column, to the current day, based on the same column.
+
   '''NUM_OF_DAYS(FIRST_DAY_OF(0; "Data Emissão"); "Data Emissão")''' – retorna o número de dias entre o primeiro dia do ano, baseado na coluna ''Data Emissão'', até o dia atual, baseado na mesma coluna
 +
  '''NUM_OF_DAYS(FIRST_DAY_OF(1;"Data Pedido");LAST_DAY_OF(1;"Data Pedido"))''' - retorna o número de dias do mês baseado na coluna ''Data Pedido''.
  
  '''NUM_OF_DAYS(FIRST_DAY_OF(1;"Issued Date");LAST_DAY_OF(1,"Issued Date"))''' - Returns the number of days of the month, based on the ''Issued Date'' column.
 
  
 +
==== Função NUM_OF_MONTHS (Número de Meses) ====
  
==== NUM_OF_MONTHS function (Number of months) ====
+
Retorna o número de meses entre duas datas. Logo, dois parâmetros data são exigidos.
  
Returns the number of months between two dates. Therefore, two date parameters are required.
+
Sintaxe:
 +
  NUM_OF_MONTHS(< data 1>; < data 2>)
 +
Exemplo:
 +
  '''NUM_OF_MONTHS(FIRST_DAY_OF(0; "Data"); "Data")''' – Retorna o número de meses entre o primeiro dia do ano e o mês atual, com base na coluna ''Data''
  
Syntax:
 
  NUM_OF_MONTHS(<date 1>; <date 2>)
 
Example:
 
  '''NUM_OF_MONTHS(FIRST_DAY_OF(0; "Date"); "Date")''' - Returns the number of months between the first day of the year and the current month, based on the ''Date'' column.
 
  
 +
==== Função PREVIOUS_DATE (Data anterior) ====
  
==== PREVIOUS_DATE function (Previous date) ====
+
Dado um dia e um mês, retorna a última ocorrência dessa data. Ou seja, se a data atual (hoje) for menor do que a data passada por parâmetro (dia/mês), o retorno será a data (passada por parâmetro) do ano anterior. Se não o retorno será a data do ano atual.
  
Given a day and a month, returns the last occurrence of that date. That is, if the current date (today) is less than the date passed by parameter (day / month), the return is the date (passed by parameter) of the previous year. Otherwise the return will be the current year date.
+
Sintaxe:
 
+
   PREVIOUS_DATE(<dia>; <mês>)
Syntax:  
+
Exemplos:
   PREVIOUS_DATE(<day>; <month>)
+
   '''PREVIOUS_DATE(15;12)''' – Considerando que a data de hoje seja 14/11/2019, a última vez que 15/Dezembro ocorreu em relação a data de hoje foi 15/12/2018, logo esse será o retorno.
Examples:  
 
   '''PREVIOUS_DATE(15;12)''' - Considering that today's date is 14/11/2019, the last time December 15th occurred relative to today's date was 15/12/2018, so this will be the return.
 
  
  
== Special Variables ==
+
== Variáveis Especiais ==
  
They can be used in conjunction with expressions to create complex calculations. Must be used in double quotation marks ()
+
Podem ser usadas em conjunto com as expressões para criar cálculos complexos. Devem ser utilizadas entre aspas duplas ('''"''')
  
  
* '''"@count"''' - Total number of rows that were returned for the component.
+
* '''"@count"''' – Número total de linhas que foram retornadas para o componente
* '''"@row"''' - Current row number
+
* '''"@row"''' – Número da linha atual
* '''"@sum[column]"''' - Sum of the indicated column.
+
* '''"@sum[coluna]"''' – Somatório da coluna indicada.
** Example: ''"@sum[Price]"'' - returns the sum of all rows in the ''Price'' column.
+
** Exemplo: ''"@sum[Preço]"'' – retorna a soma de todas as linhas da coluna ''Preço''
* '''"@avg[column]"''' - Average column, similar to ''"@sum[column]"'' / ''"@count"''
+
* '''"@avg[coluna]"''' – Média da coluna, semelhante a ''"@sum[coluna]"'' / ''"@count"''
* '''"@prev[column]"''' - Row value before current row for this column
+
* '''"@prev[coluna]"''' – Valor da linha anterior à linha atual, para essa coluna
* '''"@accumCol[column]"''' - Cumulative value from column to current row. Useful for calculating variable mean.
+
* '''"@totalRowValue[coluna]"''' - Valor da Linha de Total, (se presente), para essa coluna.
** Example: ''"@accumCol[column]"'' / ''"@row"''
+
* '''"@accumCol[coluna]"''' – Valor acumulado da coluna até a linha corrente. Útil para calcular média variável.  
 +
** Exemplo: ''"@accumCol[coluna]"'' / ''"@row"''

Latest revision as of 03:20, 5 October 2022

Other languages:
English • ‎português do Brasil


É possível criar expressões (fórmulas) diretamente nos componentes dos painéis. Podendo assim exibir valores calculados que não estão presentes no arquivo/planilha de origem dos dados.


Para criar as expressões (fórmulas) nos componentes, é necessário que o componente suporte à adição da coluna especial Expressão (Fórmula).


No TaticView, é possível utilizar nas expressões todas as colunas existentes no arquivo de dados, desde que estes sejam adicionados ao componente que receberá a expressão.


Além disso, também é possível utilizar números e textos fixos nos casos de expressões comparativas e ou cálculos matemáticos.


Exemplo de expressão:

  • Se o componente possui as colunas Preço Total e Quantidade, pode-se criar uma expressão para calcular o Preço Unitário. Ficaria assim:
    • "Preço Total" / "Quantidade"
  • Além disso, pode-se utilizar valores fixos, como por exemplo:
    • "Preço Total" / 10


Lembramos apenas que atualmente o TaticView suporta apenas expressões cujo retorno é numérico.


As expressões suportam a barra inversa como caractere de escape para que nomes possam conter os caracteres delimitadores.

Abaixo detalhes sobre o funcionamento das expressões.

Estrutura básica de uma expressão

Identificador

É o nome do campo ou coluna envolvido na expressão, deve ser delimitado por aspas duplas.

  • Exemplos: "Preço médio", "Parafuso 1\" philips", "Vendedor"

Operando de Valor

São os valores numéricos. É possível utilizar tanto valores inteiros quanto valores decimais. Para valores decimais, o separador decimal deverá ser o ponto.

  • Exemplos: 1, 1.05, 2.55
  • Importante: Não é permitido usar separador de milhar nos valores, assim como "," como separador decimal.

Operando de Texto

São os operandos de texto. Para utilizar esse tipo de operando em uma expressão é necessário delimita-los pelo caractere aspa simples (').

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


Operando de Data

São valores que expressam qualquer data. Para representar uma data nas expressões o comportamento é semelhante aos operandos de texto, ou seja, o conteúdo deve ser circundado por aspa simples ('). Porém deve-se utilizar a máscara dd/MM/aaaa.

  • Exemplos: '01/01/2019', '14/11/2019', '25/12/2019'


Operando Booleano

São operadores do tipo verdadeiro ou falso. Normalmente utilizados para validar, ou não, uma condição em uma expressão mais complexa.

  • Exemplos: true, false


Parênteses

Utilizados para agrupar e separar partes de uma expressão. Expressões dentro de parênteses são processados antes das demais.

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


Operando de variável do sistema

São variáveis pré-definidas no sistema. Para utilizar as variáveis do sistema deve-se precede-las por hashtag (#) e delimita-las por aspas duplas ("). Atualmente apenas a variável "#null" está disponível e indica conteúdos nulos.

  • Exemplo: IF("Produto" == "#null";0;20)

Expressões Aritméticas

As expressões aritméticas relacionam dois operandos (que pode ser qualquer um dos operandos descritos acima, ou ainda outra expressão) para compor a soma, subtração, multiplicação ou divisão.


Soma (+)

Soma dois operandos de valor. Representado pelo caractere +.

Sintaxe:

 <operando ou expressão> + <operando ou expressão>

Exemplo:

 "Impostos" + "Comissões" – Soma os valores dos campos Impostos e Comissões


Subtração (-)

Subtrai dois operandos de valor ou o resultado de outra expressão. Representado pelo caractere -.

Sintaxe:

 <operando ou expressão> - <operando ou expressão>

Exemplo:

 "Preço" - "Impostos" – Subtrai os valores dos campos Preço e Impostos


Multiplicação (*)

Multiplica dois operandos de valor ou resultados de outra expressão. Representado pelo caractere de multiplicação *.

Sintaxe:

 <operando ou expressão> * <operando ou expressão>

Exemplo:

 "Quantidade" * "Preço Unitário" – Multiplica o valor do campo Quantidade pelo valor do campo Preço Unitário


Divisão (/)

Divide dois operandos de valor ou resultado de outras expressões. Representada pelo caractere de divisão /.

Sintaxe:

 <operando ou expressão> / <operando ou expressão>

Exemplo:

 "Preço" / "Quantidade" – Divide o valor do campo Preço pelo valor do campo Quantidade


Expressões Relacionais

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


Igualdade (==)

Compara se dois operandos são iguais, retornando true se forem iguais ou false se diferentes. Representado pelo operador de igualdade ==.

Sintaxe:

 <operando ou expressão> == <operando ou expressão>

Exemplo:

 IF("Produto" == "#null";0;20) – Se o produto for nulo, considera o valor 0. Caso contrário considera o valor 20


Diferente (!=)

Compara se dois operandos são diferentes, retornando true se foram diferentes ou false se iguais. Representado pelo operador de diferença !=.

Sintaxe:

 <operando ou expressão> != <operando ou expressão>

Exemplo:

 IF("Produto" != 'LASANHA';0;20) – Se o produto for diferente de Lasanha, considera o valor 0. Caso contrário considera o valor 20


Maior que (>)

Compara se o primeiro operador (da esquerda) é maior que o segundo operador (da direita), retornando true se for maior e false se for menor ou igual. Representado pelo operador maior >.

Sintaxe:

 <operando ou expressão> > <operando ou expressão>

Exemplo:

 IF("Valor Bruto" > 1000;1;0) – Se o Valor Bruto for maior que 1000, retorna o valor 1, se não o valor 0


Maior ou igual a (>=)

Compara se o primeiro operador (da esquerda) é maior ou igual ao segundo operador (da direita), retornando true se for maior ou igual e false se for menor. Representado pelo operador maior >=.

Sintaxe:

 <operando ou expressão> >= <operando ou expressão>

Exemplo:

 IF("Valor Bruto" >= 2500;100;0) – Se o Valor Bruto for maior ou igual a 2500 retorna 100, caso contrário retorna 0


Menor que (<)

Compara se o primeiro operador (da esquerda) é menor que o segundo operador (da direita), retornando true se for menor e false se for maior ou igual. Representado pelo operador maior <.

Sintaxe:

 <operando ou expressão> < <operando ou expressão>

Exemplo:

 IF("Valor Bruto" < 100;50;200) – Se o Valor Bruto for menor que 100, retorna 50, se não retorna 200


Menor ou igual a (<=)

Compara se o primeiro operador (da esquerda) é menor ou igual ao segundo operador (da direita), retornando true se for menor ou igual e false se for maior. Representado pelo operador maior <=.

Sintaxe:

 <operando ou expressão> <= <operando ou expressão>

Exemplo:

 IF("Valor Bruto" <= 500;100;0) – Se o Valor Bruto for menor ou igual a 500 retorna 100, se não retorna 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 verdadeiro (true) ou falso (false). Normalmente esse tipo de expressão é utilizada para tomadas de decisão, como o IF (Se) e com expressões relacionais.


Operador E (&&)

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

Sintaxe:

 <expressão> && <expressão>

Exemplos:

 IF(("Preço" > 0) && ("Vendedor" == 'André Moraes');450;0) – Se o Preço for maior que 0 E o Vendedor for igual a André Moraes, retorna 450, se não retorna 0
 IF(("Cidade" != "#null") && ("Produto" != 'Lasanha');1;0) – Se a Cidade for diferente de nula E o Produto for diferente de Lasanha retorna 1, se não retorna 0


Operador Ou (||)

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

Sintaxe:

 <expressão> || <expressão>

Exemplos:

 IF(("Preço" > 1000) || ("Lucro" >= 50);75;55) – Se o Preço for maior que 1000 OU o Lucro for maior ou igual a 50 retorna 75, se não retorna 55
 IF(("Cidade" != "#null") || ("Produto" != 'Lasanha');1;0) - Se Cidade não for null OU Produto deferente de Lasanha returna 1 senão retorna 0


Operador de Negação (!)

Executa a operação lógica de negação para um valor booleano. Se o resultado da operação for verdadeiro (true) o operador de negação converte para falso (false) e vice-versa. Representado pelo operador !.

Sintaxe:

 !<expressão>

Exemplo:

 IF(!BETWEEN("Data Entrega"; '01/01/2015'; '31/12/2015');2016; 2015) – Se a Data Entrega não tiver entre 01/01/2015 e 31/12/2015 retorna 2016. Se estiver entre esse período retorna 2015


Funções Auxiliares

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


Função ABS

Função que retorna o valor numérico absoluto de um valor numérico base.

Sintaxe:

 ABS(<expressão>)

Exemplo:

 ABS("Preço" / "Quantidade") – Retorna o valor absoluto do Preço divido pela Quantidade


Função AVG

Retorna a média dos valores de uma sequência de valores. Pode ser utilizado para retornar a média de diferentes valores de uma mesma linha das tabelas.

Sintaxe:

 AVG(<expressão 1>; <expressão 2>; ...)

Exemplo:

 AVG("Impostos"; "Lucro"; "Custo") – Retorna a média entre a soma das colunas Impostos, Lucro e Custo


Função BETWEEN (Entre)

Verifica se um valor está estre os limites dos parâmetros utilizados.

Sintaxe:

 BETWEEN(<expressão a ser testada>; <limite inicial>; <limite final>)

Exemplo:

 BETWEEN("Data Emissão"; '01/01/2019'; '31/12/2019') – Retorna true se a Data Emissão estiver entre 01/01/2019 e 31/12/2019. Caso contrário retorna false

Função COUNT

Retorna o número de ocorrências (linhas) de uma coluna ou valor.

Por ora, esta função funciona apenas em expressões de Fontes de Dados

Sintaxe:

 COUNT(<expressão>) 

Exemplo:

 COUNT("Produto") - Retorna o número de ocorrências (linhas) de produtos

Função COUNT_DISTINCT

Retorna o número de ocorrências únicas (linhas) de uma coluna ou valor.

Por ora, esta função funciona apenas em expressões de Fontes de Dados

Sintaxe:

 COUNT_DISTINCT(<expressão>) 

Exemplo:

 COUNT_DISTINCT("Produto") - Retorna o número de ocorrências únicas de produtos

Função IF ELSE (Se.... Senão...)

Testa uma expressão booleana e aplica uma condição em caso verdadeiro (true) ou outra condição nos casos de retornar falso (false). Precisa de três parâmetros, separados por ponto e virgula (;). O primeiro parâmetro é a expressão a ser testada, o segundo o valor a ser aplicado no caso de verdadeiro e o terceiro para ser aplicado no caso de falso.

Sintaxe:

 IF(<expressão a ser testada>; <expressão no caso de verdadeiro>; <expressão no caso de falso>)

Exemplos:

 IF(BETWEEN("Valor"; 0; 100); 10; 250) – Se o Valor estiver entre 0 e 100 retorna 10, se não retorna 250
 IF("Lucro" == 0;0;"Lucro" + "Impostos") - Se Lucro igual a 0 retorna 0, senão retorna a soma de Lucro e Impostos
 IF("Código Produto" == 3231;0;"Quantidade" * 3;"Quantidade") - Se Código Produto igual a 3231 retorna Quantidade vezes 3

Função LOG

Retorna o logaritmo de um número em uma base definida. Pode ser utilizada com apenas um parâmetro, neste caso é utilizado o logaritmo na base 10. Caso seja utilizado dois parâmetros, o segundo serve para informar a base a ser utilizada pelo logaritmo.

Sintaxe:

 LOG(<expressão>; <base>)

Exemplos:

 LOG("Lucro") – Retorna o logaritmo do campo Lucro
 LOG("Preço";2) - Retorna o logaritmo do campo Preço na base 2


Função MAX

Retorna o maior valor entre dois valores.

Sintaxe:

 MAX(<expressão 1>; <expressão 2>)

Exemplo:

 "Valor" / MAX("Quantidade"; 1) – Divide o Valor pelo maior valor entre a Quantidade e 1


Função MIN

Retorna o menor valor entre dois valores.

Sintaxe:

 MIN(<expressão 1>; <expressão 2>)

Exemplo:

 "Valor" / MIN("Custo"; 100) – Divide o Valor pelo menor valor entre Custo e 100


Função POTENCIA

Retorna a potência de um valor em um expoente definido. Pode ser utilizada com apenas um parâmetro, neste caso considera o expoente padrão 2. Se um segundo parâmetro for passado, esse será o expoente.

Sintaxe:

 POW(<expressão>; <expoente>)

Exemplos:

 POW("Lucro") – Retorna a potência do valor Lucro
 POW("Custo"; 3) - Retorna a potência do calor Custo elevado na terceira


Função RANDOM

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

Sintaxe:

 RANDOM(<limite inicial>; <limite final>)

Exemplo:

 RANDOM(10; 100) – Retorna um número aleatório entre 10 e 100

Função ROUND

Retorna o arredondamento de uma coluna de valor ou valor.

Sintaxe:

 ROUND(<valor>;<precisão>)

Exemplo:

 ROUND("Lucro") - Se lucro for 10.38 retorna 10.00
 ROUND(15.65) - Retorna 16.00
 ROUND(1.777;1) - Retorna 1.8

Função SQRT (Raiz Quadrada)

Retorna a raiz quadrada de um valor.

Sintaxe:

 SQRT(<valor ou expressão>)

Exemplos:

 SQRT("Lucro") – Retorna a raiz quadrada do valor Lucro
 SQRT(81) - Retorna a raiz quadrada de 81


Função LIKE (Contém)

Retorna verdadeiro (true) se o conteúdo desejado for encontrado na lista e falso (false) caso contrário. Precisa de dois parâmetros, o primeiro são os dados que serão consultados e o segundo é o termo a ser encontrado. Lembrando que é necessário utilizar o operador de curinga % e circundar o termo por aspa simples.

Sintaxe:

 LIKE(<dados>; <termo>)

Exemplo:

 LIKE("Produto"; '%anh%') – Retorna true se o Produto contém o termo anh ou false caso contrário
 LIKE("Produto"; '%anh%') - Retorna verdadeiro se o Produto conter a string anh, caso contrário falso

Funções de Data

As funções de data são operações que usam como parâmetro uma data e retornam também uma data. Existem algumas constantes para auxiliar na utilização das funções de data, são elas:

  • 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)


Função DATE_PART (Parte da data)

Retorna parte de uma data. Precisa de dois parâmetros, o primeiro é a data de referência e o segundo é a constante que representa qual parte da data queremos obter.

Sintaxe:

 DATE_PART(< data>; <constante que representa qual parte>)

Exemplo:

 DATE_PART("Data Emissão"; 0)  - retorna a parte do ano da Data Emissão


Função DAY_FROM_TODAY (Dias a partir de hoje)

Retorna uma contagem de dias para trás (negativa) ou para frente (positiva) contando a partir de hoje. Precisa de um parâmetro que indica o número de dias para adicionar ou subtrair.

Sintaxe:

 DAY_FROM_TODAY(<número de dias>)

Exemplo:

 DAY_FROM_TODAY(-1) - retorna a data de ontem


Função FIRST_DAY_OF (Primeiro dia de)

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

  • Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), e o segundo é a data base.

Sintaxe:

 FIRST_DAY_OF(<parte da data>; < data base>)

Exemplos:

 FIRST_DAY_OF(0; DAY_FROM_TODAY(0)) – retorna o primeiro dia do ano a partir de hoje
 FIRST_DAY_OF(1;"Data Problema") - retorna o primeiro dia baseado na coluna Data Problema
  • Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.

Sintaxe:

 FIRST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)

Exemplo:

 FIRST_DAY_OF(1; 0; -1) – primeiro dia do mês atual do último ano


Função LAST_DAY_OF (Último dia de)

Retorna o último dia de um agrupamento de data. Esta função possui duas variações.

  • Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), e o segundo é a data base.

Sintaxe:

 LAST_DAY_OF(<parte da data>; < data base>)

Exemplos:

 LAST_DAY_OF(0; DAY_FROM_TODAY(0)) – retorna o último dia do ano a partir de hoje
LAST_DAY_OF(1;"Date Problema") - retorna o último dia do mês baseado na coluna Data Problema
  • Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.

Sintaxe:

 LAST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)

Exemplo:

 LAST_DAY_OF(1; 0; -1) – último dia do mês atual do último ano


Função NEW_DATE (Nova data)

Cria uma nova data. Precisa de três parâmetros, o primeiro corresponde ao dia (entre 1 e 31), o segundo mês (entre 1 e 12) e o terceiro o ano. A data é criada do ano para o dia, ou seja, o dia deve ser válido para o mês e ano (considerando 29/02, o ano deve ser bissexto).

Sintaxe:

 NEW_DATE(<dia>; <mês>; <ano>)

Exemplo:

 NEW_DATE(1; 4; DATE_PART("Data Emissão"; 0)) – cria o primeiro dia de abril do ano determinado pela linha atual da coluna Data Emissão


Função NUM_OF_DAYS (Número de dias)

Retorna o número de dias entre duas datas. Portanto necessita de duas datas.

Sintaxe:

 NUM_OF_DAYS(< data 1>; < data 2>)

Exemplos:

 NUM_OF_DAYS(FIRST_DAY_OF(0; "Data Emissão"); "Data Emissão") – retorna o número de dias entre o primeiro dia do ano, baseado na coluna Data Emissão, até o dia atual, baseado na mesma coluna
 NUM_OF_DAYS(FIRST_DAY_OF(1;"Data Pedido");LAST_DAY_OF(1;"Data Pedido")) - retorna o número de dias do mês baseado na coluna Data Pedido.


Função NUM_OF_MONTHS (Número de Meses)

Retorna o número de meses entre duas datas. Logo, dois parâmetros data são exigidos.

Sintaxe:

 NUM_OF_MONTHS(< data 1>; < data 2>)

Exemplo:

 NUM_OF_MONTHS(FIRST_DAY_OF(0; "Data"); "Data") – Retorna o número de meses entre o primeiro dia do ano e o mês atual, com base na coluna Data


Função PREVIOUS_DATE (Data anterior)

Dado um dia e um mês, retorna a última ocorrência dessa data. Ou seja, se a data atual (hoje) for menor do que a data passada por parâmetro (dia/mês), o retorno será a data (passada por parâmetro) do ano anterior. Se não o retorno será a data do ano atual.

Sintaxe:

 PREVIOUS_DATE(<dia>; <mês>)

Exemplos:

 PREVIOUS_DATE(15;12) – Considerando que a data de hoje seja 14/11/2019, a última vez que 15/Dezembro ocorreu em relação a data de hoje foi 15/12/2018, logo esse será o retorno.


Variáveis Especiais

Podem ser usadas em conjunto com as expressões para criar cálculos complexos. Devem ser utilizadas entre aspas duplas (")


  • "@count" – Número total de linhas que foram retornadas para o componente
  • "@row" – Número da linha atual
  • "@sum[coluna]" – Somatório da coluna indicada.
    • Exemplo: "@sum[Preço]" – retorna a soma de todas as linhas da coluna Preço
  • "@avg[coluna]" – Média da coluna, semelhante a "@sum[coluna]" / "@count"
  • "@prev[coluna]" – Valor da linha anterior à linha atual, para essa coluna
  • "@totalRowValue[coluna]" - Valor da Linha de Total, (se presente), para essa coluna.
  • "@accumCol[coluna]" – Valor acumulado da coluna até a linha corrente. Útil para calcular média variável.
    • Exemplo: "@accumCol[coluna]" / "@row"