Potrzebuję wyciągnąc klientów, którzy zamówili jakąkolwiek książkę w ciągu ostatnich 90 dni, ale nigdy nie zamówili np. Sienkiewicza.
Mamy tabelę customer, order, order_details. Customer łączy się z order, a order z order_detail. Mam coś takiego, ale nie mam pewności, że ten not exists wyciągnie klientów tylko z tych, którzy zamówili jakąkolwiek książke w ciągu ostatnich 90 czy ze wszystkich w bazie?
SELECT customer_id
FROM customer c
WHERE exists (select 1
from order o
inner join c.customer = o.customer_id
where date > curdate() - interval 90 day)
AND NOT exists ( SELECT 1
FROM order o
INNER JOIN order_details od ON o.order_id = od.order_id
WHERE c.customer_id = o.customer_id
AND author = 82)