Masz rację - możesz zrobić lepiej. Zobacz ten artykuł autorstwa Quassnoi o szczegóły, ale wniosek jest następujący:
Twoje zapytanie przepisane przy użyciu NOT IN
może wyglądać tak:
SELECT *
FROM posts
WHERE posts.id NOT IN (SELECT post_id
FROM comments
WHERE comments.comment_type = 'good'
AND comments.created_at BETWEEN '2010-05-01 00:00:00'
AND '2010-05-01 23:59:59')