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

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

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

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

date

dateは、date型や日付に関する関数や処理についてのタグです

SQL

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

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

解決済

1回答

1752閲覧

bigqueryで日付に関する質問(date_add、date_sub)

HR_query

総合スコア2

BigQuery

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

date

dateは、date型や日付に関する関数や処理についてのタグです

SQL

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

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

0クリップ

投稿2021/03/17 03:27

編集2021/03/17 03:41

前提・実現したいこと

bigqueryでwith句のdateに対してdate_add/date_subをすると、エラーが表示されます。
この理由を知りたいです。

発生している問題・エラーメッセージ

No matching signature for function DATE_ADD for argument types: STRUCT<s_date DATE>, INTERVAL INT64 DATE_TIME_PART. Supported signature: DATE_ADD(DATE, INTERVAL INT64 DATE_TIME_PART)

該当のソースコード

with s_date as (select date("2021-03-17") as s_date), dateadd as (select DATE_ADD(s_date, INTERVAL 149 DAY) from s_date)

試したこと

以下の記載方法だと実行できることは確認しています。

with s_date as (select date("2021-03-17") as s_date), dateadd as (select DATE_ADD((select * from s_date), INTERVAL 149 DAY) from s_date)

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

Orlofsky

2021/03/17 03:39

[PL/SQL]タグは不要では?
HR_query

2021/03/17 03:42

失礼しました、修正しました
guest

回答1

0

ベストアンサー

argument typesというエラーですから、withで、selectしている項目のエイリアスがwithで指定している名称と被っているから、意図通りに参照出来ていないのではないでしょうか。
以下の様にすると、改善されませんか?

SQL

1with 2 s_date as ( 3 select date("2021-03-17") as s_date_value 4 ) 5, dateadd as ( 6 select DATE_ADD(s_date_value, INTERVAL 149 DAY) as dateadd_value from s_date 7 ) 8select * from dateadd

投稿2021/03/17 07:25

編集2021/03/17 07:56
sazi

総合スコア25195

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

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

HR_query

2021/03/17 08:12

ありがとうございます、エラー解消できました。 名称については盲点でした。 今後似たようなときも注意できるのでとても助かりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問