質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.38%
Power BI

Power BIは、マイクロソフト社が提供しているBIツールです。レポートの作成・共有、エクセルや会計システムなどさまざまなソフトウエアのデータをグラフやチャートに変換。データの分析・解析などにも利用できます。

Q&A

解決済

1回答

137閲覧

PowerBI 30分ごとのデータを月別に前月比をもとめたい

ma2hisa

総合スコア1

Power BI

Power BIは、マイクロソフト社が提供しているBIツールです。レポートの作成・共有、エクセルや会計システムなどさまざまなソフトウエアのデータをグラフやチャートに変換。データの分析・解析などにも利用できます。

0グッド

0クリップ

投稿2024/09/20 03:24

実現したいこと

次のようなファクトテーブル('DATE')があります。
日付は30分毎で約2年分、拠点は約1000に及びます。
月ごとの量合計を前月比較したいため、日付テーブル('Calender')とメジャーを次のように作りました。
リレーションは'DATA'[日付]と''Calender'[日付]で多対1

【'DATA'】

日付地域拠点
2023/06/01 0:00:000東北A
2023/06/01 0:30:000東北A
2023/06/01 1:00:001東北A
2023/06/01 1:30:002東北A
2023/06/01 2:00:000東北A
・・・
2024/07/31 23:00:002九州Z
2024/07/31 23:30:001九州Z

【'Calender'】※一部省略
Calender =
ADDCOLUMNS(
DISTINCT('DATA'[日付]),
"年/月", FORMAT ( [日付], "yy/MM" )
)

【メジャー】
前月量=CALCULATE(SUM('DATA'[量]), DATEADD('Calender'[日付].[Date], -1, MONTH))

発生している問題・分からないこと

得たいのは次のような結果ですが、どうも前月量が正しく拾えません。

年/月前月量
23/645
23/75045
23/86050
23/97060
24/6110100
24/7150110

下記のように、量と前月量が同じになってしまいます。

年/月前月量
23/64545
23/75050
23/86060
23/97070
24/6110110
24/7150150

該当のソースコード

特になし

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

日付テーブルを日別のものにし('Calender2')、
ファクトテーブルに日付だけのカラム([date])を作ってリレーションした場合も同じ結果でした。

【'Calender2'】
Calender2 =
ADDCOLUMNS(
CALENDAR("2023/6/1","2024/7/31"),
"年/月", FORMAT ( [date], "yy/MM" )
)

【メジャー】
前月量2= CALCULATE(SUM('DATA'[量]), DATEADD('Calender2'[Date], -1, MONTH))

今まで日にちだけのファクトテーブルでなんの支障もなくできていたのに、時刻が加わっただけでできません。何がだめなのでしょうか。

補足

特になし

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sk.exe

2024/09/20 05:46

> 月ごとの量合計を前月比較したい クエリの段階で全ての集計を行なってしまえばよいのではないでしょうか。
ma2hisa

2024/09/20 10:03

時間帯別も集計表示したいので、日単位に丸めてしまうわけにはいかないのです。
sk.exe

2024/09/24 01:42

「時間帯別に集計表示するクエリ」とは別に、「月ごとに[量]の合計を求め、更に前月の[量]の合計を取得するクエリ」を新たに作成なさればよいのではないでしょうか。
ma2hisa

2024/09/27 05:21

それも考えましたが、もっと簡単な方法をみつけ自己解決しました。
guest

回答1

0

自己解決

カレンダーテーブルを2重にすることで解決しました。
ファクトテーブルには日付・時刻でユニークのカレンダーテーブル(Calender_time)をつなぎ、さらに日付ユニークのカレンダーテーブル(Calender)をつないで、メジャーを作成すると想定通りに算出できました。
DATEADD関数の参照する日付列は、日付がユニークである必要があるようです。(ヘルプと違う、、、)と理解しました。

投稿2024/09/27 05:31

ma2hisa

総合スコア1

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.38%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問