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

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

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

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

SQL

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

Q&A

解決済

1回答

530閲覧

where区で指定するluidが同一レコードに特定カラムのデータがある場合にTrueを返すSQLの書き方を教えて頂きたいです。

amaturePy

総合スコア131

BigQuery

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

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

SQL

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

0グッド

0クリップ

投稿2020/08/26 15:57

タイトルが分かりにくく申し訳ありません。
GoogleのBigQueryを扱いながらSQLを書いています。
ですが、なかなか思い通りの結果を出すことができす、ご質問させて頂きたいです。
ご質問させて頂きたいのは、以下のことを実現するSQLになります。

【実現したいこと】 where区で指定するluidと同じレコード内にあるorderidカラムに値が入っていれば Trueを返し、無ければFalseを返す

現状試したSQLではluidカラムに値があれば全てTrueを返してしまうなど、思い通りの結果を出してくれるSQLを書くことができませんでした。ご教授頂ければ幸いです。
luidはシステム上のuseridになっておりまして、セキュリティの関係上一部マスキングさせて頂いております。
以下実装した一部SQLになります。ご査証頂ければと思います。

test-266110.conversion_log.conversion_log_ pgid | luid | orderid | cv_date | 1111 | UUU1 | 1234 | 2020-08-01 ←このluidの場合はorderidに値あがあるためTrueを返したいです 2222 | UUU2 | | ←このluidの場合はorderidに値あがないためFalseを返したいです
【実装したSQL①】 SELECT EXISTS(SELECT orderid FROM `test-266110.conversion_log.conversion_log_2020*` WHERE luid = "Uc8bb65587eXXXXXXXXX" limit 1000) →luidがテーブル内に存在すれば同一レコードに存在するordridカラムの値の有無に関係なくTrueが返る →luidがテーブルに存在しなければFalseが返る 【実装したSQL②】 SELECT CASE WHEN EXISTS(SELECT orderid FROM `test-266110.conversion_log.conversion_log_2020*` WHERE luid = "Udd05f656543dxxxxxxxxxxx" limit 1000) THEN 1 -- 'ALL' ELSE 0 -- 'NOT ALL' end →結果が全て1で返る

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

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

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

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

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

guest

回答1

0

ベストアンサー

orderid の値の有無の判定が不足しています。

SQL

1select exists( 2 SELECT 1 3 FROM `test-266110.conversion_log.conversion_log_2020*` 4 WHERE luid = "Uc8bb65587eXXXXXXXXX" 5 AND orderid is not null 6 )

投稿2020/08/26 16:11

sazi

総合スコア25327

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

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

amaturePy

2020/08/26 16:48

ありがとうございます!! こちら私の説明不足になるのですが、orderidのカラムはデータが無い場合はnullではなく空でした。 そのため頂いたコードを参考にwhere以下をorderid != ''に変更させて頂き解決いたしました!! 大変助かりました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問