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

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

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

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

SQL

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

Q&A

解決済

1回答

3108閲覧

standardsqlで、年齢計算でのエラーの理由がわからない

akm2929

総合スコア12

BigQuery

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

SQL

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

0グッド

0クリップ

投稿2018/11/03 13:19

編集2018/11/03 13:40

standardsql

1#standardsql 2with T as ( 3 select 4 user_id 5 ,user_properties.value.string_value as birthday 6 7 from 8 `全日付のテーブル` 9 ,unnest(user_properties) user_properties 10 where ( 11 _TABLE_SUFFIX between "20180707" 12 and 13 FORMAT_DATE ("%Y%m%d", DATE_SUB(CURRENT_DATE(), INTERVAL 1 DAY)) 14 ) 15 and 16 app_info.install_source = "iTunes" 17 and 18 date(TIMESTAMP_ADD (timestamp_micros(user_first_touch_timestamp),interval device.time_zone_offset_seconds SECOND)) > Date("2018-07-06") 19 and 20 date(TIMESTAMP_ADD(timestamp_micros(user_first_touch_timestamp), interval device.time_zone_offset_seconds SECOND)) < CURRENT_DATE('Asia/Tokyo') 21 and 22 date(TIMESTAMP_ADD(timestamp_micros(user_first_touch_timestamp), interval device.time_zone_offset_seconds SECOND)) = parse_date("%Y%m%d", event_date) 23 and 24 user_id is not null 25 and 26 ----誕生日入力されてるユーザーのみ抽出 27 user_properties.key = "birthdate" 28 limit 10000 29) 30 31,users as ( 32 select 33 user_id as id 34 from 35 T 36 group by user_id 37) 38 39,age as ( 40 select 41 user_id 42 ,cast((cast(FORMAT_DATE("%Y%m%d",CURRENT_DATE()) as int64)-cast(FORMAT_DATE("%Y%m%d",date(T.birthday)) as int64))/10000 as int64) as age 43 44 from 45 T 46) 47select * 48from age

user_id|age
のビューをつくる段階なのですが、ageのビューでのエラーが何が原因かわかりません。
おそらく日付の扱いでミスがあるのですが、そもそも日付の型変換についてあまりよくわかっていないため、なにがだめなのかがわからないです。

ちなみに、birthdayのカラムは以下のようになってます。
1995/01/14 00:00:00
1995/01/14 00:00:00
1995/01/14 00:00:00

##追記
エラー文
Error running query: No matching signature for function DATE for argument types: STRING. Supported signatures: DATE(TIMESTAMP, [STRING]); DATE(DATETIME); DATE(INT64, INT64, INT64) at [43:88]
43行目

standardsql

1 ,cast((cast(FORMAT_DATE("%Y%m%d",CURRENT_DATE()) as int64)-cast(FORMAT_DATE("%Y%m%d",date(T.birthday)) as int64))/10000 as int64) as age 2コード

ご回答いただけると幸いです。よろしくお願いします。

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

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

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

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

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

kaba

2018/11/03 13:44

エラーメッセージを記載すれば解決が早いと思います
akm2929

2018/11/03 13:45

すいません、追記させていただきました。
guest

回答1

0

ベストアンサー

date(T.birthday)がエラーで、原因はT.birthdayの型がSTRINGだからと書いてあります。
T.birthdayをTIMESTAMPかDATETIMEで定義するか、もしくはdatetimeにキャストするか、
int64で定義してcastするのをやめるかするといいです

datetimeにキャストする例
修正前 date(T.birthday)
修正後 CAST(T.birthday AS datetime)

投稿2018/11/03 13:52

編集2018/11/04 01:39
kaba

総合スコア314

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

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

akm2929

2018/11/03 16:34

すいません、未熟すぎてどういうことなのかがわかりません… コードで教えていただけると嬉しいです。。。
kaba

2018/11/04 01:42

依頼通り、回答を修正しました。 今後技術者としてやっていくつもりなら、即物的にコードで示してもらうよりもわずかでも自分で解決出来る実力を付けたほうがよいのではないですか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問