Ir al contenido

Active record

De Wikipedia, la enciclopedia libre
Esta es una versión antigua de esta página, editada a las 23:05 22 sep 2014 por 2rombos (discusión · contribs.). La dirección URL es un enlace permanente a esta versión, que puede ser diferente de la versión actual.

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

Referencias

  1. Fowler, Martin (2003). Patterns of enterprise application architecture. Addison-Wesley. ISBN 978-0-321-12742-6. 

Plantilla:Boceto-ingeniería-de-software