Agregacion en Django

Trabajando con modelos en Django para aplicaciones web de alto perfil, como las desarrolladas por AxiaCore, nos encontrábamos frecuentemente con tener que hacer cálculos aritméticos básicos manualmente sobre un conjunto de datos en particular.

Por ejemplo si necesitábamos obtener el total de ventas de un mes determinado, se tenia que iterar cada elemento del conjunto de datos (QuerySet) e ir sumando en una variable cada valor obtenido, los que hemos trabajado con aplicaciones conectadas a una base de datos sabemos que existen funciones de SQL con SUM() que efectúan esa tarea mucho mas cómodamente.

Afortunadamente para la nueva versión de Django, próxima a salir, la v1.1 existe la posibilidad de utilizar ‘Agregaciones’ y ‘Anotaciones’ que permiten efectuar este tipo de cálculos de una manera mucho mas fácil y recargando la responsabilidad de los cálculos a la base de datos y no a la lógica de la aplicación.

Factura.objects.aggregate(
    Avg('precio'), Max('precio'), Min('precio'), Sum('precio')
)

Mas información en la documentación oficial del proyecto.

Enlace: http://docs.djangoproject.com/en/dev/topics/db/aggregation/

Bookmark and Share

About Camilo Nova

Desarrollador Web y trabajador multiusos en AxiaCore
This entry was posted in AxiaCore and tagged , . Bookmark the permalink.

3 Responses to Agregacion en Django

  1. Martin says:

    Hola muy buena informacion una pregunta que queria hacerte es la siguiente como podria mostrar en el template el valor se una suma con aggregate por ejemplo si tengo la siguiente sentecia:
    precio_total = Factura.objects.aggregate(Sum(‘precio’))

    yo ando al template la variable precio_total verdad tonces en el template yo lo pongo asi {{ precio_total }} pero este me muestra lo siquite: {‘precio__sum’: 21} pero yo solo quiero el 21 no se si me doy a entender

    gracias

  2. Camilo Nova says:

    Hola, la forma de imprimir el valor que buscas es {{ precio_total.0 }} en la plantilla.

    O en la vista retorna este valor precio_total = Factura.objects.aggregate(Sum(’precio’))['precio__sum'] y en la plantilla {{ precio_total }}

    Saludos

  3. Martin says:

    gracias estare probando

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos necesarios están marcados *

*

Puedes usar las siguientes etiquetas y atributos HTML: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre lang="" line="" escaped="">