Ver Mensaje Individual
  #2  
Antiguo 08-02-2018
Avatar de jhonny
jhonny jhonny is offline
Jhonny Suárez
 
Registrado: may 2003
Ubicación: Colombia
Posts: 7.058
Reputación: 29
jhonny Va camino a la famajhonny Va camino a la fama
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
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!"

http://www.purodelphi.com/
http://www.nosolodelphi.com/
Responder Con Cita