Imagina que sin el having la consulta te devuelve algo como:
Cita:
1, 2, 'AlDia', 'Anual'
2, 2, 'AlDia', 'Anual'
3, 2, 'EnMora', 'Mensual'
4, 3, 'AlDia', 'Anual'
5, 4, 'AlDia', 'Anual'
|
Si a ello le aplicas el having que mencionas...
"HAVING EXTRACT(MONTH FROM MAX(Fecha)) = 2", entonces sobre la consulta anterior Firebird aplicaría otro filtro más... (Como si de una "minitabla" se tratara), quedando así... ya que le has dicho que solamente te interesan los meses de febrero...
Cita:
1, 2, 'AlDia', 'Anual'
2, 2, 'AlDia', 'Anual'
3, 2, 'EnMora', 'Mensual'
|
Ahora bien, para este caso en particular, lo mismo deberías lograr si haces desde el principio lo siguiente:
Código SQL
[-]SELECT DISTINCT Codigo, EXTRACT(MONTH FROM MAX(Fecha)), Situacion, Periodo
FROM Rc03
WHERE (Fecha < :Fecha OR Fecha IS NULL)
AND Periodo = 'Anual'
AND EXTRACT(MONTH FROM Fecha) = 2
GROUP BY 1, 3, 4 ORDER BY 4, 3, 2