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

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

新規登録して質問してみよう
ただいま回答率
85.47%
BigQuery

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

Q&A

1回答

241閲覧

Bigqueryで含まれる言葉別かつ日付別に集計をしたい

rjberger19

総合スコア33

BigQuery

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

0グッド

1クリップ

投稿2022/02/26 13:38

Bgquery上に以下のようなテーブルがあった場合に、日付ごとかつキーワード別に数を集計したいのですがそのようなことは可能でしょうか?

日付 │テキスト
------------│---------------
1/1. │楽しかったです
1/1.  │そこそこ
1/1. │微妙
1/1. │微妙
1/2 │楽しかったです
1/2. │そこそこ
1/2  │そこそこ

↓集計

日付│楽し│そこ│微妙
ーーーーーーーーーーーーーーーーーーーーーーーーー
1/1 │1 │1  │2
1/2 │1 │2  │0

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

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

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

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

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

guest

回答1

0

こんな感じでしょうか。

ご希望通り列として持つなら https://dev.classmethod.jp/articles/sql-data-horizontal-vertical/ の「縦持ちを横持ちに」を参考に。
配列がいいなら array_agg で。

with data as ( select date('2022-01-01') as mydate,'楽しかったです' as str union all select date('2022-01-01') as mydate,'楽しかったです' as str union all select date('2022-01-01') as mydate,'そこそこ' as str union all select date('2022-01-02') as mydate,'楽しかったです' as str ), list as ( select '楽し' as word union all select 'そこ' as word union all select '微妙' as word ), result as ( select * from data, list where data.str like '%'||list.word||'%' ) select mydate, word, count(*) from result group by mydate, word

結果

2022-01-01 | 楽し | 2 2022-01-01 | そこ | 1 2022-01-02 | 楽し | 1

投稿2022/02/27 05:17

68user

総合スコア2005

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

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

rjberger19

2022/02/27 15:33

ありがとうございました!!! 頂いたクエリでできそうです! ちなみに検索キーワードに使うキーワードをor条件で複数入れる場合は list as ( select '楽し' OR '楽ぴ' as word union all select 'そこ' as word union all select '微妙' as word ), のようにするのかと思ったのですが、どのように書けば構文上正しいかご教示頂けないでしょうか。。 のように
68user

2022/02/28 01:18

こんな感じでしょうか。 with data as ( select date('2022-01-01') as mydate,'楽しかったです' as str union all select date('2022-01-01') as mydate,'楽しかったです' as str union all select date('2022-01-01') as mydate,'楽ぴ' as str union all select date('2022-01-01') as mydate,'そこそこ' as str union all select date('2022-01-02') as mydate,'楽しかったです' as str ), list as ( select '楽し' as word, '楽し' as match_word union all select '楽し' as word, '楽ぴ' as match_word union all select 'そこ' as word, 'そこ' as match_word union all select '微妙' as word, '微妙' as match_word ), result as ( select * from data, list where data.str like '%' || list.match_word || '%' ) select mydate, word, count(*) from result group by mydate, word
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問