Apagando ou voltando registros com DbDelete e DbRecall – Maratona AdvPL e TL++ 121

Nesse vídeo demonstraremos a utilização das funções DbDelete e DbRecall sendo que a primeira serve para apagar um registro de uma tabela, e a segunda para voltar esse registro ao normal.

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

//Bibliotecas
#Include "TOTVS.ch"

/*/{Protheus.doc} User Function zExe121
Exclui um registro da tabela ou faz a recuperação dele
@type Function
@author Atilio
@since 14/12/2022
@see https://tdn.totvs.com/display/tec/DBDelete e https://tdn.totvs.com/display/tec/DBRecall
@obs 
    Função DbDelete
    Não possui parâmetros nem retorno

    Função DbRecall
    Não possui parâmetros nem retorno

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

User Function zExe121()
    Local aArea      := FWGetArea()
    Local cCodClient := "C00003"

    DbSelectArea('SA1')
    SA1->(DbSetOrder(1)) //A1_FILIAL + A1_COD + A1_LOJA
    SA1->(DbGoTop())

    //Iniciando o controle de transações
    Begin Transaction

        //Se conseguir posicionar no cliente, apaga o registro
        If SA1->( MsSeek(FWxFilial('SA1') + cCodClient))
            RecLock('SA1', .F.)
                DbDelete()
            SA1->(MsUnlock())
        EndIf
        
        //Pergunta se deseja voltar
        If FWAlertYesNo("Você deseja realmente apagar o registro (sim), ou deseja cancelar a exclusão (não)?", "Continua (DbDelete/DbRecall)?")
            SA1->(DbCommit())

        Else
            SA1->(DbRecall())
        EndIf
    End Transaction

    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.

2 Responses

  1. Ramilson C Sobral de M Junior disse:

    Muito bom, parabéns.

Deixe uma resposta

Terminal de Informação