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 :: DNA Tech Editor xBase/SQL

DNA Tech Editor xBase/SQL 


 O Harbour permite criar, testar, e executar código xBase online. Ex.:


Senti falta de algo semelhante no Protheus. Então, decidi implementar algumas melhorias no DNA Tech Editor xBase/SQL . Por enquanto apenas para ser executado no smartclient, mas futuramente.... quem sabe!



***Exemplo de Código criado no DNA Tech Editor xBase/SQL 

```xBase


#pragma @__BeginText@
{
    "Includes" : "C:\\totvs\\includes;C:\\GitHub\\naldodj-tlpp\\include",
    "MainFunction" : "u_DNaEdtTst()"    
}
#pragma @__EndText@

#include "totvs.ch"

static Function __Teste(n) as variant
return(MsgInfo(n,ProcName()))

function u_DNaEdtTst() as variant

    local n,d:=10 as numeric
    __cInternet:=NIL
    for n:=1 to d
        __Teste(n)
    next n

    dna.tech.dirtools():BrowseFiles("Includes","c:\totvs\includes\","*.*")
   
return(nil)


```



...






***Um outro Exemplo de Código criado no DNA Tech Editor xBase/SQL 
```xBase
#pragma @__BeginText@
{
    "Includes" : "C:\\totvs\\includes;C:\\GitHub\\naldodj-tlpp\\include",
    "MainFunction" : "u_DNaEdtTst()"    
}
#pragma @__EndText@

#include "totvs.ch"

static function MyChangeQuery(cQuery)
    local nAT as numeric
    cQuery:=allTrim(cQuery)
    cQuery:=strTran(cQuery,"`","")
    nAT:=AT("SELECT",Upper(cQuery))
    cQuery:=subStr(cQuery,nAT)
    cQuery:=strTran(cQuery,";","")
    cQuery:=strTran(cQuery,chr(13),"")
    cQuery:=strTran(cQuery,chr(10),"")
    cQuery:=ChangeQuery(cQuery)
return(cQuery)

function u_DNaEdtTst() as variant

    local cQuery as character

    beginContent var cQuery
        SELECT SX5.X5_FILIAL
              ,SX5.X5_TABELA
              ,SX5.X5_DESCRI
          FROM SX5030 SX5
         WHERE SX5.D_E_L_E_T_=' '
    endContent
    
    cQuery:=strTran(cQuery,"SX5030",RetSQLName("SX5"))
    
    dna.tech.sqlTools():QueryFWMBrowse(MyChangeQuery(cQuery))
    
return(nil)
```





Mas a idéia básica é essa. Ainda está em desenvolvimento. 

Quer ter acesso a essa e a outras incríveis ferramentas desenvolvidas por este que vos escreve. Compartilhe com o Projeto "Eu sou Ninja (Abada Capoeira)" (BlackTDN :: Social :: Rifa Festival da Arte Capoeira Projeto Eu Sou Ninja) e tenha a chance de concorrer a todo código de minha biblioteca pessoal.

Comentários

Postagens mais visitadas