Twoja najgłębsza selekcja nie używa niczego od siebie w klauzuli where, więc zawsze znajduje coś dla dudziarza. Wypróbuj
select distinct b.profname from committee b
where not exists (
select commname from committee a
where a.profname = 'piper' and not exists (
select commname from committee c
where c.profname=b.profname and c.commname=a.commname
)
);