Chevere el ejercicio, me puse en la tarea de hacerlo, pero en Firebird 1.5.2, espero que
te sirva.
Meta usted unos valores, por aca en Colombia se le llaman contadores a los dispositivos
que cuentan el numero de metros cubicos que consume una casa y en algunos sistemas
para servicios publicos se considera el numero de contador como identificador unico.
En Colombia se le llama la 'critica' a la informacion de consumos de los 6 meses anteriores
para cualquier recibo de servicio publicos domiciliarios, y es de obligatorio cumplimiento
que esos valores aparezcan en el recibo.
El indice sugerido es mas rapido que uno basado en (fecha + contador).
El pedacito de codigo 'and :i < 3' es una ventaja de los procedimientos almacenados, es decir,
puede introducirse dentro del for select una condicion de salida que no tiene nada que ver con
los campos de la tabla seleccionada !!!
Haste unas pruebas de rendimiento con SQLHammer, es Open SOurce y cuenta con un analizador
de consultas (bueno realmente muestra las estadisticas de la consulta pero es muy bueno).
Código SQL
[-]
CREATE TABLE LECTURA (
ID_LECTURA INTEGER NOT NULL,
CONTADOR INTEGER NOT NULL,
FECHA DATE NOT NULL,
VALOR INTEGER NOT NULL);
alter table LECTURA
add constraint PK_LECTURA
primary key (ID_LECTURA);
CREATE INDEX IDX_LECTURA_CONTADORFECHA
ON LECTURA (CONTADOR,FECHA);
SET TERM ^ ;
CREATE PROCEDURE SP_CRITICA (
CONTADOR INTEGER,
FECHA_REFERENCIA DATE)
RETURNS (
VALOR_1 INTEGER,
VALOR_2 INTEGER)
AS
DECLARE VARIABLE I INTEGER;
DECLARE VARIABLE VALOR_AUXILIAR INTEGER;
begin
valor_1 = 0;
valor_2 = 0;
i = 0;
for select valor
from lectura
where contador = :contador
and fecha <= :fecha_referencia
and :i < 3
order by fecha desc
into :valor_auxiliar
do begin
if (i = 0) then
valor_1 = valor_auxiliar;
else if (i = 1) then
valor_2 = valor_auxiliar;
i = i + 1;
end
suspend;
end
^
SET TERM ; ^
GRANT SELECT ON LECTURA TO PROCEDURE SP_CRITICA;
GRANT EXECUTE ON PROCEDURE SP_CRITICA TO SYSDBA;