SELECT DISTINCT a,b,c FROM t
je přibližně ekvivalentní:
SELECT a,b,c FROM t GROUP BY a,b,c
Je dobré si zvyknout na syntaxi GROUP BY, protože je výkonnější.
Pro váš dotaz bych to udělal takto:
UPDATE sales
SET status='ACTIVE'
WHERE id IN
(
SELECT id
FROM sales S
INNER JOIN
(
SELECT saleprice, saledate
FROM sales
GROUP BY saleprice, saledate
HAVING COUNT(*) = 1
) T
ON S.saleprice=T.saleprice AND s.saledate=T.saledate
)