Pegando informações de índices com as IndexKey e IndexOrd – Maratona AdvPL e TL++ 305

Nesse vídeo demonstraremos a utilização das funções IndexKey e IndexOrd, que servem para retornar informações dos índices utilizados.

Abaixo o código fonte desenvolvido para o exemplo em vídeo acima:

//Bibliotecas
#Include "TOTVS.ch"

/*/{Protheus.doc} User Function zExe305
Retorna o dados de um índice do Protheus
@type Function
@author Atilio
@since 22/02/2023
@see https://tdn.totvs.com/display/tec/IndexKey e https://tdn.totvs.com/display/tec/IndexOrd
@obs 

    Função IndexKey
    Parâmetros
        + nOrdem        , Numérico   , Número do Índice do Alias sendo que a partir da letra A no configurador passa a ser 10 (então B é 11, C é 12, D é 13 e assim por diante)
    Retorno
        + cRet          , Caractere  , Conteúdo do índice com os campos

    Função IndexOrd
    Parâmetros
        Não possui parâmetros
    Retorno
        + nOrd          , Numérico   , Número do Índice do Alias sendo que a partir da letra A no configurador passa a ser 10 (então B é 11, C é 12, D é 13 e assim por diante)

    **** Apoie nosso projeto, se inscreva em https://www.youtube.com/TerminalDeInformacao ****
/*/

User Function zExe305()
    Local aArea      := FWGetArea()
    Local cMensagem  := ""

    //Abre a tabela de produtos e posiciona num índice
    DbSelectArea("SB1")
    SB1->(DbSetOrder(5))

    //Monta a mensagem e exibe
    cMensagem := "Cadastro de Produtos" + CRLF + CRLF
    cMensagem += "O índice numérico é: " + cValToChar(SB1->(IndexOrd())) + CRLF
    cMensagem += "E a chave do índice é: " + SB1->(IndexKey(IndexOrd())) + CRLF
    FWAlertInfo(cMensagem, "Teste IndexKey e IndexOrd")

    FWRestArea(aArea)
Return

Bom pessoal, por hoje é só.

Abraços e até a próxima.

Dan (Daniel Atilio)
Cristão de ramificação protestante. Especialista em Engenharia de Software pela FIB, graduado em Banco de Dados pela FATEC Bauru e técnico em informática pelo CTI da Unesp. Entusiasta de soluções Open Source e blogueiro nas horas vagas. Autor e mantenedor do portal Terminal de Informação.

Deixe uma resposta

Terminal de Informação