Active record
En Ingeniería de software, active record es un patrón de proyecto encontrado en aplicaciones que almacenan sus datos en Bases de datos relacionales. Fue llamado así por Martin Fowler en su libro Patterns of Enterprise Application Architecture[1]. La interfaz de un cierto objeto debe incluir funciones como por ejemplo insertar (INSERT), actualizar (UPDATE), eliminar (DELETE) y propiedades que correspondan de cierta manera directamente a las columnas de la base de datos asociada.
Active record es un enfoque para aceso de datos en una base de datos. Una tabla de la base de dados o vista (view) está envuelta en una clase. Por lo tanto, una instancia de un objeto está ligada a un único registro (tupla) en la tabla. Después de crear y grabar un objeto, un nuevo registro es adicionado a la tabla. Cualquier objeto cargado obtiene su información a partir de la base de datos. Cuando un objeto es actualizado, un registro correspondiente en la tabla también es actualizado. Una clase de envoltura implementa los métodos de acceso (setter e getter) o propiedades para cada columna en la tabla o vista.
Este patrón suele ser utilizado por herramientas de persistencia de objetos en el mapeo objeto-relacional. Generalmente las relaciones de llave foránea serán expuestas como una instancia de objeto de tipo apropiado por medio de una propriedad.
Implementación
Su implementación puede ser encontrada en varios frameworks para diversos ambientes de programación.
Por ejemplo, si una base de datos
posee una tabla productos
con las columnas nombre
(tipo String) y valor
(tipo Number) y un patrón de proyecto Active Record es implementado en la clase Producto
, el pseudo-código:
producto = new Producto() producto.nombre = "Producto ejemplo" producto.valor = 123.45 producto.save()
Creará un nuevo registro en la tabla productos
con los valores proporcionados lo cual vendría siendo equivalente al comando SQL:
INSERT INTO productos (nombre, valor) VALUES ('Producto ejemplo', 123.45);
De la misma forma, una clase puede ser usada para consultar una BD:
b = Producto.find_first("nombre", "televisor")
Este código creará un nuevo objeto de tipo Producto
basado en el primer registro encontrado de la tabla productos
donde la columna nombre
contiene un valor "televisor". El comando SQL equivalente puede ser similar al siguiente (dependiendo de los detalles de la implementación SQL de la base de datos):
SELECT * FROM productos WHERE nombre = 'televisor' LIMIT 1; -- MySQL o PostgreSQL
Enlaces externos
- Implementaçión en Java (en inglés)
- Implementaçión en .NET (en inglés)
- Implementaçión en Ruby (en inglés)
- Implementaçión en PHP (en inglés)
- Página del Proyeto AIR Active Record (en inglés)
Referencias
- ↑ Fowler, Martin (2003). Patterns of enterprise application architecture. Addison-Wesley. ISBN 978-0-321-12742-6.