select
o.*,
SUM(if(ol.status = "Approved" and (ol.end_date > now() or end_date is null), 1, 0)) as cond1,
SUM(if(ol.status = "Pending" and (ol.end_date != now() or end_date is null), 1, 0)) as cond2
from
outreach o
left join
outreach_links ol on ol.outreach_id = o.id
group by
o.id
having
cond1 = 0 and cond2 != 1
;
Не съм сигурен дали това търсите, но можете да опитате.cond2 !=1 прави вашето условие COUNT(id) =1 (ако има повече от един свързан идентификатор в outreach_links cond2 ще бъде по-голям от 1)