簡體   English   中英

如何使用 BigQuery 從另一個表中獲取包含相同項目的交易?

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM