Postagem em destaque
- Gerar link
- Outros aplicativos
Protheus :: Advpl :: Dicas do Robson :: Usando UniqueKey() para filtrar registros
Função: UniqueKey( <uFields> , <cAlias>, <lResetKeys>, <nMaxRec> ) Objetivo: Verificar se a chave passada é única de acordo com o campo ou campos passados nos parâmetros. Esta função ajuda a apresentar um único registro quando houver vários semelhantes, por exemplo: Fazer consulta SXB na tabela SC7, porém apresentando um registro por pedido de compra independente de quantos itens existam. Parâmetros: uFields – String contendo o campo ou Array unidimensional com as strings dos campos que que serão considerados para pesquisa da chave única. cAlias – Alias do arquivo para pesquisa. lResetKeys – Reinicializa as chaves. nMaxRec – Número máximo de elementos. |
Essa mesma dica poderá, por extensão, servir ao fitro do MPSDU/APSDU como abaixo:
!Deleted().and.C7_EMISSAO>=FirstDate(Date()).and.C7_EMISSAO<=LastDate(Date()).and. UniqueKey({"C7_FILIAL","C7_NUM"}) |
Irá retornar todos os primeiros n registros da tabela SC7, não deletados, com a data de emissão dentro do mês corrente.
Dada a característica da Função UniqueKey() o intervalo de dados não poderá ser muito grande por dois motivos
- Performance;
- Tamanho máximo da “Pilha” de armazenamento;
Logo, para tabela com muitos registros, uma condição complementar deverá ser utilizada como filtro “primário” e excludente.
Exemplo:
Filtrando com:
!Deleted().and.C7_EMISSAO>=FirstDate(Date()).and.C7_EMISSAO<=LastDate(Date()).and. UniqueKey({"C7_FILIAL","C7_NUM"}) |
teremos:
Uma outra dica, para melhorar a performance do filtro usando UniqueKey() é selecionar uma Chave de índice que corresponda ao filtro desejado. No nosso caso C7_FILIAL+C7_NUM…
C7_EMISSAO>=FirstYDate(Date()).and.C7_EMISSAO<=LastYDate(Date()).and. UniqueKey({"C7_FILIAL","C7_NUM"}) |
- Gerar link
- Outros aplicativos
Comentários
Postagens mais visitadas
BlackTDN :: RLeg ~ Desvendando a Função ParamBox
- Gerar link
- Outros aplicativos
Protheus :: Chamando Funções do Menu Diretamente e sem a Necessidade de Login
- Gerar link
- Outros aplicativos
Minha sala de aula!
ResponderExcluir