Pular para o conteúdo principal

Postagem em destaque

BlackTDN :: Como Criar Relatórios de Cotações com Dados Agrupados Usando SQL

img: DALL·E 2024-08-09 07.00.00 - A high-quality image showcasing a detailed SQL query being written in a code editor, such as VS Code, on a dark theme background. ... ## Como Criar Relatórios de Cotações com Dados Agrupados Usando SQL Quando trabalhamos com sistemas ERP e precisamos gerar relatórios de cotações que apresentam dados de múltiplos fornecedores, é comum encontrarmos a necessidade de pivotar registros que, originalmente, são apresentados de forma vertical. Isso é especialmente útil quando o objetivo é comparar preços ou condições de diferentes fornecedores para um mesmo produto em uma única linha do relatório. Neste artigo, vamos explorar uma abordagem para transformar registros verticais em colunas, facilitando a impressão de relatórios que consolidam informações de vários fornecedores em uma única linha. Vamos utilizar SQL com técnicas de pivotagem, e ao final, mostraremos como estender essa técnica para um número variável de fornecedores. ### Estrutura do Relatór

Protheus :: Advpl :: TCInternal()

Fala ae Anonimo!

Em um dos posts anteriores.. comenterei sobre o uso de algumas funções para nao ocorrer o consumo de licenças no TOP / DBAccess… e logo na sequencia houve um pedido “anonimo”

para postar o uso da TCInternal() na atualização de campos / dicionario de dados…

Postado ao som de : Delinquent Habits – Here Come The Horns

Como prometido… segue abaixo o codigo contendo o uso:

 

#include "protheus.ch"

/*
Funcao: UPDGema
Autor: Rodrigo OverFail
Data: 21/12/2011
Funcionalidade: Exemplo para uso da TCInternal()
*/

User Function UpdGema()

cArqEmp     := "SigaMat.Emp"
nModulo        := 05
__cInterNet := Nil
PRIVATE cMessage
PRIVATE aArqUpd     := {}
PRIVATE aREOPEN     := {}
Private __lPyme  := .F.

#IFDEF TOP
    TCInternal(5,'*OFF') //-- Desliga Refresh no Lock do Top
#ENDIF

Set Dele On

GEMOpenSM0(.T.)
DbGoTop()

lHistorico     := MsgYesNo("Atualização das tabelas e campos de exemplo UPDGema, Confirma?", "Update")
lEmpenho    := .F.
lAtuMnu        := .F.

DEFINE WINDOW oMainWnd FROM 0,0 TO 01,30 TITLE "Update"
ACTIVATE     WINDOW oMainWnd ICONIZED ;
            ON INIT (If(lHistorico ,Processa({||UpdTables()} ,"Atualização das tabelas") ,.F.), oMainWnd:End())

Return

Static Function GEMOpenSM0(lShared)
    Local lOpen := .F.                 
    Local i := 0
    For i := 1 To 20
        dbUseArea(.T., , "SIGAMAT.EMP", "SM0", lShared, .F.)
        If !Empty(Select("SM0"))
            lOpen := .T.
            dbSetIndex("SIGAMAT.IND")
            Exit   
        EndIf
        Sleep(500)
    Next
Return lOpen

Static Function UpdTables()
Local nRecno       := 0
Local nRecAtu     := 0
Local aAreaSM0     := {}

While SM0->(!Eof())
    nRecAtu := SM0->(Recno())
    aAreaSM0 := SM0->(GetArea())
    RpcSetType(3)
    RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)
    RestArea(aAreaSM0)
    SM0->(dbGoto(nRecAtu))
    RpcClearEnv()
    GEMOpenSM0(.F.)
    SM0->(dbGoto(nRecAtu))
    SM0->(dbSkip())

    If SM0->(! Eof())
        nRecno := SM0->(Recno())
        SM0->(DbGoTo(nRecno))
    EndIf   

EndDo

dbSelectArea("SM0")
dbGotop()
While SM0->(!Eof())

    nRecAtu := SM0->(Recno())
    aAreaSM0 := SM0->(GetArea())
    RpcSetType(3)
    RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)

    RestArea(aAreaSM0)

    dbSelectArea("SM0")
    dbGoto(nRecAtu)       
    If HasTemplate("LOT")
        dbGoto(nRecAtu)       
        dbSelectArea("SX3")
        dbSetOrder(2)
        If SX3->(dbSeek("LJN_TPPRIC"))
            RecLock("SX3",.F.)
            SX3->X3_WHEN := "t_VerWhenLJN()"
            MsUnlock()
        EndIf
    ENDIF     
    SM0->(dbGoto(nRecAtu))
    SM0->(dbSkip())

    If SM0->(! Eof())
        nRecno := SM0->(Recno())
        SM0->(DbGoTo(nRecno))
    EndIf   
EndDo

Alert("Fim da atualização")

Return(.T.)

User Function UpdGemSini()

