Projeto

Geral

Perfil

Manual de Integração » Histórico » Versão 43

ivo, 15/04/2014 13:44 h

1 23 Anônimo
h1. Manual de Integração
2 1 Anônimo
3 36 Anônimo
[[Envio de Duplicatas]]
4 40 vinidalmagro
[[CRM]]
5 23 Anônimo
6 23 Anônimo
7 1 Anônimo
*Índice* 
8 23 Anônimo
# [[Manual de Integração#Introdução|Introdução]] 
9 23 Anônimo
# [[Manual de Integração#Acesso-via-JDBC|Acesso via JDBC]] 
10 23 Anônimo
# [[Manual de Integração#Tabelas-de-Integração|Tabelas de Integração]] 
11 23 Anônimo
## [[Manual de Integração#Representantes|Representantes]] 
12 23 Anônimo
## [[Manual de Integração#Municípios-do-Representante|Municípios do Representante]] 
13 23 Anônimo
## [[Manual de Integração#Clientes-e-Prospects|Clientes e Prospects]] 
14 23 Anônimo
## [[Manual de Integração#Coleções|Coleções]] 
15 23 Anônimo
## [[Manual de Integração#Linhas-de-Produto|Linhas de Produto]] 
16 23 Anônimo
## [[Manual de Integração#Vendas|Vendas]] 
17 23 Anônimo
## [[Manual de Integração#Liquidez|Liquidez]]
18 37 Anônimo
## [[Manual de Integração#Títulos-em-Aberto|Títulos em Aberto]]
19 22 Anônimo
20 1 Anônimo
h1. Introdução
21 1 Anônimo
22 23 Anônimo
O presente documento tem por objetivo orientar as empresas de ERP na geração dos arquivos e/ou tabelas necessárias para integração com o IGS.
23 1 Anônimo
24 1 Anônimo
Dúvidas ou maiores esclarecimentos podem ser obtidos pelo e-mail contato@ibtech.inf.br ou pelo telefone (47) 3370-0504.
25 1 Anônimo
26 23 Anônimo
h1. Acesso via JDBC
27 1 Anônimo
28 23 Anônimo
*Pré-Requisito:* Suporte por parte do Banco de Dados da Empresa fornecedora do ERP a acesso JDBC.
29 1 Anônimo
30 23 Anônimo
Na integração via JDBC a fornecedora de ERP deve disponibilizar para a IBTech tabelas (ou visões) conforme os layouts especificados neste documento, também deverá fornecer um usuário e senha que tenha permissão de consulta nas referidas tabelas ou visões. A IBTech fará acesso via JDBC à base de dados do cliente para extrair as informações.
31 23 Anônimo
32 23 Anônimo
h1. Tabelas de Integração
33 23 Anônimo
34 23 Anônimo
Todas as tabelas/visões tem um campo chamado “codEmpresa” que separa a geração dos dados entre as possíveis várias empresas que o cliente tenha na mesma base de ERP.
35 23 Anônimo
36 23 Anônimo
*Observação:* Os campos com asterisco (*) compõem a “primaryKey” e podem ser enviados como String ou Integer dependendo da necessidade do cliente.
37 23 Anônimo
38 23 Anônimo
Seguem os layouts das tabelas/visões
39 23 Anônimo
40 23 Anônimo
h2. Representantes
41 23 Anônimo
42 23 Anônimo
Esta tabela/visão será utilizada para carregar no IGS a lista de representantes. Não é uma integração obrigatória, pois o cliente pode digitar os representantes diretamente no IGS.
43 23 Anônimo
44 23 Anônimo
|_. Campo      |_. Tipo   |_. Precisão |_. Descrição |
45 23 Anônimo
| codEmpresa * | String/Integer   | 10         | Código da Empresa origem dos dados |
46 23 Anônimo
| codRepres *  | String/Integer   | 255        | Código do Representante no ERP |
47 23 Anônimo
| nome         | String   | 255        | Nome do Representante |
48 23 Anônimo
| telefone     | String   | 255        | Telefone de Contato |
49 23 Anônimo
| email        | String   | 255        | E-Mail |
50 23 Anônimo
| endereco     | String   | 255        | Rua + Número do endereço do Representante |
51 23 Anônimo
| bairro       | String   | 255        | Bairro do Endereço do Representante |
52 23 Anônimo
| CEP          | String   | 8          | CEP do endereço do Representante |
53 23 Anônimo
| Cidade       | String   | 255        | Nome da Cidade do Endereço do Representante |
54 23 Anônimo
| UF           | String   | 2          | Sigla da UF da Cidade |
55 23 Anônimo
| codIBGE      | String   | 7          | Codigo do IBGE da Cidade |
56 23 Anônimo
| situacao     | Integer |          | Situação do cadastro do representante: 0 - Inativo, 1 - Ativo |
57 23 Anônimo
58 23 Anônimo
h2. Municípios do Representante
59 23 Anônimo
60 23 Anônimo
Tabela/visão com a relação dos municípios que o representante atende. Esta não é uma integração obrigatória.
61 23 Anônimo
62 23 Anônimo
|_. Campo      |_. Tipo   |_. Precisão |_. Descrição |
63 23 Anônimo
| codEmpresa * | String/Integer  | 10         | Código da Empresa origem dos dados |
64 23 Anônimo
| codRepres *  | String/Integer   | 255        | Código do Representante no ERP |
65 23 Anônimo
| codIBGE      | String   | 7          | Codigo do IBGE da Cidade |
66 30 Anônimo
| nomeDistrito       | String   | 255        | Nome da Cidade ou Distrito |
67 23 Anônimo
68 23 Anônimo
h2. Clientes e Prospects
69 23 Anônimo
70 23 Anônimo
Tabela/visão com a relação dos clientes e prospects.
71 23 Anônimo
Podem ser listados clientes ativos ou inativos dependendo da necessidade do cliente.
72 23 Anônimo
73 23 Anônimo
*Situação:* O conceito de situação do cliente para o IGS é:
74 23 Anônimo
* 0-Inativo: Cliente que não está comprando, mas pode voltar a comprar
75 23 Anônimo
* 1-Ativo: Cliente com compra regular
76 23 Anônimo
* 2-Bloqueado: Cliente com restrições (ex: crédito) ou "Clientes que não interessam a empresa"
77 23 Anônimo
Caso seu ERP tenha somente os clientes ativos e inativos, retorne desta forma.
78 23 Anônimo
79 23 Anônimo
*Representante:* Só usar os campos codRepres2 e codRepres3 caso o cliente tenha variação de representante por linha de produto
80 23 Anônimo
81 23 Anônimo
|_. Campo      |_. Tipo   |_. Precisão |_. Descrição |
82 23 Anônimo
| codEmpresa * | String/Integer   | 10         | Código da Empresa origem dos dados |
83 23 Anônimo
| codIBGE     | String   | 7          | Codigo do IBGE da Cidade |
84 23 Anônimo
| codCliente *    | String/Integer   | 255          | Codigo do Cliente ou Prospect |
85 23 Anônimo
| tipo      | Integer   |           | Tipo de registro: 1 - Cliente, 2 - Prospect |
86 23 Anônimo
| nome         | String   | 255        | Nome do cliente |
87 23 Anônimo
| situacao     | Integer |          | Situação do cadastro do cliente: 0 - Inativo, 1 - Ativo, 2 - Bloqueado |
88 23 Anônimo
| codRepres1   | String   | 255        | Código do Representante Principal no ERP |
89 23 Anônimo
| codRepres2  | String   | 255        | Código do Representante 2 no ERP |
90 23 Anônimo
| codRepres3   | String   | 255        | Código do Representante 3 no ERP |
91 23 Anônimo
| telefone     | String   | 255        | Telefone de Contato |
92 23 Anônimo
| email        | String   | 255        | E-Mail |
93 23 Anônimo
| endereco     | String   | 255        | Rua + Número do endereço do cliente |
94 23 Anônimo
| bairro       | String   | 255        | Bairro do Endereço do cliente |
95 23 Anônimo
| CEP          | String   | 8          | CEP do endereço do cliente |
96 23 Anônimo
| dataCadastro | Date    |          | Data de Cadastro do Cliente |
97 29 Anônimo
| cnpjCpf | String | 255 | CNPJ ou CPF do cliente |
98 29 Anônimo
| emailCobranca | String | 255 | Endereço de e-mail de cobrança |
99 43 ivo
| nomeDistrito       | String   | 255        | Nome do Distrito (para o caso de São Paulo, os bairros – para o caso de Brasília, os Distritos)
100 43 ivo
Se o seu sistema não tiver esta informação, retornar o bairro. |
101 38 vinidalmagro
| celular       | String   | 255        | Numero do Celular |
102 38 vinidalmagro
| inscricaoEstadual       | String   | 255        | Inscrição estadual do cliente |
103 39 vinidalmagro
| enderecoNumero       | String   | 255        | Número do endereço do cliente  |
104 38 vinidalmagro
| complemento       | String   | 255        | Complemento do endereço |
105 41 ivo
| telefone2       | String   | 255        | Telefone 2. Se não existir o campo, retornar null |
106 41 ivo
| telefoneCobranca       | String   | 255        | Telefone de cobrança. Se não existir o campo, retornar null |
107 41 ivo
| IndicePontualidade       | Number   | 5,2       | Indice de Pontualidade. (Específico Naguchi) |
108 23 Anônimo
109 23 Anônimo
h2. Coleções
110 23 Anônimo
111 23 Anônimo
Tabela/visão com a relação das coleções.
112 23 Anônimo
113 23 Anônimo
|_. Campo      |_. Tipo   |_. Precisão |_. Descrição |
114 23 Anônimo
| codEmpresa * | String/Integer   | 10         | Código da Empresa origem dos dados |
115 23 Anônimo
| codColecao *     | String   | 255          | Codigo da coleção |
116 23 Anônimo
| nome      | String   | 255          | Nome da coleção |
117 23 Anônimo
118 23 Anônimo
h2. Linhas de Produto
119 23 Anônimo
120 23 Anônimo
Lista das linhas de produtos que tiveram dados gerados.
121 23 Anônimo
Entendesse como Linha de Produto a forma adotada pela empresa detentora do ERP para dividir seus produtos em grupos! Em caso de confecções, por exemplo, pode-se utilizar os critérios de (Infantil, Masculino, Feminino,etc.)
122 23 Anônimo
123 23 Anônimo
|_. Campo      |_. Tipo   |_. Precisão |_. Descrição |
124 23 Anônimo
| codEmpresa * | String/Integer  | 10   | Código da Empresa origem dos dados |
125 23 Anônimo
| codLinha *     | String  | 255        | Codigo da linha de produto |
126 23 Anônimo
| nome      | String   | 255          | Nome da linha de produto |
127 23 Anônimo
128 23 Anônimo
h2. Vendas
129 23 Anônimo
130 23 Anônimo
Esta é a principal tabela do processo de integração. Ela deverá armazenar os dados necessários para apresentação dos valores relativos às vendas realizadas.
131 23 Anônimo
Geralmente é gerada em cima dos pedidos de venda. Caso o ERP não consiga gerar os dados com base nos pedido de venda, deveremos acionar o cliente para definir outra tabela para extração dos dados (Exemplo: Notas Fiscais).
132 23 Anônimo
Caso a geração seja por coleção (no caso de Confecções, por exemplo), a fornecedora de ERP deve manter uma configuração onde o cliente deverá informar de quais coleções as informações devem ser geradas.
133 23 Anônimo
Caso a geração seja por período, deve-se definir com o cliente de qual período ele quer as informações (ultimo ano, últimos 2 anos, etc).
134 23 Anônimo
135 23 Anônimo
*Prazo Médio:* Média em dias do prazo de pagamento (condição de pagamento). Por exemplo, condição 30/60/90: 30+60+90 = 180, 180 / 3 parcelas = 60 dias.
136 23 Anônimo
137 23 Anônimo
*Campos Coringa:* Os campos coringa são definidos no momento da implantação, para a primeira integração deve-se retornar nestes campos valor nulo (NULL).
138 23 Anônimo
139 23 Anônimo
*Observação:* Os campos com asterisco (*) deverão ser agrupados(group by) e os demais somados (sum).
140 23 Anônimo
141 23 Anônimo
|_. Campo          |_. Tipo   |_. Precisão |_. Descrição |
142 23 Anônimo
| codEmpresa *     | String/Integer   | 10         | Código da Empresa origem dos dados |
143 23 Anônimo
| codColecao *     | String | 255        | Código da Coleção sobre a qual estamos gerando os dados. |
144 23 Anônimo
| dataReferencia * | Date     | 255        | Armazena a data de emissão do Pedido de Venda. (Caso a geração seja em cima das notas fiscais, deverá armazenar a data de emissão da Nota Fiscal) |
145 23 Anônimo
| codLinha *       | String   | 255        | Código da Linha de Produto. Define-se com o cliente o que ele quer gerar como linha de produto.  |
146 23 Anônimo
| codRepres *      | String/Integer   | 255        | Código do Representante no ERP |
147 23 Anônimo
| codCliente *     | String/Integer   | 255        | Codigo do Cliente |
148 23 Anônimo
| codIBGE *        | String  | 7          | Codigo do IBGE da Cidade do Cliente |
149 23 Anônimo
| UF *             | String  | 2          | Sigla da UF da Cidade do Cliente |
150 23 Anônimo
| valorBruto       | Double   |            | Valor Bruto das Vendas |
151 23 Anônimo
| valorLiquido     | Double   |            | Valor Liquido das Vendas (ex: Valor Bruto - Valor Descontos) |
152 23 Anônimo
| valorDesconto    | Double   |            | Valor de Descontos das Vendas |
153 23 Anônimo
| valorComissao    | Double   |            | Valor de Comissão das Vendas |
154 23 Anônimo
| prazoMedioXValor | Double   |            | Valor Líquido das Vendas multiplicado pelo Prazo Médio de pagamento. |
155 23 Anônimo
| quantidade       | Double   |            | Quantidade de Peças das Vendas |
156 23 Anônimo
| nomeCliente *    | String   | 255        | Nome do Cliente |
157 23 Anônimo
| codPedido *      | String   | 255        | Código do Pedido |
158 23 Anônimo
| codProduto *     | String   | 255        | Código do produto ou referência |
159 23 Anônimo
| campoCoringa1 *  | String   | 255        | Campo valores diversos, inicialmente retornar NULL - Ver com IBTech |
160 23 Anônimo
| campoCoringa2 *  | String   | 255        | Campo valores diversos, inicialmente retornar NULL - Ver com IBTech |
161 1 Anônimo
| campoCoringa3 *  | String   | 255        | Campo valores diversos, inicialmente retornar NULL - Ver com IBTech |
162 1 Anônimo
| dataPrevFaturamento | Date    |        | Data de Previsão de Faturamento |
163 43 ivo
| nomeDistrito *       | String   | 255        |  Nome do Distrito (para o caso de São Paulo, os bairros – para o caso de Brasília, os Distritos)
164 43 ivo
Se o seu sistema não tiver esta informação, retornar o bairro. |
165 43 ivo
| grupoCliente       | String   | 255        | Grupo Economico do Cliente (conforme regra de negócio de cada empresa). Se o seu ERP não tem isso, retornar null |
166 43 ivo
| valorRentabilidade | Double   |            | Valor da Rentabilidade do Pedido. Se o seu ERP não tem rentabilidade por pedido, retornar null |
167 42 ivo
| dataUltFaturamento | Date   |            | Data do último faturamento (específico Naguchi) |
168 42 ivo
| valorFaturado | Double   |            | Valor Faturado (específico Naguchi) |
169 42 ivo
| valorSaldo | Double   |            | Valor Saldo (específico Naguchi) |
170 42 ivo
171 23 Anônimo
172 23 Anônimo
h2. Liquidez
173 23 Anônimo
174 23 Anônimo
Listar dados totalizando os valores a receber e os valores recebidos agrupando por representante. Normalmente estes registros são provenientes do cadastro de contas a receber.
175 32 ivo
A Liquidez resume-se a:
176 32 ivo
- O Valor a vencer no período e pago dividido pelo a vencer no período.
177 32 ivo
- Não entra no cálculo da Liquidez os títulos pagos fora do período de vencimento.
178 23 Anônimo
179 1 Anônimo
*Importante!* Este SQL possui parâmetros.
180 1 Anônimo
181 1 Anônimo
Layout da tabela/visão:
182 1 Anônimo
183 23 Anônimo
|_. Campo          |_. Tipo   |_. Precisão |_. Descrição |
184 23 Anônimo
| codRepres *      | String/Integer   | 255        | Código do Representante no ERP |
185 23 Anônimo
| valorAReceber    | Double   |            | Valor a receber acumulado por representante |
186 23 Anônimo
| valorRecebido    | Double   |            | Valor recebido acumulado por representante |
187 1 Anônimo
188 1 Anônimo
Lista de Parâmetros:
189 1 Anônimo
190 23 Anônimo
_Formato sugerido de data: dd/mm/yyyy (31/12/2013)_
191 1 Anônimo
192 23 Anônimo
|_. Parâmetro      |_. Tipo   |_. Precisão |_. Descrição |
193 23 Anônimo
| :pCodEmpresa     | String/Integer   | 10         | (opcional) Código da empresa no ERP |
194 23 Anônimo
| :pDataInicio     | String   | 10         | Data inicial para filtrar o vencimento e pagamento (formato a combinar) |
195 23 Anônimo
| :pDataFim        | String   | 10         | Data final para filtrar o vencimento e pagamento (formato a combinar) |
196 1 Anônimo
197 23 Anônimo
*Exemplo:*
198 1 Anônimo
199 23 Anônimo
Supondo que o ERP possua duas tabelas/visões, uma para Contas a Receber e outra para Contas Recebidas. Então devera ser feito um UNION das duas tabelas a fim de facilitar a manutenção do SQL:
200 1 Anônimo
201 23 Anônimo
*Observação:* Note que usamos uma função “to_date” que converte o valor String para o formato data, utilize uma função compatível com o seu banco. Caso seja necessário utilizar outro formato, favor entrar em contato com a IBTech para configuração.
202 23 Anônimo
203 23 Anônimo
<pre>
204 23 Anônimo
SELECT codRepres, sum(valorAReceber), sum(valorRecebido)
205 23 Anônimo
FROM (
206 23 Anônimo
		SELECT codRepres,
207 23 Anônimo
				valorTitulo as valorAReceber,
208 23 Anônimo
				0.0 as valorRecebido
209 23 Anônimo
		FROM ContasAReceber
210 23 Anônimo
		WHERE codempresa = :pCodEmpresa
211 23 Anônimo
		AND dataVecto >= to_date(:pDataInicio,'dd/mm/yyyy')
212 23 Anônimo
		AND dataVecto <=to_date(:pDataFim,'dd/mm/yyyy')
213 23 Anônimo
		UNION ALL
214 23 Anônimo
		SELECT codrepres,
215 23 Anônimo
				0.0 as valorAReceber,
216 23 Anônimo
				sum(valorTitulo) as valorRecebido
217 23 Anônimo
		FROM ContasRecebidas
218 23 Anônimo
		WHERE codempresa = :pCodEmpresa
219 23 Anônimo
		AND dataPagto >= to_date(:pDataInicio,'dd/mm/yyyy')
220 23 Anônimo
		AND dataPagto <=to_date(:pDataFim,'dd/mm/yyyy')
221 23 Anônimo
		AND dataVecto >= to_date(:pDataInicio,'dd/mm/yyyy')
222 23 Anônimo
		AND dataVecto <=to_date(:pDataFim,'dd/mm/yyyy')
223 23 Anônimo
)
224 23 Anônimo
GROUP BY codRepres
225 23 Anônimo
</pre>