Consulta de Produtos x Empresa

Regras de negócio

A empresa pode possuir mais de uma tabela de preço cadastrada para seus produtos, sendo que podem ser concedidos descontos promocionais com o mesmo período e produto para tabelas diferentes com percentuais diferentes.
OBS: Caso tenha alguma necessidade de configuração do ERP procure “Consultor” ou acesso o link de apoio:
https://ajuda.sankhya.com.br/hc/pt-br/articles/360044600034-Descontos-Promocionais

Dependências

Não possui dependências

Detalhes Técnicos

A entidade utilizada é a EmpresaProdutoImpostos que por sua vez instancia a tabela TGFPEM mapeando os campos principais.

Para realizarmos a busca através do Json, utilizamos o serviço "CRUDServiceProvider.loadRecords".

O serviço CRUDServiceProvider.loadRecords é um otimo serviço para ser utilizado para consulta de dados através do JSON.

No exemplo abaixo foi utilizado como filtro os campos CODEMP e CODPROD, para poder pesquisar os produtos por empresa, porém você pode utilizar outros campos da entidade .

• CODEMP – Código da Empresa.
• CODPROD – Código do Produto.
Para utilizarmos o filtro, basta acrescentar no corpo da requisição o código abaixo utilizando o criteria:
              "criteria": {
                 "expression": {
                    "$": "this.CODEMP = ? and this.CODPROD = ?"
                 },
                 "parameters": [
                   {
                     "$": "10",
                     "type": "I"
                   },
                   {
                     "$": "1",
                     "type": "I"
                   }
                 ]
              }

Para melhor performance sempre utilize nas suas consultas apenas os campos necessários, para evitar tráfego de dados que não serão utilizados.

Descritivo de campos da entidade

Acesse aqui o dicionário de dados da tabela TGFPEM

Exemplo de uso:


URL de chamada: https://api.sankhya.com.br/gateway/v1/mge/service.sbr?serviceName=CRUDServiceProvider.loadRecords&outputType=json

Corpo de requisição
{
  "serviceName": "CRUDServiceProvider.loadRecords",
  "requestBody": {
    "dataSet": {
      "rootEntity": "EmpresaProdutoImpostos",
      "includePresentationFields": "S",
      "offsetPage": "0",
      "criteria": {
        "expression": {
          "$": "this.CODEMP = ? and this.CODPROD = ?"
        },
        "parameters": [
          {
            "$": "10",
            "type": "I"
          },
          {
            "$": "1",
            "type": "I"
          }
        ]
      },
      "entity": {
        "fieldset": {
          "list": "CODEMP,CODPROD"
        }
      }
    }
  }
}

Retorno em json:

{
    "serviceName": "CRUDServiceProvider.loadRecords",
    "status": "1",
    "pendingPrinting": "false",
    "transactionId": "8A0582AF4F679BDCBA971C91E7AE1D00",
    "responseBody": {
        "entities": {
            "total": "1",
            "hasMoreResult": "false",
            "offsetPage": "0",
            "offset": "0",
            "metadata": {
                "fields": {
                    "field": [
                        {
                            "name": "CODEMP"
                        },
                        {
                            "name": "CODPROD"
                        },
                        {
                            "name": "Empresa_NOMEFANTASIA"
                        },
                        {
                            "name": "Produto_DESCRPROD"
                        }
                    ]
                }
            },
            "entity": {
                "f0": {
                    "$": "10"
                },
                "f1": {
                    "$": "1"
                },
                "f2": {
                    "$": "EMPRESA MODO CHECKOUT"
                },
                "f3": {
                    "$": "Bolsa Térmica"
                }
            }
        }
    }
}
Language
Click Try It! to start a request and see the response here!