Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

...

Informações
iconfalse
Deck of Cards
iddicas
Card
iddica1
labelDica 1

Evitar chamadas "burras" ao server. Ao executar o ReadRecord é feita uma consulta que não vai retornar nada porque as chaves estão null e se existir campos complementares a lib vai executar uma consulta no banco que também não irá retornar nada.

No caso acima é possível passar para o dataserver o contexto sem executar o ReadRecord, pois o método GetUsrFilter é um método do EduDataServer que estende de RMSDataServer.

Card
iddica2
labelDica 2

Evitar chamadas desnecessárias de ReadRecord, se deseja apenas trazer apenas alguns campos. Ao executar o ReadRecord é feita uma consulta que ir retornar um dataset completo com vários campos que nem serão utilizados, além de trazer os campos complementares do mesmo no dataset. Os campos que necessito são CODCURSO, CODHABILITACAO e CODGRADE, então não se dá a necessidade de executar um ReadRecord para tal fim.

No caso acima ao invés de executar o um ReadRecord, executo um consulta simples trazendo apenas os campos que necessito conforme abaixo.

Card
iddica3
labelDica 3

Sempre observar a ordem das chaves para fazer um join, ao colocar na ordem correta se torna mais performática a consulta. Abaixo temos um join com chaves fora da ordem no banco de dados.

Image Added

Abaixo temos o mesmo join com a ordem correta do banco.

Image Added

Ordem das chaves no banco.

Image Added

Card
iddica4
labelDica 4

Sempre informar o tipo do campo no filtro da sua consulta. Abaixo temos um exemplo de filtro sem o tipo. A importância deste tipo é fazer com que a lib não procure que tipo (string, número, data e etc.) é aquele campo do filtro.

Image Added

Abaixo temos o filtro com o tipo dos campos.

Image Added

Tipos disponíveis:

  • _N: número
  • _S: string;
  • _D: data.
Card
iddica5
labelDica 5

Sempre que utilizar o cache de parâmetro no lado client, o carregamento da classe de parâmetros é muito custoso. Abaixo temos um exemplo de sempre que chamar o EduParametros é feito o carregamento do mesmo.

Image Added

Segue abaixo a utilização de cache de parâmetros.

Bloco de código
languagec#
   private EduParams EduParametros
    {
      get
      {
        if (_params == null)
          _params = new EduParams(RMSSession.Context.CodColigada, RMSSession.Context.CodFilial, RMSSession.Context.CodTipoCurso);
        return _params;
      }
    }
    private EduParams _params = null;