Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 08-02-2018
Avatar de jhonny
jhonny jhonny is offline
Jhonny Suárez
 
Registrado: may 2003
Ubicación: Colombia
Posts: 7.058
Poder: 30
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
  #2  
Antiguo 08-02-2018
manelb manelb is offline
Miembro
 
Registrado: mar 2017
Posts: 281
Poder: 8
manelb Va por buen camino
La cláusula where evalua cada uno de los registros de la tabla de forma individual para valorar si la fila entra o no en el resultado final de la consulta.

El having evalua la función agregada en cuestión una vez evaluados los registros para valorar si la fila resultante, que puede corresponder a varios registros, debe formar parte del resultado de la consulta.

En tu caso, tal y como apunta jhonny, debería funcionar la consulta que te propone aunque creo que podrías omitir el
Código SQL [-]
OR Fecha IS NULL
por dos cuestiones
1.- Creo recordar que las funciones agregadas omiten directament los valore null
2.- Al especificar
Código SQL [-]
AND EXTRACT(MONTH FROM Fecha) = 2
estas descartando directamente los valores null para la fecha

Saludos
Responder Con Cita
  #3  
Antiguo 09-02-2018
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Gracias por vuestras respuestas. Me han sido muy útiles.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
ibase_affected_rows para SELECT en PHP5 mr_pascale PHP 1 01-02-2008 20:14:09
Salir del for select cuando se cumpla una condición Ivanzinho Firebird e Interbase 8 30-11-2005 21:47:48
*.EoF = mas de una condicion para un solo resultado papulo Varios 8 19-09-2005 16:39:32
Select con una condicion un poco peculiar mrmanuel SQL 6 16-08-2005 12:53:38
Para ejecución de Select repo Firebird e Interbase 0 07-02-2005 17:11:19


La franja horaria es GMT +2. Ahora son las 02:18:50.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi