[英]How do I get transactions that contains the same items from another table using BigQuery?
假設我有一個包含項目列表的 BigQuery 表,像這樣捆綁在一起:
捆綁名稱 | 產品名稱 |
---|---|
捆綁包 1 | 蘋果 |
捆綁包 1 | 西瓜 |
捆綁包 2 | 葡萄 |
捆綁包 2 | 檸檬 |
然后,我還有一個包含交易列表的 BigQuery 表,其中一個交易可以包含多個產品,如下所示:
交易編號 | 產品名稱 |
---|---|
交易 1 | 蘋果 |
交易 1 | 西瓜 |
交易 2 | 葡萄 |
交易 2 | 檸檬 |
交易 2 | 香蕉 |
交易 3 | 菠蘿 |
交易 3 | 獼猴桃 |
交易 3 | 葡萄 |
我想從捆綁列表中獲取包含確切項目的交易。 在這種情況下,我應該得到交易 1,因為它在交易中有一個與捆綁包 1(蘋果和西瓜)完全匹配的產品組合,而交易 2 因為它也有一個與捆綁包 2(葡萄和檸檬)匹配的產品組合。
我不能使用 JOIN,因為如果我使用 Product Name 加入 Bundle 表和 Transaction 表,Transaction 3 也將被包括在內,因為它與 Bundle 2 (Grapes) 具有相同的產品名稱。
我怎樣才能做到這一點? 提前致謝
考慮以下方法
select transactionID, bundleName
from (
select transactionID, array_agg(distinct productName) as products
from transactions group by transactionID
) t1, (
select bundleName, array_agg(distinct productName) as products
from bundles group by bundleName
) t2
where (
select count(product1) = count(product2)
from t2.products product2
left join t1.products product1
on product1 = product2
)
如果應用於您問題中的示例數據 - output 是
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.