cArqEmp     := "SigaMat.Emp"
nModulo        := 05
__cInterNet := Nil
PRIVATE cMessage
PRIVATE aArqUpd     := {}
PRIVATE aREOPEN     := {}
Private __lPyme  := .F.

#IFDEF TOP
    TCInternal(5,'*OFF') //-- Desliga Refresh no Lock do Top
#ENDIF

Set Dele On

GEMOpenSM0(.T.)
DbGoTop()

lHistorico     := MsgYesNo("Atualização dos campos do template de exmplo com base SINIEF, Confirma?", "Update")
lEmpenho    := .F.
lAtuMnu        := .F.

DEFINE WINDOW oMainWnd FROM 0,0 TO 01,30 TITLE "Update"
ACTIVATE     WINDOW oMainWnd ICONIZED ;
            ON INIT (If(lHistorico ,Processa({||AuxGEMSINIEF()} ,"Atualização das tabelas") ,.F.), oMainWnd:End())

Return
Static Function AuxGEMSINIEF()
Local nRecno   := 0
Local nCnt     :=0

Local nRecAtu := 0
Local aAreaSM0 := {}

While SM0->(!Eof())
    nRecAtu := SM0->(Recno())
    aAreaSM0 := SM0->(GetArea())
    RpcSetType(3)
    RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)
    RestArea(aAreaSM0)
    SM0->(dbGoto(nRecAtu))
    RpcClearEnv()
    GEMOpenSM0(.F.)
    SM0->(dbGoto(nRecAtu))
    SM0->(dbSkip())

    If SM0->(! Eof())
        nRecno := SM0->(Recno())
        SM0->(DbGoTo(nRecno))
    EndIf   

EndDo

dbSelectArea("SM0")
dbGotop()
While SM0->(!Eof())

    nRecAtu := SM0->(Recno())
    aAreaSM0 := SM0->(GetArea())
    RpcSetType(3)
    RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)

    RestArea(aAreaSM0)

    dbSelectArea("SM0")
    dbGoto(nRecAtu)       
    If HasTemplate("LOT")
        dbGoto(nRecAtu)       
        dbSelectArea("SXG")
        dbSetOrder(1)
        If dbSeek("018")        
            nSize := SXG->XG_SIZE
            aSX2Alias := {}
            aSX3Field := {}
            aAdd( aSX3Field ,{"LIT" ,"LIT_DOC" })
            aAdd( aSX3Field ,{"LIU" ,"LIU_DOC" })
            aAdd( aSX3Field ,{"LIT" ,"LIT_DUPL"})
            aAdd( aSX3Field ,{"LIW" ,"LIW_NUM" })
            aAdd( aSX3Field ,{"LIY" ,"LIY_NUM" })
            aAdd( aSX3Field ,{"LJA" ,"LJA_DOC" })
            aAdd( aSX3Field ,{"LJA" ,"LJA_DUPL"})
            aAdd( aSX3Field ,{"LJB" ,"LJB_DOC" })
            aAdd( aSX3Field ,{"LJE" ,"LJE_NUM" })
            aAdd( aSX3Field ,{"LJV" ,"LJV_NUM" })
            aAdd( aSX3Field ,{"LJX" ,"LJX_NUM" })
            aAdd( aSX3Field ,{"LJT" ,"LJT_NUM" })
            aAdd( aSX3Field ,{"LIX" ,"LIX_NUM" })
            aAdd( aSX3Field ,{"LK7" ,"LK7_NUM" })
            ProcRegua(Len(aSX3Field))
            For nCnt := 1 To Len(aSX3Field)
                IncProc("Atualizando o dicionario de campos...")

                dbSelectArea("SX3")
                dbSetOrder(2)
                If dbSeek(aSX3Field[nCnt ,02])
                    If SX3->X3_ARQUIVO == aSX3Field[nCnt ,01]
                        If aScan(aSX2Alias,{|x| x == SX3->X3_ARQUIVO })==0
                            aAdd(aSX2Alias ,SX3->X3_ARQUIVO)
                        EndIf
                        RecLock("SX3",.F.)
                            SX3->X3_TAMANHO := nSize
                            SX3->X3_GRPSXG  := "018"
                        MsUnLock()
                        dbCommit()
                    EndIf
                EndIf
            Next nCnt

               ProcRegua(Len(aSX2Alias))
            __SetX31Mode(.F.)
            For nCnt := 1 To Len(aSX2Alias)
                IncProc("Atualizando a estrutura da tabela: " +aSX2Alias[nCnt])
                If Select(aSX2Alias[nCnt])>0
                    dbSelecTArea(aSX2Alias[nCnt])
                    dbCloseArea()
                EndIf
                X31UpdTable(aSX2Alias[nCnt])
                If __GetX31Error()
                    Alert(__GetX31Trace())
                    Aviso("Erro!!!", "Falha na atualizacao da tabela: " + aSX2Alias[nCnt] + ". ", {"OK"},2)
                EndIf
            Next nX
            If Len(aSX2Alias) >0
                Alert("Atenção!!!" +chr(13)+chr(10) +;
                      "Foram atualizados " + AllTrim(str(Len(aSX2Alias))) + " tabelas referentes ao SINIEF.")
            EndIf
        Else
            Alert("Atenção!!!" +chr(13)+chr(10) +;
                  "O grupo de campo 018 - Documento de entrada/saida não existe. " +chr(13)+chr(10) +;
                  "Verifique se o atualizador do SINIEF foi executado anteriormente.")
        EndIf
    EndIf         
    dbSelectArea("SM0")
    dbGoto(nRecAtu)

    aAreaSM0 := SM0->(GetArea())
    RpcClearEnv()
    RestArea(aAreaSM0)
    GEMOpenSM0(.F.)

    dbSelectArea("SM0")
    dbGoto(nRecAtu)
    SM0->(dbSkip())
    If SM0->(! Eof())
        nRecno := SM0->(Recno())
        SM0->(DbGoTo(nRecno))
    EndIf
