Oracle
 sql >> Base de données >  >> RDS >> Oracle

oracle sql - trouver des articles communs achetés entre deux utilisateurs

Vous décrivez les exigences de base pour une requête d'intersection.

select item.id, item.name
from item, PurchaseLog p, user u
where lower(u.username) = lower('Username1')
AND p.user_id = u.user_id
and item.id = p.itemid
and p.purchasedate between SYSDATE and SYSDATE-365
INTERSECT
select item.id, item.name
from item, PurchaseLog p, user u
where lower(u.username) = lower('Username2')
AND p.user_id = u.user_id
and item.id = p.itemid
and p.purchasedate between SYSDATE and SYSDATE-365

Cela renverra une liste d'item.id et d'item.name qui apparaissent pour les deux utilisateurs.