Django ORM
Django ORM
Django ORM
: Lynette Garca
Tarea No.5
Django ORM
Trabajo presentado por: Luis Carlos Aldana Molina, 08261 Martn Luis H. Guzmn Colmenares, 08041 Byron Orlando Morales Sequn, 08414 Guatemala, 03 de septiembre de 2011
Django ORM is licensed under Creative commons Attribution- Noncommercial-Share Alike 3.0 Guatemala License
1/22
RESUMEN
Django es un entorno de desarrollo web escrito en Python que fomenta el desarrollo rpido y el diseo limpio y pragmtico. Django es un framework web de cdigo abierto escrito en Python que permite construir aplicaciones web ms rpido y con menos cdigo. Este Framework est compuesto de un mapeo objeto-relacional para convertir los modelos de datos, un apoyo en configuracin de URL, un sistema completo de plantillas, sistemas para realizar procesos de solicitud y administracin de base de datos relacionales, lo que permite un ptimo desarrollo de aplicaciones. A partir de los modelos creados en Python, Django proporciona una abstraccin de la base de datos a travs de su API que permite crear, recuperar, actualizar y borrar objetos. Tambin es posible que el usuario ejecute sus propias consultas SQL directamente. En el modelo de datos de Django, una clase representa una tabla en la base de datos y las instancias de esta sern las filas en la tabla.
NDICE DE CONTENIDOS
Pgina 1. Resumen ............................................................................................... .................................................................................. .................................................................................. .................................................................................. .................................................................................. .................................................................................. .................................................................................. ..................................................................... 2 4 4 4 4 5 5 5 6 7 8 9 9 9 2/22
2. Introduccin ............................................................................................... 3. Django como ORM a. Ventajas 4. Archivo model.py 5. Modelos a. Campos b. Mtodos c. Herencia
6. Manejadores ............................................................................................... 7. Manipulacin de datos a. Crear objetos .................................................................................. b. Guardar cambios en objetos ........................................................
........................................................
10 12 13 14 14 14 15 16 16 17 18 18 19 19 20 21 21 22 22
.....................................................................
e. Actualizar mltiples objetos ........................................................ .................................................................................. .................................................................................. ........................................... ...................................................................... ......................................................... 8. Transacciones b. Autocommit()
d. Commit_manually() ...................................................................... .................................................................................. ...................................................................... ............................................ ............................... .................. 9. Mltiples bases de datos
d. Seleccin manual de base de datos ............................................ ............................... Limitaciones de mltiples bases de datos ............................... ...............................................................................................
3/22
INTRODUCCIN
Django es un framework para el desarrollo de aplicaciones web, escrito en Python, que sigue el patrn de diseo de modelo vista controlador. Django pone nfasis en la reutilizacin de cdigo, la conectividad y extensibilidad de componentes y el desarrollo rpido. El ncleo de Django consiste en un mapeo objeto-relacional que media entre los modelos de datos, definidos como clases de Python, y la base de datos relacional; un sistema para procesar peticiones y un despachador de URL basado en expresiones regulares. El presente trabajo intenta describir las caractersticas principales y el uso del ORM incluido en el framework Django.
Ventajas
El ORM de Django es muy potente, porque permite sacar provecho de las ventajas del lenguaje para el cual est diseado. Por ejemplo, podemos incluir consultas SQL para optimizar ciertos aspectos de nuestras aplicaciones (o interacciones con la base de datos). Existe un gran nmero de tipos de columna soportados. Adems de que permite disear/definir tipos personalizados, los cuales pueden ser utilizados dentro de diferentes proyectos que estn dentro de Django. La forma en que Django maneja la meta-informacin de nuestros modelos ayuda personalizar cada uno de ellos. Tanto en el diseo lgico dentro de Django como dentro del diseo fsico (parmetros para interactuar con el DBMS relacional con el que se est trabajando).
Desventajas
Los nombres de los campos no pueden contener dos signos de subrayado seguidos, debido a que crean confusiones con algunas de las funciones de Django. 4/22
Adems, los problemas de rendimiento y claridad de cdigo que son producidos al trabajar con herencia de mltiples modelos hacen que trabajar con estos paradigmas sea poco prctico.
Archivo model.py
Es un archivo dentro de un proyecto de Django. En l se definen los modelos en los que se contiene la lgica del negocio de la aplicacin; en otras palabras, contiene el diseo de la base de datos mediante clases de Python utilizando a la clase Model (incluida en el mdulo model de Django). La representacin completa de los modelos de la lgica de negocio son llamados amodel. Utilizando objetos de los modelos que se encuentran dentro del amodel es como interactuamos con la base de datos (crear, obtener, actualizar, eliminar registros o tuplas dentro de las tablas de la base de datos).
Modelos Campos
La parte ms importante de la definicin de los modelos es la utilizacin de la descripcin de los campos o atributos que lo componen. Para ello en Django, se utilizan variables de clase que toman como valor un objeto que hereda (directa o indirectamente) de la clase Field. Dentro de los campos se define el tipo de la columna que define; el widget que debe ser utilizado para el ingreso mediante la interfaz web; y, algunas validaciones simples o mnimas. Adems se puede dar formato a los nombres de salida que tendrn los campos. Ests definiciones se hacen mediante el paso de parmetros a los constructores de los objetos de la clase. Bsicamente existen dos tipos de parmetros: los parmetros especficos y los parmetros generales. Los parmetros especficos se utilizan para definir datos que son estrictamente esenciales en la definicin de una columna (como ocurre con las columnas de texto, que necesitan definir el mximo nmero de caracteres que utilizan). Mientras que los parmetros generales, son aquellos que especifican informacin que todas las columnas contienen, tanto dentro de la base de datos, como de validacin y mtodos de entrada desde la interfaz web; por ejemplo si la columna acepta null (parmetro null), si un campo pertenece a la clave primaria de la tabla (primary_key), etc.
5/22
Algunos otros de los parmetros generales importantes son: blank: permitir dejar en blanco en la ingreso (de tipo validacin). choices: muestra una lista de los valores admitidos para este campo (de tipo entrada). default: le poner un valor por defecto a la columna (de tipo entrada). help_text: muestra un texto de ayuda para el ingreso del campo (de tipo entrada). unique: no permite valores repetidos dentro de la base de datos (acta sobre la base de datos).
Adems, el ORM de Django permite definir relaciones entre los modelos (de forma anloga a como lo hace un DBMS). Los tipos de relaciones que soporta son: Uno a uno: Se especifica mediante la funcin OneToOneField, que toma como parmetro la clase a la que debe hacer referencia. Uno a muchos: Se especifica mediante la funcin ForeignKey, que toma como parmetro la clase a la que debe hacer referencia. Muchos a muchos: Existen dos formas de definir relaciones muchos a muchos: Simple: cuando la relacin se hace nicamente por atributo. Se especifica mediante la funcin ManyToManyField, que toma como parmetro la clase a la que debe hacer referencia. Compuesta: cuando la relacin se por ms de un atributo atributo. Se especifica mediante la funcin ManyToManyField, que toma como parmetro la clase a la que debe hacer referencia y adems en el parmetro through se especfica la clase por medio de la cual se hace la relacin.
Mtodos
Los mtodos dentro de las clases que heredan de la clase Model actan nicamente sobre un objeto (instancia) a la vez, por ello se denominan mtodos a nivel de tupla (row level) dentro de la base de datos. El permitirnos realizar estos mtodos ayuda a mantener la lgica del negocio en un slo lugar: el modelo. Existen mtodos que son heredados de la clase Model, en algunas ocasiones puede resultar til sobreescribirlos. Algunos de ellos son:
6/22
__unicode__: debe brindar la representacin de texto extendido de una tupla (objeto). get_absolute_url: nos da la URL directa para llegar a la informacin de este objeto dentro de la aplicacin web. save: guarda la instancia actual dentro de la base de datos. delete: elimina el objeto actual de la base de datos.
Adems, dentro de estos mtodos podemos incluir sentencia SQL para manejar consultas, relaciones u otras acciones de forma ms eficiente a como lo hace Django. Tambin podemos extender las funcionalidades que nos brinda Django, creando operaciones que el framework no puede realizar por s solo.
Herencia
Utiliza las facilidades que brinda Python para utilizar herencia. Bsicamente se permiten tres tipos de herencia: Herencia de clases base abstractas: Se crea un modelo abstracta (se especfica en la meta-informacin), de ella se hereda hacia otros modelos los cuales automticamente tienen todos las columnas de la clase base. Herencia de meta-informacin: la meta-informacin es heredada a los modelos que lo especifiquen pero tiene mayor prioridad la propia meta informacin del modelo (por ejemplo, el nombre de tabla se crea con el nombre especificado en la meta-informacin del modelo que hereda y no con la meta-informacin del modelo abstracto). Herencia multitabla: se realiza creando un modelo, y a partir de ese modelo se hereda hacia otro modelo. Esto se realiza creando una relacin uno a uno dentro de la base de datos, lo que lleva a que la informacin completa este guardada en diferentes tablas dentro de la base de datos. Herencia apoderada de modelos (Proxy Model Inheritance): se realiza especificando la relacin de proxy dentro de la meta-informacin del modelo que hereda. Esto hace que todas las acciones que se realicen sobre las instancias del modelo que hereda sean vistas en el modelo que ha sido heredado.
Hay que mencionar que en ningn tipo de herencia se soporta la sobreescritura de campos, dado que as es como se garantiza la integridad de los datos dentro de la misma base de datos.
7/22
Manejadores
Una manejador es la interfaz que provee las operaciones a la base de datos para cada modelo, por lo que existe almenos un manejador por cada modelo. El manejador predeterminado que tiene cada modelo se encuentra en el campo objects, el cual puede ser sobre-escrito. Crear manejadores personalizados permite agregar funcionalidad a manejadores predeterminados, el cul se ve reflejado dentro de la base de datos como funcionalidad a nivel de tabla. Adems tambin permite modificar el conjunto de operaciones que permiten utilzar los manejadores preestablecidos, operaciones que involucren incluso la interaccin con otros modelos. Esto se realiza al crear una clase que herede de la clase Manager que se encuentra en el modulo model, proporcionado por Django. Los manejadores son heredados cuando se realiza la herencia, incluso el manejador que se encuentra en objects. La nica excepcin a esto es cuando se hereda de una clase base abstracta, porque el manejador predeterminado se hereda pero no es el manejador principal del modelo que hereda. A continuacin se muestra un ejemplo de implementacin de un manejador. Figura No.0 Ejemplo de manejadores
En este caso, tanto la clase MaleManager, como FemaleManager lo que hacen es retornar un QuerySet con los respectivos filtros para seleccionar a los hombres o mujeres.
8/22
Manipulacin de datos
Una vez se haya creado el modelo de los datos, Django provee automticamente una API para la abstraccin de la base de datos, para crear, recuperar, actualizar y eliminar los objetos.
Crear objetos
Para representar una tabla en la base de datos utilizando objetos de Python, Django utiliza un sistema bastante intuitivo: Un modelo de clase representa una tabla de base de datos, y una instancia de esa clase representa un registro en particular en la tabla de la base de datos. Para crear un objeto, simplemente se instancia un objeto de una de estas clases con los argumentos requeridos por el modelo, y a continuacin, llamar al mtodo save() para guardarla en la base de datos. Para realizar este procedimiento Django lo que hace es convertir a una instruccin de INSERT de SQL lo que se est haciendo. sta se crea en el momento que se llama al mtodo save(). En la figura de abajo se muestra un pequeo ejemplo de cmo crear objetos y meterlos a la base de datos. Figura No.1 Ejemplo para crear objetos
9/22
Si lo que se desea es actualizar una llave fornea, se puede hacer de manera similar: Figura No.3 Ejemplo guardar cambios en llave fornea
Por otro lado, si lo que se desea es agregar objetos en una relacin de muchos a muchos, Django permite hacerlo de la siguiente forma: Figura No.4 Ejemplo guardar cambios en relacin muchos a muchos
Recuperacin de objetos
Para recuperar objetos de la base de datos es necesario construir un QuerySet a partir del Manager del modelo de la clase. Un QuerySet representa una coleccin de objetos de la base de datos. Otro concepto importante es el de filtro. Un filtro representa un criterio para reducir el nmero de resultados en funcin de los parmetros. En trminos de SQL, un QuerySet representa una instruccin SELECT, mientras un filtro representa una clusula WHERE o LIMIT. Cada modelo tiene un Manager. Por defecto, ste se llama: objects. Cabe destacar que para acceder al Manger, objects es necesario acceder directamente a travs de la clase del modelo (no desde una instancia del objeto). Por ejemplo: Figura No.5 Ejemplo acceder al Manager mediante la clase, no la instancia
10/22
Mediante el Manager obtenemos un QuerySet, que describe todos los objetos de una determinada clase en la base de datos. Con stos es posible hacer varias cosas: Recuperar todos los objetos: La forma ms sencilla es obteniendo todos los objetos de una clase por medio del Manager. Para hacer uso del mismo es posible utilizar el mtodo all() sobre el Manager, para obtener todos los objetos en un QuerySet. Por ejemplo: Figura No.6 Ejemplo recuperar todos los objetos de una clase
Recuperar objetos especficos con filtros : Usualmente es necesario nicamente recuperar un subconjunto de todos los objetos que se encuentran almacenados. Para recuperar un subconjunto es necesario refinar el conjunto QuerySet, mediante filtros. Las dos formas ms comunes de hacerlo es mediante el uso de 2 mtoso: filter(**kwargs): Devuelve un nuevo QuerySet que contiene los objetos que coinciden con los parmetros de bsqueda dados. exclude(**kwargs): Devuelve un nuevo QuerySet que contiene los objetos que no coinciden con los parmetros de bsqueda dados. Figura No.7 Ejemplo recuperar objetos especficos con filtros
Recuperar objetos encadenando filtros: Tambin es posible encadenar los filtros, para refinar las bsquedas. Figura No.8 Ejemplo filtros encadenados
Recuperar un simple objeto con get: El mtodo filter() siempre devolver un QuerySet, sin importar que el resultado sea un nico objeto. Si se desea obtener inmediatamente el objeto puede usarse el mtodo get(). 11/22
Limitar la cantidad de recuperaciones : Es posible limitar el nmero de resultados en una recuperacin, utilizando la sintaxis de arreglos. Esto es equivalente a utilizar LIMIT de SQL y las clusulas OFFSET. Por ejemplo, si se desea recuperar nicamente 5 elementos (LIMIT 5): Figura No.10 Ejemplo limitar la cantidad de recuperaciones
Otro ejemplo podra ser si se desea recuperar 5 elementos, pero no los primeros 5 sino los segundos (LIMIT 5 OFFSET 5) Figura No.11 Ejemplo limitar la cantidad de recuperaciones con OFFSET
Recuperar con operaciones booleanas: Tambin es posible utilizar operaciones booleanas como AND y OR a la hora de realizar los filtros. Los parmetros que poseen los mtodos filter() y get() representan una operacin booleana AND. Si se desea realizar un OR es necesario especificarla mediante una barra vertical. La siguiente figura muestra un ejemplo:
Eliminar objetos
Para eliminar objetos de la base de datos puede utilizarse el mtodo delete(). ste puede ser utilizado de varias formas. Por ejemplo: Figura No.13 Ejemplo eliminar un objeto de la base de datos
12/22
Con este mtodo es posible eliminar mltiples objetos, es decir, se pueden borrar todos los elementos que devuelva un QuerySet. Figura No.14 Ejemplo eliminar objetos de un QuerySet
Sin embargo, hay que tener cuidado con el uso del mtodo delete(), ya que cuando se manda a llamar, por defecto, emula el comportamiento de la restriccin de SQL: ON DELETE CASCADE. En otras palabras, cuando se elimina un objeto, se eliminan tambin todos los objetos que tengan referencia hacia l. Por ejemplo: Figura No.15 Ejemplo eliminar en cascada
El uso del mtodo update() implica la conversin directa a una sentencia UPDATE de SQL. Por lo tanto no realiza una bsqueda y luego la guarda. Sin embargo, si se quiere modificar y actualizar cada elemento de un QuerySet por separado, puede recorrerse de la siguiente forma: Figura No.17 Ejemplo uso de QuerySet como lista
13/22
SQL puro
El uso de la capa de abstraccin que provee Django puede ser bastante sencillo de utilizar. Sin embargo, si se desea, es posible utilizar sentencias SQL. Para esto se puede recurrir al mtodo raw(). A continuacin se muestran dos pequeos ejemplos de cmo utilizarlo: Figura No.18 Ejemplo uso de SQL puro en un objeto
Transacciones
Django provee cmo controlar la forma en que se manejan las transacciones de la base de datos, si el manejador soporta transacciones. Por predeterminado, Django maneja una transaccin abierta, la cual hace commit automticamente cuando una funcin de actualizacin del modelo es invocada. Muy parecido a la configuracin auto-commit para muchas bases de datos. Cuando se realiza una accin que necesita escribir en la base de datos, Django produce las sentencias INSERT/UPDATE/DELETE y luego hace el commit. No hay un rollback implcito.
Administracin de transacciones
Si se necesita ms control sobre las transacciones, se pueden utilizar las funciones que provee Django para controlar las transacciones basadas en:
14/22
Autocommit()
Configuracin por defecto. Se puede utilizar para modificar el manejo de transacciones si se modific la configuracin global. Figura No.22 Ejemplo auto-commit
15/22
Commit_on_success()
Se utiliza como decorador para utilizar una sola transaccin por funcin. Si la funcin retorna con xito, Django hace commit al trabajo realizado dentro de la funcin. Si la funcin levanta una excepcin, Django hace rollback al trabajo realizado. Figura No.23 Ejemplo commit_on_success
Commit_manually()
Se utiliza para tener control total sobre las transacciones. Si la vista realiza cambios en los datos y no se hace commit o rollback, Django levanta una excepcin. Figura No.24 Ejemplo commit_manually
16/22
Savepoints
Los savepoints estn disponibles en PostgreSQL y Oracle. Permiten hacer rollback parte de los cambios realizados en una transaccin en lugar de hacer rollback a la transaccin completa. Los savepoints no son tiles si se utiliza el comportamiento por defecto de Django. Sin embargo, si se utiliza otro comportamiento, cada transaccin abierta acumula una serie de operaciones a la base de datos esperando a hacer commit o rollback. Los savepoints proveen la habilidad de realizar un rollback ms especfico. Los savepoints se manejan por tres funciones: 1. savepoint(): crea un nuevo savepoint. regresa el identificador de savepoint. 2. savepoint_commit(sid): actualiza el savepoint para incluir la operaciones que han sido realizadas desde la creacin del savepoint. 3. savepoint_rollback(sid): hace un rollback hasta el punto donde se cre el savepoint.
17/22
18/22
Siempre que una base de datos intenta realizar una consulta a la base de datos debe saber a cul hacerla. sto se hace utilizando el enrutamiento maestro.
19/22
20/22
Se empieza creando un objeto Person, con nombre 'Fred'. La siguiente instruccin corresponde a guardar a dicho objeto en la base de datos con alias 'first'. Al hacer esto al objeto se le crea una llave primaria (si no se especifica), para que sea adecuadamente insertado en la base de datos. Si no se ejecuta la lnea p.pk = None existe el problema que al intentar guardar el objeto en la base de datos 'second' es necesario revisar que la llave primaria no se encuentre anteriormente usada. Para evitar sto se puede, como se hace en el ejemplo, borrarle la llave primaria al objeto, o bien, forzar a que sea insertado de la siguiente forma: p.save(using='second', force_insert=True).
21/22
CONCLUSIONES
La definicin de campos o columnas es la parte ms importante de los modelos, por ello es importante la personalizacin (mediante la utilizacin de parmetros, especficos o generales) que le demos a cada uno. La utilizacin de mtodos dentro de los modelos, permiten crear funcionalidad a nivel de tupla. Lo que esto nos permite, es personalizar el comportamiento que tendr cada uno de las instancias del modelo (y de su interaccin con otras instancias de modelos). La utilizacin de Manejadores permite tratar la informacin a nivel de tabla, de tal forma que creando manejadores personalizados es posible crear o modificar operaciones que se realizan sobre el conjunto de datos que pertenecen al modelo al cual el manejador pertenece. Tanto la personalizacin de funciones a nivel de tuplas como funciones a nivel de tablas nos permiten mantener la lgica del negocio dentro de Django. Django provee automticamente una API para la abstraccin de la manipulacin de los datos de la base de datos. sta provee muchas funciones para la creacin, recuperacin, actualizacin y eliminacin de los datos de forma sencilla. Django provee forma de controlar y manejar transacciones de la base de datos, siempre y cuando el manejador soporte las transacciones. Django acepta interactuar con mltiples bases de datos de manera simultnea. Para acceder a ellas existen dos formas: el enrutamiento automtico y la seleccin manual. Es posible que un objeto interacte con ms de una base de datos. Sin embargo, Django est limitado cuando se trata de relaciones de muchos a muchos entre diferentes bases de datos.
BIBLIOGRAFA
Django. Models. Django documentation. Sitio web: https://docs.djangoproject.com/en/1.3/topics/db/models/ Django. Model instance reference. Django documentation. Sitio web: https://docs.djangoproject.com/en/dev/ref/models/instances/?from=olddocs Django. Making queries. Django documentation. Sitio web: https://docs.djangoproject.com/en/1.3/topics/db/queries/ Gomaa, A. The Django ORM Problem. 2007. Sitio web: http://adam.gomaa.us/blog/2007/aug/26/the-django-orm-problem/ The Django Book. Captulos 5 y 10. Sitio web: http://www.djangobook.com/en/2.0/ CustomSolutions. Desarrollo Django. Sitio web: http://www.customsolutions.es/desarrollo-aplicaciones-django/ Djngo en espaol. Descubre Django!. Sitio web: http://django.es/ 22/22