EndDo

Alert("Fim da atualização")

Return(.T.)

Rodrigo “OverFail”

Comentários

  1. Algo interessante que poucas pessoas conhecem é uma função automática (NGCRIAUPD) para criar updates, independente do módulo e alteração/inclusão de SX*, facilitando assim na manutenção e desenvolvimento de novos updates.

    Não consegui postar neste comentário o código exemplo pois há limitação de nº de caracteres.
    Se houver interesse de alguém me envie um e-mail: vitorebatista@gmail.com

    Abraço!

    ResponderExcluir
  2. Vitor,

    Tem, também, a função U_ExporDic.

    BaseDic
    http://dl.dropbox.com/u/1327330/Ferramentas/BaseDic/BaseDic.rar
    CompaDic
    http://dl.dropbox.com/u/1327330/Ferramentas/CompaDic/CompaDic.rar
    ExporDic
    http://dl.dropbox.com/u/1327330/Ferramentas/ExporDic/ExporDic.rar
    FSBitMap
    http://dl.dropbox.com/u/1327330/Ferramentas/FSBitMap/FSBitMap.rar
    FSEnvMail
    http://dl.dropbox.com/u/1327330/Ferramentas/FSEnvMail/FSEnvMail.rar
    FSFontes
    http://dl.dropbox.com/u/1327330/Ferramentas/FSFontes/FSFontes.rar
    Todas as Ferramentas
    http://dl.dropbox.com/u/1327330/Ferramentas/Ferramentas.rar

    ResponderExcluir
  3. Naldoidao, essa do expordic merece um post.

    ResponderExcluir
  4. Realmente este ExporDic foi bem elaborado e é de grande uso principalmente para quem não tem muito conhecimento de programação, pois é bem intuitivo.

    Copiei sua ideia do dropbox e postei o fonte exemplo utilizando o NGCRIAUPD, fonte padrão desde a versão 8 R4. :D

    O NGCRIAUPD tem por objetivo facilitar ao programador o desenvolvimento de novos updates, pois os updates que ainda são utilizados tem 1000 linhas e 90% do código dele é "inútil", ficando no CTRL + C / CTRL + V de um update para outro, certo?

    http://dl.dropbox.com/u/8503472/NGCRIAUPD/UPDTESTE.PRW

    abraço

    ResponderExcluir
  5. Rodrigo,

    Cadê o Prometido sobre a TCInternal? Você disse que disse, prometeu que prometeu, escreveu um bucado de código inútil baseado em copy/past só para isso: "TCInternal(5,'*OFF') //-- Desliga Refresh no Lock do Top". Que LIXO.... Cadê TCInternal ??? Se quer participar de BlackTDN tem que escrever à ALTURA...

    ResponderExcluir
  6. Eitaaaa... não precisava disso né brother!
    Ignorancia não é necessária, bastava dizer que esperava mais do exemplo.

    O site é nosso... e toda contribuição deve ser respeitada!

    {}'s

    ResponderExcluir
    Respostas
    1. eu mandava ele ir atrás e não esperar os outros darem o conhecimento assim de graça

      Excluir
  7. Naldo ,

    Gostei das ferramentas que você postou , mas tem algumas que não tem manual e nem exemplo
    teria como postar

    ResponderExcluir
  8. Ola Daniel

    Ainda não tive tempo para documentar todas as minhas ferramentas. Assim que puder vou fazer isso sim. Tambem estou elaborando outras novas.

    Obrigado

    Ernani Forastieri

    ResponderExcluir
  9. Olá

    Eu coloquei a documentação das ferramentas no meu site. Por favor acessem:

    http://www.ernaniforastieri.com

    Espero que ajude.

    Obrigado.

    ResponderExcluir

Postar um comentário

Postagens mais visitadas