active_record ( Ruby ) sin Rails - Parte I
Saturday, 28 April , 2007
Actualmente estoy trabajando en un módulo de una aplicación web cuyo objetivo es presentar reportes de accesos a un predio, la aplicación está desarrollada en php y postgresql, los reportes están basados en vistas, dónde tengo una “vista base” llamada “stats_ingresos”, y las demás vistas hacen uso de “stats_ingresos”. Todo muy lindo, pero actualmente este sistema es muy lento, las consultas a estas vistas demoran más 2 minutos lo cual es inaceptable para una aplicación web, entonces decidí pasar esta vista base a tabla, con lo cual el costo de la consulta se reduce a 0. Obviamente esta solución tiene una desvetaja, tengo que actualizar la tabla “stats_ingresos” perdiódicamente, la actualización se va a realizar una vez por día y se actualizarán todos los accesos del mes (ya sé que esto se puede mejorar).
Para ir al grano, he decidido implentar este script de update con ruby + active_record y como metodología bdd usando rspec.
Esta es la tabla que va a reemplazar a la “vista base”:
CREATE TABLE stats_ingresos ( id SERIAL NOT NULL, nombre VARCHAR(25), apellido VARCHAR(25), dni VARCHAR(12), id_institucion INTEGER, institucion VARCHAR(50), dia SMALLINT, mes SMALLINT, anio SMALLINT, ts timestamp, PRIMARY KEY (id) );
