Verificando se um alias está aberto com a Select – Maratona AdvPL e TL++ 433

Nesse vídeo demonstraremos a utilização da função Select, que serve para validar se um alias esta aberto em memória.

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

//Bibliotecas
#Include "TOTVS.ch"

/*/{Protheus.doc} User Function zExe433
Retorna o numero na memória de um alias aberto
@type Function
@author Atilio
@since 30/03/2023
@see https://tdn.totvs.com/display/tec/Select
@obs 
    Função Select
    Parâmetros
        + cAlias      , Caractere     , Alias que será analisado
    Retorno
        + nRet        , Numérico      , Retorna o número encontrado da área de trabalho (workarea)

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

User Function zExe433()
    Local aArea    := FWGetArea()
    Local cQuery   := ""

    //Abrindo uma tabela e mostrando com qual número ela foi aberta    
    DbSelectArea("SB1")
    FWAlertInfo("O alias SB1 foi aberto com o seguinte número: " + cValToChar(Select("SB1")), "Teste 1 - Select")

    //Exemplo 2, fechando um alias, antes de abrir novamente
    cQuery := " SELECT TOP 1 B1_COD, B1_DESC FROM " + RetSQLName("SB1") + " SB1 WHERE " + RetSQLCond("SB1")
    If Select('QRY_SB1') > 0
        FWAlertSuccess("Estava aberto o Alias QRY_SB1, então foi fechado!", "Teste 2 - Select")
        QRY_SB1->(DbCloseArea())
    EndIf
    PLSQuery(cQuery, 'QRY_SB1')

    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