🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
BigQuery

BigQueryは、Google Cloud Platformが提供しているビッグデータ解析サービス。数TB(テラバイト)またはPB(ペタバイト)の膨大なデータに対し、SQL風のクエリを実行し、高速で集計・分析を行うサービスです。

参照

参照は、プログラミングにおいて変数や関数といったメモリ空間上での所在を指示するデータのことを指します。その中にはデータ自体は含まれず、他の場所にある情報を間接的に指示するプログラムです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

データ構造

データ構造とは、データの集まりをコンピュータの中で効果的に扱うために、一定の形式に系統立てて格納する形式を指します。(配列/連想配列/木構造など)

再帰

情報工学における再帰とは、プログラムのあるメソッドの処理上で自身のメソッドが再び呼び出されている処理の事をいいます。

Q&A

解決済

2回答

1879閲覧

【SQL】範囲日付のカラムを対象年月に変換したい

engineer_takuto

総合スコア5

BigQuery

BigQueryは、Google Cloud Platformが提供しているビッグデータ解析サービス。数TB(テラバイト)またはPB(ペタバイト)の膨大なデータに対し、SQL風のクエリを実行し、高速で集計・分析を行うサービスです。

参照

参照は、プログラミングにおいて変数や関数といったメモリ空間上での所在を指示するデータのことを指します。その中にはデータ自体は含まれず、他の場所にある情報を間接的に指示するプログラムです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

データ構造

データ構造とは、データの集まりをコンピュータの中で効果的に扱うために、一定の形式に系統立てて格納する形式を指します。(配列/連想配列/木構造など)

再帰

情報工学における再帰とは、プログラムのあるメソッドの処理上で自身のメソッドが再び呼び出されている処理の事をいいます。

0グッド

0クリップ

投稿2021/01/18 23:43

実現したいこと

該当テーブルのカラムとして、開始日付、終了日付を保持しており、
その2カラムを対象年月に変換したいと考えております。
※対象年月に集計後、同一テーブルの金額を計算する予定ですが、省略しております。

発生している問題

期間を含む対象年月ごとに集計したいのですが、横持ちしている日付を、
対象年月に変換する良い方法が見つからず困っております。

検討事項

  • with句を使った再帰クエリと結合すれば良いのですが、

BiqQueryでは利用できないため、他の方法で検討しております。

データイメージ

対象テーブルの定義は以下のとおりです。

フィールド名タイプモード
idINTEGERNULLABLE
開始日付TIMESTAMPNULLABLE
終了日付TIMESTAMPNULLABLE

参照データは以下のとおりです。

id開始日付終了日付
A2021-01-012021-02-28
B2020-12-012021-02-28

集計結果イメージは以下のとおりです。

id対象年月
A2021-01-01
A2021-02-01
B2020-12-01
B2021-01-01
B2020-02-01

補足情報(FW/ツールのバージョンなど)

  • GCP BigQuery

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

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

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

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

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

guest

回答2

0

ベストアンサー

連続した日付を生成したいのであればGENERATE_DATE_ARRAYGENERATE_TIMESTAMP_ARRAYを利用することが多いと思います。

なお「対象テーブル」を「集計結果イメージ」に変換する方法ですが、生成した年月マスタ(以下ではSとしている)と「対象テーブル」をCROSS JOINしてしまうのが手っ取り早そうです。

sql

1DECLARE min_date, max_date DATE; 2 3SET (min_date, max_date) = ( 4 SELECT AS STRUCT 5 EXTRACT(DATE FROM TIMESTAMP_TRUNC(MIN(開始日付), MONTH)), 6 EXTRACT(DATE FROM TIMESTAMP_TRUNC(MIN(終了日付), MONTH)) 7 FROM 対象テーブル 8); 9 10WITH S AS ( 11 SELECT TIMESTAMP(target_date) AS target_timestamp 12 FROM UNNEST(GENERATE_DATE_ARRAY(min_date, max_date, INTERVAL 1 MONTH)) AS target_date 13) 14SELECT id, target_timestamp 15FROM 対象テーブル, S 16WHERE target_timestamp BETWEEN 開始日付 AND 終了日付;

投稿2021/01/19 10:39

neko_the_shadow

総合スコア2349

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

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

engineer_takuto

2021/01/19 12:09

解決しました!ありがとうございます!
guest

0

with句を使った再帰クエリと結合すれば良いのですが、BiqQueryでは利用できないため

GENERATE_ARRAY()UNNEST()を組み合わせれば同じことが出来ます。
BigQueryで無から連番のレコードを生成する方法

投稿2021/01/19 07:53

sazi

総合スコア25327

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

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

engineer_takuto

2021/01/19 12:10

ご回答ありがとうございます!解決しました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問