LuckyTemplates の GroupBy: VertiPaq の暗黙関数

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

このチュートリアルでは、LuckyTemplates のストレージ エンジンと暗黙の GroupBy について説明します。パフォーマンスの背後で何が起こっているかを学び、潜在的なボトルネックを確認します。これにより、DAX のパフォーマンスを高速化するために、これらの問題を軽減するためのアイデアや戦略を作成できるようになります。

ストレージ エンジンのクエリは、xmSQL と呼ばれる言語で表現されます。これは実際のプログラミング言語ではなく、ストレージ エンジンの動作を視覚的に表現したものです。これにより、ユーザーはさまざまなクエリの実行時にバックグラウンドで計算が行われている内容を確認できます。

目次

LuckyTemplates の暗黙的な GroupBy

最初に確認する必要があるのは、すべての xmSQL に含まれる暗黙の GroupBy です。

これは、EVALUATE 関数と VALUES 関数を含むサンプル クエリです。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

クエリは、DimCalendar テーブルから年のすべての値を取得します。10 行のデータが返されたことがわかります。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

このプロセスは、クエリが DimCalendar から暦年を選択し、年ごとにグループ化する SQL ステートメントに示されています。クエリには他に何もないため、このステートメントは計算に GroupBy 関数を暗黙的に含んでいます。暗黙的な GroupBy は、集計を使用する場合にさらに顕著になります。

ストレージ エンジン内の集約

集計とは何かを理解するには、DAX Studio に移動し、サーバー タイミングとクエリ プランをオンにします。次に、このサンプル測定を実行します。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

クエリを実行すると、スキャンが 1 つある前のサンプル クエリとは異なり、このメジャーには 2 つあることがわかります。これは、最初のサンプルには DimCalendar Year の値しか含まれていないためです。このサンプル クエリには暦年と集計が含まれています。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

最初のスキャンは実際のクエリです。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

DimCalendar Year を選択し、データ モデルの関係に従って販売データ テーブルから販売数量を合計します。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

データ モデルでは、DimCalendar テーブルは、Fact テーブルの Purchase Date 列から Calendar テーブルの Date 列に続きます。

2 回目のスキャンでは、すべての欠損値が確実に考慮されます。

結果では、売上高が 2015 年から 2018 年までのみ表示されていることがわかります。ただし、2012 年から 2014 年は空白であっても表示されます。

LuckyTemplates の GroupBy: VertiPaq の暗黙関数

結論

DAX Studio のストレージ エンジンは、計算の背後にあるプロセス全体を表示します。これにより、各関数を監視し、DAX のパフォーマンスを低下させる可能性のあるヒットを確認できます。このような情報を使用して、DAX コードの実行における潜在的なボトルネックを軽減するソリューションを作成できます。

DAX の実行が遅い場合は、ストレージ エンジンを調べて、レポートのパフォーマンスを向上させるために何ができるかを見つけてください。


マルチスレッド環境の VertiPaq ストレージ エンジン
LuckyTemplates の VertiPaq 圧縮とストレージ
LuckyTemplates Desktop の DAX Studio とは









Python における Self とは: 実際の例

Python における Self とは: 実際の例

Python における Self とは: 実際の例

RでRDSファイルを保存してロードする方法

RでRDSファイルを保存してロードする方法

R の .rds ファイルからオブジェクトを保存および読み込む方法を学習します。このブログでは、R から LuckyTemplates にオブジェクトをインポートする方法についても説明します。

最初の N 営業日の再考 – DAX コーディング言語ソリューション

最初の N 営業日の再考 – DAX コーディング言語ソリューション

この DAX コーディング言語チュートリアルでは、GENERATE 関数の使用方法とメジャー タイトルを動的に変更する方法を学びます。

LuckyTemplates のマルチスレッド動的ビジュアル手法を使用したインサイトのショーケース

LuckyTemplates のマルチスレッド動的ビジュアル手法を使用したインサイトのショーケース

このチュートリアルでは、マルチスレッド動的ビジュアル手法を使用して、レポート内の動的データ視覚化から洞察を作成する方法について説明します。

LuckyTemplates のフィルター コンテキストの概要

LuckyTemplates のフィルター コンテキストの概要

この記事では、フィルター コンテキストについて説明します。フィルター コンテキストは、LuckyTemplates ユーザーが最初に学習する必要がある主要なトピックの 1 つです。

LuckyTemplates Online Service でアプリを使用する際の最良のヒント

LuckyTemplates Online Service でアプリを使用する際の最良のヒント

LuckyTemplates Apps オンライン サービスが、さまざまなソースから生成されたさまざまなレポートや分析情報の管理にどのように役立つかを示したいと思います。

時間の経過に伴う利益率の変化を分析する – LuckyTemplates と DAX を使用した分析

時間の経過に伴う利益率の変化を分析する – LuckyTemplates と DAX を使用した分析

LuckyTemplates でのメジャー分岐や DAX 数式の結合などの手法を使用して、利益率の変化を計算する方法を学びます。

DAX Studio でのデータ キャッシュのマテリアライゼーションのアイデア

DAX Studio でのデータ キャッシュのマテリアライゼーションのアイデア

このチュートリアルでは、データ キャッシュの具体化のアイデアと、それが結果を提供する際の DAX のパフォーマンスにどのように影響するかについて説明します。

LuckyTemplates を使用したビジネス レポート

LuckyTemplates を使用したビジネス レポート

これまで Excel を使用している場合は、ビジネス レポートのニーズに合わせて LuckyTemplates の使用を開始するのに最適な時期です。

LuckyTemplates ゲートウェイとは何ですか? 知っておくべきことすべて

LuckyTemplates ゲートウェイとは何ですか? 知っておくべきことすべて

LuckyTemplates ゲートウェイとは何ですか? 知っておくべきことすべて