GERADOR DE SAIDAS - V12 - AP02 Ok
GERADOR DE SAIDAS - V12 - AP02 Ok
GERADOR DE SAIDAS - V12 - AP02 Ok
Proibida a reprodução total ou parcial, bem como a armazenagem em sistema de recuperação e a transmissão, de qualquer
modo ou por qualquer outro meio, seja este eletrônico, mecânico, de fotocópia, de gravação, ou outros, sem prévia autorização
por escrito da proprietária.
O desrespeito a essa proibição configura em apropriação indevida dos direitos autorais e patrimoniais da TOTVS.
Conforme artigos 122 e 130 da LEI no. 5.988 de 14 de Dezembro de 1973.
Gerador de Saídas
RM – Versão 12
Sumário
1. Objetivo......................................................................................................................................... 4
2. Introdução ..................................................................................................................................... 5
3. Principais Conceitos ..................................................................................................................... 5
3.1. O que é layout ........................................................................................................................... 5
3.2. O que é arquivo ......................................................................................................................... 6
3.3. O que é registro ......................................................................................................................... 7
3.4. O que é campo .......................................................................................................................... 8
3.5. O que é contexto ....................................................................................................................... 8
4. Importante..................................................................................................................................... 9
5. Configuração em ambiente 3 camadas ........................................................................................ 9
6. Acessando o RM Gerador de Saídas ........................................................................................... 10
7. Categoria de Layout ..................................................................................................................... 12
8. Tipo de Layout .............................................................................................................................. 15
9. Comparação ................................................................................................................................. 17
10. Executar...................................................................................................................................... 19
11. Layouts ....................................................................................................................................... 21
11.1. Criando Layout ........................................................................................................................ 21
11.2. Construindo e Configurando Layout ........................................................................................ 23
11.2.1. Formatação Padrão........................................................................................................................ 24
11.2.1.1. Texto ............................................................................................................................ 24
11.2.1.2. Número Inteiro ............................................................................................................. 24
11.2.1.3. Número Decimal .......................................................................................................... 25
11.2.1.3. Data ............................................................................................................................. 26
11.2.1.4. Lógico .......................................................................................................................... 26
11.3. Adicionando Arquivo ao Layout ............................................................................................... 27
11.4. Adicionando Registros ao Layout ............................................................................................ 28
11.5. Adicionando Contexto ao Layout ............................................................................................. 31
11.6. Tipos de Contexto: ................................................................................................................... 32
11.6.1. Classe RM.NET:............................................................................................................................. 32
11.6.1.1. Consulta SQL: ............................................................................................................. 33
11.6.1.2. Cadastro do Sistema (Tela do Sistema): ..................................................................... 35
11.6.1.3. Contexto da Aplicação: ................................................................................................ 36
11.6.1.4. Conjunto de Dados: ..................................................................................................... 39
11.6.1.5. Contadores: ................................................................................................................. 42
11.6.1.6. Stored Procedure:........................................................................................................ 44
11.6.1.7. Criação de Layout do Gerador de Saídas com Parâmetros ........................................ 46
11.6.1.8. Operações com Layout ................................................................................................ 50
2
Gerador de Saidas
3
Gerador de Saidas
1. Objetivo
O Curso RM Gerador de Saídas visa apresentar as funcionalidades dessa ferramenta, bem como orientar no
desenvolvimento de layouts em .txt.
Conceitos Básicos:
Layout.
Arquivo.
Registro.
Campo.
Contexto
Inclusão de um layout
Configuração do layout
Classe RM.NET.
Consulta SQL.
Cadastro do Sistema.
Contexto da Aplicação.
Parâmetros da Geração.
Conjunto de Dados.
Contadores.
Stored Procedure.
4
Gerador de Saidas
2. Introdução
O que é Gerador de Saídas?
O Gerador de Saídas é uma ferramenta criada para exportar de qualquer módulo do RM através de arquivo texto.
Inicialmente a ferramenta foi desenvolvida para ser utilizada pelo Gestão Fiscal onde as rotinas são todas geradas no
formato texto.
Disponibilidade
O Gerador de Saídas só está disponível a partir da versão 11.40 podendo ser acessado pela nova MDI. Em versões
anteriores a 11.40 é possível executar somente o serviço, não sendo possível a criação e edição dos layouts. O
Gerador de Saídas, hoje, se encontra disponível somente no módulo Fiscal e de integração. Estuda-se a possibilidade
desta exportação ser feita em outros formatos, como o XML por exemplo.
3. Principais Conceitos
Este material didático foi desenvolvido seguindo uma ordem que facilita o aprendizado. Mostraremos a sequência em
que desenvolvemos um layout, iniciando da maneira mais simples e ao decorrer das lições incrementando recursos
mais complexos.
Antes de iniciar
Antes de criar um layout temos que nos atentar para um detalhe muito importante: Nunca inicie o desenvolvimento de
um layout se você não estiver seguro de que sabe exatamente o que o layout deve conter e de que forma este deve
mostrar as informações.
Esclareça todas as dúvidas antes de iniciar o desenvolvimento do layout, desta forma podemos evitar retrabalhos. Após
ter conhecimento de todos os detalhes do layout, precisamos formatar a sua estrutura e identificar quais contextos fará
parte de seu conteúdo.
Definir o layout de um escritório, por exemplo é organizar as mesas e armários da melhor maneira possível para que se
possa aproveitar o espaço da sala.
No caso de rotinas legais e da integração, layout é um arquivo que define a organização das informações solicitadas:
ordenação, hierarquia, formato de dados e formato do arquivo. Sempre que trabalha com exportação deve-se definir um
layout para auxiliar na leitura das mesmas por uma pessoa ou outro sistema.
Em síntese, o layout contém os registros com as informações que serão geradas no arquivo. Determina a organização
destas informações no arquivo gerado.
5
Gerador de Saidas
Exemplo de arquivo
6
Gerador de Saidas
Exemplo Registro
7
Gerador de Saidas
Exemplo de campo
8
Gerador de Saidas
Exemplo de contexto
4. Importante
Evite utilizar caractere especial na criação do layout (arquivos, registros, campos e contextos). Na geração irá acontecer
a compilação do layout e esses caracteres especiais podem gerar dificuldades na compilação.
Primeiro passo é necessário inserir a Tag abaixo nos arquivos RM.Host.exe.Config e RM.Host.Service.Config.
Segundo passo é criar um diretório em um dos servidores de rede e compartilhar estes diretórios, liberando acesso a
estes diretórios ao usuário que executa o Host do sistema.
Terceiro passo é marcar a opção: “Gerar Arquivo em Servidor” na geração do layout. Esta opção será relembrada em
tópico posterior.
9
Gerador de Saidas
10
Gerador de Saidas
11
Gerador de Saidas
E ao acessar a MDI RM, localize no menu TOTVS Linha RM / BackOffice / Gestão Fiscal ou Integração.
7. Categoria de Layout
A categoria de layout serve para permitir acesso ao usuário. Acesse o menu Integração / Gerador de Saída e clique
em Categoria:
12
Gerador de Saidas
Para criar nova categoria, clique no ícone “Incluir (Ctrl+Ins)”, localizado na barra superior e a esquerda.
13
Gerador de Saidas
Para vincular o perfil, clique no ícone “Incluir (Ctrl+Ins)”, localizado na barra superior e a esquerda.
14
Gerador de Saidas
8. Tipo de Layout
O tipo de layout não é cadastrado pelo usuário. São tipos de pré-definidos que são incluídos pelo Analista responsável
de cada Produto via banco de dados no script de conversão da base. Os tipos são utilizados para separar os layouts
por processos/aplicativos.
Exemplo
Quando for criada uma chamada para layouts do financeiro não serão apresentados outros tipos de layout.
15
Gerador de Saidas
16
Gerador de Saidas
9. Comparação
Para verificar as alterações nos layouts.
Exemplo
17
Gerador de Saidas
18
Gerador de Saidas
10. Executar
Para gerar o arquivo de exportação.
19
Gerador de Saidas
20
Gerador de Saidas
11. Layouts
21
Gerador de Saidas
Visível para todas as coligadas: Flag (marque) este campo se o seu arquivo de exportação será visível em outras
coligadas.
Ativo: Flag (marque) este campo se o layout está disponível. Caso, queira inativar desmarque este campo.
22
Gerador de Saidas
Layout Pai: Crie layout pai para separar os tipos de layouts para organização dos layouts do Gerador de Saídas. Em
síntese, serve para criar uma estrutura de árvore em sua visão para melhor organizar e visualizar seus layouts.
Tipo: O tipo de layout não é cadastrado pelo usuário. São tipos de pré-definidos que são incluídos pelo Analista
responsável de cada Produto via banco de dados no script de conversão da base. Os tipos são utilizados para separar
os layouts por processos/aplicativos.
Exemplo
Quando for criada uma chamada para layouts do financeiro não serão apresentados outros tipos de layout.
Preencha sempre os campos de descrição com o maior número de informações possíveis, pois desta forma a
documentação do layout gerada pela ferramenta será mais completa.
23
Gerador de Saidas
Parâmetros e erros.
Usa diretório padrão: definir que será usado o diretório padrão TOTVS: C:\totvs\CorporeRM\RM.Net\Saidas
Preenchendo essa formatação todos os campos criados no layout respeitarão essa formatação. A formatação deve ser
feita separadamente pelo tipo do campo.
24
Gerador de Saidas
11.2.1.1. Texto
Caracteres de preenchimento: completa o tamanho do campo com os caracteres definidos nesta formatação.
Exemplo: 0 (zero), espaço, letra.
Expressão regular dos caracteres não permitidos: é possível definir uma expressão regular para remover
caracteres que não podem sair no layout.
Expressão regular para pesquisa no texto: possui a função de obter uma parte do texto desejado.
Máscara de entrada: a máscara definida no layout é aplicada no arquivo todo e se for definida nos registros
será aplicada apenas na linha definida.
Substituir caracteres especiais: não substitui a função, remove os caracteres especiais. Exemplo: se vier @, /,
a ferramenta irá eliminar.
Tipo de dado do sistema: apenas para consulta. A ferramenta já apresenta o tipo de dado automaticamente. O
tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados em
relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL). Exemplo: System.Int32.
Valor nulo: definir o caractere que o Gerador de Saídas irá acrescentar quando for nula a informação.
Caractere de preenchimento: completa o tamanho do campo com os caracteres definidos nesta formatação.
Exemplo: 0 (zero), espaço, letra.
24
Gerador de Saidas
Separador de milhares: Lembrando sempre que o SQL Server internamente armazena o separador decimal
como ponto (.) e o separador de milhar como vírgula (,).
Tipo de dado do sistema: apenas para consulta. A ferramenta já apresenta o tipo de dado automaticamente. O
tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados em
relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL). Exemplo: System.Int32.
Valor nulo: definir o caractere que o Gerador de Saídas irá acrescentar quando for nula a informação.
Caractere de preenchimento: completa o tamanho do campo com os caracteres definidos nesta formatação.
Modo de arredondamento: definir se irá arredondar ou truncar (A função TRUNC remove a parte fracionária
do número. INT arredonda números para baixo até o inteiro mais próximo com base no valor da parte
fracionária do número. Trunca um número até um inteiro, removendo a parte decimal ou fracionária do
número.)
Separador de milhares: Lembrando sempre que o SQL Server internamente armazena o separador decimal
como ponto (.) e o separador de milhar como vírgula (,). Defina o separador de milhares.
Separador decimal: Lembrando sempre que o SQL Server internamente armazena o separador decimal como
ponto (.) e o separador de milhar como vírgula (,). Defina o separador decimal.
Tipo de dado do sistema: Apenas para consulta. A ferramenta já apresenta o tipo de dado automaticamente.
O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados em
relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL). Exemplo: System.Int32.
Valor nulo: Definir o caractere que o Gerador de Saídas irá acrescentar quando for nula a informação.
25
Gerador de Saidas
Caractere de preenchimento: completa o tamanho do campo com os caracteres definidos nesta formatação.
Tipo de dado do sistema: apenas para consulta. A ferramenta já apresenta o tipo de dado automaticamente.
O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados em
relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL). Exemplo: System.Int32.
Valor nulo: definir o caractere que o Gerador de Saídas irá acrescentar quando for nula a informação.
11.2.1.4. Lógico
Caractere de preenchimento: completa o tamanho do campo com os caracteres definidos nesta formatação.
Exemplo: 0 (zero), espaço, letra.
Tipo de dado do sistema: apenas para consulta. A ferramenta já apresenta o tipo de dado automaticamente.
O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados em
relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL).
Exemplo: System.Int32.
26
Gerador de Saidas
Valor nulo: definir o caractere que o Gerador de Saídas irá acrescentar quando for nula a informação.
Arquivo
27
Gerador de Saidas
Tipo do arquivo: definir a extensão do arquivo a ser gerado. Até o momento é gerado em .txt.
Propriedades
Registro 001
Tipo:
Lista: repete mais de uma vez. Imprime todos os registros, exemplo: CLI/FOR (lista).
28
Gerador de Saidas
Agrupador: registro oculto. Não aparece no layout. Deve ser utilizado baseado na hierarquia das informações.
Exemplo:
Para obter as informações da COLIGADA e dos DEPARTAMENTOS é necessário utilizar a tabela de FILIAL.
As informações da Filial não são necessárias no layout, então a tabela de FILIAL será um registro agrupador.
Ligação sob demanda: é quando não possui a informação na ligação. E o usuário não consegue adicionar no conjunto
de dados. Exemplo: as mensagens personalizadas no arquivo bancário.
Filtro da ligação: selecionar o campo do contexto que será utilizado no filtro e montar a expressão. Linguagem C#.
Exemplo
Opções:
Gravar arquivo parcial em disco: será descontinuado, pois o modo de carga do layout executa de forma mais
eficiente esta função.
Gerar somente se possuir algum registro filho: será descontinuado, pois o modo de carga do layout
executa de forma mais eficiente esta função.
iv. Id do Registro:
29
Gerador de Saidas
O último botão exibe o nome da ligação dos campos para conhecimento do usuário.
Para adicionar um contexto a um registro selecione o contexto desejado e arraste para o registro correspondente. Caso
seja necessário é possível criar filtros e determinar uma ordenação para o registro.
Para adicionar um campo ao seu registro basta clicar no botão adicionar na guia de campos.
Modo:
Chave primária: utilizado quando o dado não pode ser repetido no registro.
Primeiro valor: retornam o primeiro e último valor de uma série quando utilizados em conjunto com a chave
primária.
Último valor: retornam o primeiro e último valor de uma série quando utilizados em conjunto com a chave
primária.
Contar: conta a quantidade de dados impressos nos registros. Utilizado em conjunto com a chave primária.
Somar: utilizado para somar valores. Utilizado em conjunto com a chave primária.
Média: calcula a média dos valores de um registro. Utilizado em conjunto com a chave primária.
Mínimo: retornam o menor e o maior valor de uma séria quando utilizados em conjunto com a chave primária.
Máximo: retornam o menor e o maior valor de uma séria quando utilizados em conjunto com a chave primária.
Posição:
30
Gerador de Saidas
Tipo de dado:
Texto: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de
dados em relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte
Precedência de tipo de dados (Transact-SQL). Definir se é tipo texto.
Número Inteiro: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos
de dados em relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte
Precedência de tipo de dados (Transact-SQL). Definir se é tipo número inteiro.
Número Decimal: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de
tipos de dados em relação aos tipos de dados de expressões de entrada. Para obter mais informações,
consulte Precedência de tipo de dados (Transact-SQL). Definir se é tipo número decimal.
Data: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados
em relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência
de tipo de dados (Transact-SQL). Definir se é tipo data.
Lógico: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de
dados em relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte
Precedência de tipo de dados (Transact-SQL). Definir se é tipo lógico.
Ligação:
Propriedades avançadas do registro: a edição das propriedades avançadas do campo: neste local são
acessadas todas as parametrizações do campo, pode-se personalizar a formatação do campo, visualizar a
ligação de dados e ainda pode-se fazer conversão de valores: “de-para”, assim como diversas outras
parametrizações.
Clique sobre o nome do contexto criado, arraste e solte a coluna desejada no campo desejado.
Observe que a coluna ligação estará com a palavra (registro) e ao passar o mouse sobre o campo é
apresentada a ligação de dados.
É possível ainda ter os seguintes tipos de campos a ligação de dados: contexto, expressão, valor fixo e
fórmula.
31
Gerador de Saidas
Após adicionar um dos tipos de contexto é necessário dar um nome para este contexto e selecionar o modo de carga
do contexto.
É um contexto que retorna os dados conforme a regra de negócios criada pelo Desenvolvimento do Sistema.
Não é possível a criação de contextos deste tipo pelos analistas que desenvolvem os layouts. Para saber quais os
dados que um contexto Classe RM.NET(DLL) retorna é necessário verificar com o Departamento de Suporte (com os
responsáveis que criaram o contexto).
Exemplo
Se foi criado um contexto do financeiro, os analistas do financeiro que desenvolveram o contexto deverão informar o
que ele retorna.
32
Gerador de Saidas
Modo de carga:
Carregado no início da geração: no início da geração do layout carregar todos os dados. Em layouts muito grandes a
geração pode ter o desempenho comprometido. Em síntese, carrega todos os dados e depois a estrutura.
Carregado sob demanda: carrega o contexto sob demanda, somente no momento que é requerido pelo layout. De
forma simples, não armazena. Se for necessário carrega de novo.
Carregado sob demanda (Cacheado): carrega sob demanda e só descarrega após utilizar as informações em todos os
layouts. Em síntese, mantém na memória.
Exemplo
Registro 01
Registro 01.01
Registro 01.02
Registro 02
Registro 03
É utilizado a informação dos clientes/fornecedores no registro 01, registro 02, este contexto será carregado na geração
do registro 01 e será descarregado somente após a utilização das informações no registro 02.
Os parâmetros da SQL deverão ser associados ao parâmetro da geração do layout. Para fazer isso é necessário clicar
com o botão esquerdo do mouse sobre o parâmetro, segurar e arrastar o parâmetro para o parâmetro da SQL e soltar o
botão do mouse.
Mode de Carga:
33
Gerador de Saidas
Carregado sob demanda: carrega o contexto sob demanda, somente no momento que é requerido pelo layout. De
forma simples, não armazena. Se for necessário carrega de novo.
Carregado sob demanda (Cacheado): carrega sob demanda e só descarrega após utilizar as informações em todos
os layouts. Em síntese, mantém na memória.
Exemplo
Registro 01
Registro 01.01
Registro 01.02
Registro 02
Registro 03
É utilizado a informação dos clientes/fornecedores no registro 01, registro 02, este contexto será carregado na geração
do registro 01 e será descarregado somente após a utilização das informações no registro 02.
Propriedades:
Consulta SQL: Linguagem de Consulta Estruturada ou SQL, é a linguagem de pesquisa declarativa padrão para banco
de dados relacional (base de dados relacional).
Exemplo
Definições
SELECT: O comando SELECT permite recuperar os dados de um objeto do banco de dados, como uma tabela, view e,
em alguns casos, uma stored procedure (alguns bancos de dados permitem a criação de procedimentos que retornam
valor).
34
Gerador de Saidas
Limita as linhas retornadas em um conjunto de resultados de consulta a um número ... de TOP (10) afetar 10 linhas,
dessas linhas, 7 podem ser atualizadas e 3 ...
FROM: Indicar a tabela. O caractere * representa todos os campos. Apesar de prático, este caractere não é muito
utilizado, pois, para o SGBD é mais rápido receber o comando com todos os campos explicitados. O uso do * obriga o
servidor a consultar quais são os campos antes de efetuar a busca dos dados, criando mais um passo no processo
SQL passar condições de filtragem.
Selecionar o cadastro do sistema que será utilizado como contexto do layout. Localizar o cadastro do sistema no
lookup, pesquisar e selecionar o resultado desejado. É possível a associação de um parâmetro ao contexto.
Mode de Carga:
Carregado no início da geração: no início da geração do layout carregar todos os dados. Em layouts muito grandes a
geração pode ter o desempenho comprometido. Em síntese, carrega todos os dados e depois a estrutura.
Carregado sob demanda: carrega o contexto sob demanda, somente no momento que é requerido pelo layout. De
forma simples, não armazena. Se for necessário carrega de novo.
35
Gerador de Saidas
Exemplo
Registro 01
Registro 01.01
Registro 01.02
Registro 02
Registro 03
É utilizado a informação dos clientes/fornecedores no registro 01, registro 02, este contexto será carregado na geração
do registro 01 e será descarregado somente após a utilização das informações no registro 02.
Exemplo
Contextos de aplicação:
36
Gerador de Saidas
Propriedades:
Adicionar:
Texto: permite que o operador digite informação do tipo texto a ser gerada no layout.
Número Inteiro: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de
dados em relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL). Definir se é tipo número inteiro.
Número Decimal: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de
dados em relação aos tipos de dados de expressões de entrada. Para obter mais informações, consulte Precedência de
tipo de dados (Transact-SQL). Definir se é tipo número decimal.
Lógico: O tipo de dados do resultado é determinado pela aplicação das regras de precedência de tipos de dados em
relação aos tipos de dados de expressões de entrada.
Para obter mais informações, consulte Precedência de tipo de dados (Transact-SQL). Definir se é tipo lógico. Permite
que o operador digite o tipo lógico a ser gerado no layout.
Lista: Criar uma lista a ser disponibilizada na visão da geração do layout e permitir ao usuário a seleção dos itens
dessa lista.
Lookup: Definir qual tabela do aplicativo estará disponível na visão da geração do layout para o operador filtrar e
selecionar o item a ser gerado neste layout. Selecionar as colunas na seção campos. Selecionar a coluna que será
utilizada na descrição do filtro na seção descrição e o código que será passado como parâmetro da action para o layout
na seção código. Nas seções descrição e código estarão disponíveis as colunas disponíveis na seção campos.
Filtro: Permite que o usuário use os filtros. Em configuração, selecionar a tabela que deverá ser utilizada no filtro dos
parâmetros do layout. O filtro será utilizado no layout após a criação.
38
Gerador de Saidas
O contexto conjunto de dados refere-se às tabelas do sistema disponíveis no banco de dados. Quando utilizamos o
contexto conjunto de dados não é necessário adicionar várias tabelas e relacioná-las para obtermos as informações
como fonte de dados para utilização no layout, pois todas as tabelas que se relacionam no banco com esta tabela estão
disponíveis no contexto.
Exemplo
Selecionamos a tabela de lançamentos FLAN temos disponível no contexto as informações por exemplo da tabela de
coligadas GCOLIGADA e assim sucessivamente com todas as tabelas que se relacionam com a tabela de lançamentos.
Mode de Carga:
39
Gerador de Saidas
Carregado sob demanda: carrega o contexto sob demanda, somente no momento que é requerido pelo layout. De
forma simples, não armazena. Se for necessário carrega de novo.
Carregado sob demanda (Cacheado): carrega sob demanda e só descarrega após utilizar as informações em todos
os layouts. Em síntese, mantém na memória.
Exemplo
Registro 01
Registro 01.01
Registro 01.02
Registro 02
Registro 03
É utilizado a informação dos clientes/fornecedores no registro 01, registro 02, este contexto será carregado na geração
do registro 01 e será descarregado somente após a utilização das informações no registro 02.
Propriedades:
Adicionar Tabela:
Tabela Base: pesquisar a tabela que será usada no layout. Exemplo: Funcionários.
40
Gerador de Saidas
Utilizar campos complementares como registro: definir se será usado campo complementar.
Ícones (a direita):
Alterar Filtro.
Excluir Filtro.
Adicionar Relacionamento:
Colunas:
41
Gerador de Saidas
Conceitos:
Uma chave primária é utilizada para identificar de forma única cada linha numa tabela. Pode fazer parte do próprio
registo atual ou pode ser um campo artificial (um que não tenha nada que ver com o registo atual). Uma chave
primária pode ser composta por um ou mais campos numa tabela.
Sob o ponto de vista de um banco de dados relacional, referem-se aos conjuntos de um ou mais campos, cujos valores,
considerando a combinação de valores em caso de mais de uma chave primária, nunca se repetem na mesma tabela e,
desta forma, podem ser usadas como um índice de referência para criar relacionamentos com as demais tabelas do
banco de dados (daí vem o nome banco de dados relacional). Portanto, uma chave primária nunca pode ter valor nulo,
nem repetição. Simplificando, quando a chave primária é simples, ou seja, é formada por um único campo da tabela,
esse campo não pode ter dois ou mais registros de mesmo valor e também não pode conter nenhum registro nulo. Se a
chave primária é composta, ou seja, formada por mais de um campo, os valores de cada campo podem se repetir, mas
nunca a combinação desses valores.
Exemplo: a tabela 'Livros_Autores' tem como chave primária (cod_livro, cod_autor). Podem existir nessa tabela os
registros:
(5, 9);
(5, 10);
(4, 9);
(9, 5).
11.6.1.5. Contadores:
Contexto utilizado para gerar contadores do layout. Existe um tipo de contar nativo que gera um contador sequencial de
linhas.
Para criar um contador de um registro específico é necessário adicionar um novo contador e adicionar a ele o registro
que deseja contar.
42
Gerador de Saidas
Propriedades:
Adicionar:
Modo:
Contar
Somar
Mínimo
Máximo
44
Gerador de Saidas
O lookup busca todas as Procedures que estão criadas na base de dados. Caso a Procedure tenha parâmetros é
necessário informar valores válidos de parâmetros para alimentar o contexto para a montagem do layout. Após a
montagem do layout é necessário inserir valores inválidos nos parâmetros para que o contexto não seja carregado
somente com os dados gerados para a montagem do layout. Os parâmetros da Procedure devem ter o mesmo nome
dos parâmetros criados no layout.
45
Gerador de Saidas
Mode de Carga:
Carregado no início da geração: no início da geração do layout carregar todos os dados. Em layouts muito grandes a
geração pode ter o desempenho comprometido. Em síntese, carrega todos os dados e depois a estrutura.
Carregado sob demanda: carrega o contexto sob demanda, somente no momento que é requerido pelo layout. De
forma simples, não armazena. Se for necessário carrega de novo.
Carregado sob demanda (Cacheado): carrega sob demanda e só descarrega após utilizar as informações em todos
os layouts. Em síntese, mantém na memória.
Exemplo
Registro 01
Registro 01.01
Registro 01.02
Registro 02
Registro 03
É utilizado a informação dos clientes/fornecedores no registro 01, registro 02, este contexto será carregado na geração
do registro 01 e será descarregado somente após a utilização das informações no registro 02.
Propriedades:
Exemplo:
46
Gerador de Saidas
Desta Forma é apresentada as configurações para este parâmetro que será apresentado ao gerar o Layout desejado:
48
Gerador de Saidas
Após esta configuração dos parâmetros, se faz necessário configurar a ligação deste parâmetro com o contexto da
sentença SQL.
Nas configurações do contexto da SQL na guia dos parâmetros temos esta opção como print abaixo:
Para que o contexto dos parâmetros da geração seja adicionado, os campos devem ser arrastados para configuração
de ligação:
Assim após estas parametrizações, o Layout ao ser Gerado solicitará a passagem dos parâmetros:
49
Gerador de Saidas
SEXO.
Observação
Repare que os nomes de dependentes são apenas do Sexo Feminino como solicitamos no parâmetro:
Para efetuar as operações com os layouts, selecione o layout desejado e clique em processos.
As operações são:
Geração de saídas: é utilizada para a geração do layout. Por padrão o layout é gravado em:
C:\totvs\CorporeRM\RM.Net\Saidas ou no diretório parametrizado para geração do layout.
Export layout.
Importar layout.
Comparação de layout (tópico 9 – Sumário): recurso muito útil para comparar diferenças entre dois layouts. Para
utilizar esta funcionalidade clique no botão comparação dos layouts e selecione os layouts, que deseja comparar e
atualizar a versão. Se, a opção exibir somente as propriedades alteradas estiver marcada será visualizada somente a
diferença entre os layouts.
50
Gerador de Saidas
51
Gerador de Saidas
52
Gerador de Saidas
Acessando o Registro do Layout, temos o campo CNPJ que corresponde ao campo da base de dados
(GCOLIGADA.CGC). Assim clicamos no Botão “Editar Propriedades Avançadas do Registro” como mostrado no Print
abaixo:
53
Gerador de Saidas
Observação
Observação: para permitir o uso de letras acentuadas e espaçamento, colocamos o valor [^a-z|0-9|A-
Z|\s|áéíóúàèìòùâêîôûãõ].
Incluindo o Caractere Ç
Para incluir o caractere Ç na impressão de layout do gerador de saídas deverá ser incluído no campo: codificação do
Arquivo selecionando a opção Europa Ocidental (ISO).
54
Gerador de Saidas
12. Exercício
Categoria: RH
55
Gerador de Saidas
Propriedades:
Selecione a subpasta Layout (F4), selecione registros e clique no ícone adicionar registro:
Tipo: Lista
Campos:
Modo: Chave primária, chave primária, primeiro valor, primeiro valor, primeiro valor, primeiro valor.
56
Gerador de Saidas
Filtro da ligação: selecionar o campo do contexto que será utilizado no filtro e montar a expressão.
Selecione a subpasta Contextos (F5), selecione contextos e clique no ícone adicionar contexto “Contexto da Aplicação”:
Retorne no registro;
Selecione a subpasta Contextos (F5), selecione contextos e clique no ícone adicionar contexto “Conjunto de Dados”:
Retorne no registro;
Salve o layout;
Acesse menu Integração / Gerador de Saída / Layouts, selecione (marque) o layout a ser gerado, clique em Processos /
Geração de Saídas:
Clique em avançar;
Clique em executar;
Clique em fechar;
58
Gerador de Saidas
13. Conclusão
Chegamos ao término do nosso curso.
Com base nos conceitos, configurações, informações importantes, estudos de casos e exercícios resolvidos, você está
apto a criar, configurar e gerenciar o Gerador de Saídas.
O CTT – Centro de Treinamento TOTVS agradece a sua participação neste curso e espera revê-lo em breve em outras
capacitações e/ou atualizações de versão.
59