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

BlackTDN :: Entendendo aEval e aSort com o uso de funções customizadas

#include "rwmake.ch"
#include "protheus.ch"   
#xtranslate MsgOut([<prm,...>]) => (ConOut([<prm>]),MsgBox([<prm>]))
//-----------------------------------------------------------------------------
    //BlackTDN :: Simulando aSort e aEval
//-----------------------------------------------------------------------------
User Function aOrdena()
 
    Local aArray := {10,9,7,4,3,2,5,6,78,89,0,43,2,4,65}
    Local aCopy  := aClone(aArray)
    Local cMsg   := ""
    Local cCRLF  := CRLF
 
    //-----------------------------------------------------------------------------

//Usando as funçõesS padrões

    //-----------------------------------------------------------------------------
    
    //-----------------------------------------------------------------------------

//Função aEval() : http://tdn.totvs.com/display/tec/AEVal

    //-----------------------------------------------------------------------------
    aEval(aArray,{|nValor|cMsg+=Str(nValor)+cCRLF})
    MsgOut(cMsg,OemToAnsi("Eval|aSort Padrão: Resultado Não Ordenado"),"INFO")
    cMsg := ""
    
    //-----------------------------------------------------------------------------

//Função aSort() : http://tdn.totvs.com/pages/viewpage.action?pageId=23889126

    //-----------------------------------------------------------------------------
    aSort(aArray,NIL,NIL,{|nMenor,nMaior|nMenor<nMaior})
 
    aEval(aArray,{|nValor|cMsg+=Str(nValor)+cCRLF})
    MsgOut(cMsg,OemToAnsi("aEval|aSort Padrões: Resultado Ordem Crescente"),"INFO")
    cMsg := ""
 
    aSort(aArray,NIL,NIL,{|nMenor,nMaior|nMenor>nMaior})
    aEval(aArray,{|nValor|cMsg+=Str(nValor)+cCRLF})
    MsgOut(cMsg,OemToAnsi("Eval|aSort Padrões: Resultado Ordem Decrescente"),"INFO")
    cMsg := ""
   
    //-----------------------------------------------------------------------------

//Usando as funções customizadas

    //-----------------------------------------------------------------------------
    
    aSize(aArray,0)
    __aEval(aCopy,{|e|aAdd(aArray,e)})
 
    __aEval(aArray,{|nValor|cMsg+=Str(nValor)+cCRLF})
    MsgOut(cMsg,OemToAnsi("Eval|aSort Customizadas: Resultado Não Ordenado"),"INFO")
    cMsg := ""
    
    __aSort(aArray,NIL,NIL,{|nMenor,nMaior|nMenor<nMaior})
 
    __aEval(aArray,{|nValor|cMsg+=Str(nValor)+cCRLF})
    MsgOut(cMsg,OemToAnsi("__aEval|__aSort Customizadas: Resultado Ordem Crescente"),"INFO")
    cMsg := ""
 
    __aSort(aArray,NIL,NIL,{|nMenor,nMaior|nMenor>nMaior})
    __aEval(aArray,{|nValor|cMsg+=Str(nValor)+cCRLF})
    MsgOut(cMsg,OemToAnsi("__aEval|__aSort Customizadas : Resultado Ordem Decrescente"),"INFO")
    cMsg := ""
    
Return(NIL)
 
//-----------------------------------------------------------------------------

//Simulando aSort padrao

//-----------------------------------------------------------------------------
Static Function __aSort(aArray,nStart,nCount,bEval)
 
    Local nD
    Local nJ
    
    Local uTmp
 
    DEFAULT nStart    := 1
    DEFAULT nCount    := Len( aArray )
 
    For nD := nStart To nCount
        For nJ := nD To nCount
            IF Eval(bEval,aArray[nJ],aArray[nD])
                uTmp          := aArray[nD]
                aArray[nD]    := aArray[nJ]
                aArray[nJ]    := uTmp
            EndIF
        Next nJ
    Next nI
 
Return(aArray)
 
//-----------------------------------------------------------------------------

//Simulando aEval padrao

//-----------------------------------------------------------------------------
Static Function __aEval(aArray,bEval,nStart,nCount)
 
    Local nD
    Local nJ
    
    DEFAULT nStart := 1
    DEFAULT nCount := Len(aArray)
    
    nJ := nCount
    For nD := nStart To nJ
        //Função Eval() :: http://tdn.totvs.com.br/pages/viewpage.action?pageId=24346635
        Eval(bEval,aArray[nD],nD)
    Next nD
                
Return(aArray)


[]s
иαldσ dj

Comentários

Postagens mais visitadas