data:image/s3,"s3://crabby-images/43b84/43b84dd1b5c333f85240a2eda449f1fb6ea95a28" alt=""
Power BI Performance analyzer
In Power BI è disponibile un utile tool Performance analyzer che torna utile per analizzare le query eseguite.
Nel risultato dell'analisi compare sia la query in formato DAX sia, nel caso di direct query, la query nel formato nativo della sorgente a cui è collegato.
Il tool si trova in View / Performance analyzerdata:image/s3,"s3://crabby-images/246c4/246c41e4759ff24df7740725b35fad873d1cf093" alt="Icona"
Icona si apre un nuovo pannello data:image/s3,"s3://crabby-images/42ba5/42ba5972f29232ec577b9a08712735056f1a1435" alt="Pannello Performance analyzer"
Pannello Performance analyzer e tramite il pulsante Start recording si puù avviare l'analisi.
Una volta avviato su ogni visual compare un pulsante Analyze this visualdata:image/s3,"s3://crabby-images/c30e8/c30e83bf259dafc561424c94f5327c533120b460" alt="Starting"
Starting premendolo la visualizzazione si aggiorna con alcune metriche oltre ad avere la possibilità di copiare la query generata con il pulsante Copy querydata:image/s3,"s3://crabby-images/94fb2/94fb2cdad7c5bd2c358e554bf6a84ffb57d4551c" alt="Recording"
Recording
In questo caso, con una sorgente importata, la query DAX è questa:
Se faccio la stessa cosa sulla prima tabella con un ordine dei campi differente, ovviamente, ho una query DAX diversadata:image/s3,"s3://crabby-images/8530c/8530cae473207e9221170eb42e968101c9b1721e" alt="Confronto query DAX"
Confronto query DAX ma l'ordine delle colonne comporta anche un diverso comportamento dei visualdata:image/s3,"s3://crabby-images/88123/881231c1efdf9e68d35374c154372cc6b769f0d0" alt="Dati diversi"
Dati diversi in entrambi i casi ho impostato sulla colonna Code il flag Show items with no datadata:image/s3,"s3://crabby-images/c8244/c824468f98be0ff1630a4c55ede231c8c3501bb4" alt="Show items with no data"
Show items with no data
Nel caso di una tabella SQL Server collegata in Direct Query la query DAX è simile a questa
dove viene riportata anche la query nativa in T-SQL.
Nel risultato dell'analisi compare sia la query in formato DAX sia, nel caso di direct query, la query nel formato nativo della sorgente a cui è collegato.
Il tool si trova in View / Performance analyzer
data:image/s3,"s3://crabby-images/246c4/246c41e4759ff24df7740725b35fad873d1cf093" alt="Icona"
data:image/s3,"s3://crabby-images/42ba5/42ba5972f29232ec577b9a08712735056f1a1435" alt="Pannello Performance analyzer"
Una volta avviato su ogni visual compare un pulsante Analyze this visual
data:image/s3,"s3://crabby-images/c30e8/c30e83bf259dafc561424c94f5327c533120b460" alt="Starting"
data:image/s3,"s3://crabby-images/94fb2/94fb2cdad7c5bd2c358e554bf6a84ffb57d4551c" alt="Recording"
In questo caso, con una sorgente importata, la query DAX è questa:
// DAX Query
DEFINE
VAR __DS0Core =
SUMMARIZECOLUMNS(
ROLLUPADDISSUBTOTAL(
ROLLUPGROUP('Vendite'[Data], 'CodiciProdotto'[Description], 'CodiciProdotto'[Code]), "IsGrandTotalRowTotal"
),
"SumQuantità", CALCULATE(SUM('Vendite'[Quantità]))
)
VAR __DS0PrimaryShowAllCompat =
ADDCOLUMNS(
KEEPFILTERS(
FILTER(
KEEPFILTERS(
GENERATEALL(
KEEPFILTERS(VALUES('Vendite'[Data])),
CALCULATETABLE(
GENERATEALL(
KEEPFILTERS(
FILTER(
KEEPFILTERS(VALUES('CodiciProdotto'[Description])),
CALCULATE(NOT(ISEMPTY('Vendite')))
)
),
CALCULATETABLE(
FILTER(
KEEPFILTERS(VALUES('CodiciProdotto'[Code])),
CALCULATE(NOT(ISEMPTY('Vendite')))
)
)
)
)
)
),
OR(
OR(
NOT(ISBLANK('Vendite'[Data])),
NOT(ISBLANK('CodiciProdotto'[Description]))
),
NOT(ISBLANK('CodiciProdotto'[Code]))
)
)
),
"IsGrandTotalRowTotal", FALSE
)
VAR __DS0PrimaryReordered =
SELECTCOLUMNS(
KEEPFILTERS(__DS0Core),
"'Vendite'[Data]", 'Vendite'[Data],
"'CodiciProdotto'[Description]", 'CodiciProdotto'[Description],
"'CodiciProdotto'[Code]", 'CodiciProdotto'[Code],
"IsGrandTotalRowTotal", [IsGrandTotalRowTotal]
)
VAR __DS0PrimaryShowAll =
NATURALLEFTOUTERJOIN(
SUMMARIZE(
UNION(__DS0PrimaryReordered, __DS0PrimaryShowAllCompat),
'Vendite'[Data],
'CodiciProdotto'[Description],
'CodiciProdotto'[Code],
[IsGrandTotalRowTotal]
),
__DS0Core
)
VAR __DS0PrimaryWindowed =
TOPN(
502,
__DS0PrimaryShowAll,
[IsGrandTotalRowTotal],
0,
'CodiciProdotto'[Description],
1,
'Vendite'[Data],
1,
'CodiciProdotto'[Code],
1
)
EVALUATE
__DS0PrimaryWindowed
ORDER BY
[IsGrandTotalRowTotal] DESC,
'CodiciProdotto'[Description],
'Vendite'[Data],
'CodiciProdotto'[Code]
Se faccio la stessa cosa sulla prima tabella con un ordine dei campi differente, ovviamente, ho una query DAX diversa
data:image/s3,"s3://crabby-images/8530c/8530cae473207e9221170eb42e968101c9b1721e" alt="Confronto query DAX"
data:image/s3,"s3://crabby-images/88123/881231c1efdf9e68d35374c154372cc6b769f0d0" alt="Dati diversi"
data:image/s3,"s3://crabby-images/c8244/c824468f98be0ff1630a4c55ede231c8c3501bb4" alt="Show items with no data"
Nel caso di una tabella SQL Server collegata in Direct Query la query DAX è simile a questa
// DAX Query
DEFINE
VAR __DS0Core =
SUMMARIZE('categories', 'categories'[Category], 'categories'[ID])
VAR __DS0PrimaryWindowed =
TOPN(501, __DS0Core, 'categories'[Category], 1, 'categories'[ID], 1)
EVALUATE
__DS0PrimaryWindowed
ORDER BY
'categories'[Category], 'categories'[ID]
// Direct Query
SELECT
TOP (501) [t4].[ID],[t4].[Category]
FROM
(
(
select [$Table].[ID] as [ID],
[$Table].[Category] as [Category],
[$Table].[modified] as [modified]
from [dbo].[categories] as [$Table]
)
)
AS [t4]
GROUP BY [t4].[ID],[t4].[Category]
ORDER BY [t4].[Category]
ASC
,[t4].[ID]
ASC