タイトルが分かりにくく申し訳ありません。
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で返る
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/08/26 16:48