Antes de comenzar a probar lo que se escribe en este artículo es necesario que realicen pruebas con el artículo mencionado anteriormente para que tengan la base de datos con sus datos listas para ser utilizadas en este artículo.
Ahora se explica como usar unas tablas con sus datos ya creada, creando una sesión para la base de datos.
Este artículo se basa en un tutorial en inglés de sqlalchemy o el tutorial paso a paso de sqlalchemy.
Lo primero que se hará es crear un archivo model.py que contendrá el modelo de la base de datos.
#Se importa el módulo datetime
import datetime #Se importa schema y tupes de sqlalchemy from sqlalchemy import schema, types #Se instancia la clase MetaData. metadata = schema.MetaData() #Se crea la función now que devuelve la hora actual. def now(): return datetime.datetime.now() #Se crea la instancia table con los campos de la tabla grupos grupos_table = schema.Table('grupos',metadata, schema.Column('id',types.Integer,primary_key=True), schema.Column('grupo',types.String(300),nullable=False), schema.Column('descripcion',types.String(500),nullable=False), ) #Se crea la instancia table con los campos de la tabla contactos contactos_table = schema.Table('contactos',metadata, schema.Column('id',types.Integer,primary_key=True), schema.Column('nombre',types.String(100),nullable=False), schema.Column('telefono',types.String(11),nullable=False), schema.Column('grupo_id',types.Integer,nullable=False), ) #Se crea la clase Contactos y Grupos que heredan de object y sólo tienen pass. class Contactos(object): pass class Grupos(object): pass #Se mapea la Clase Contactos con la tabla contactos_table orm.mapper(Contactos, contactos_table) #Se mapea la Clase Grupos con la tabla grupos_table orm.mapper(Grupos,grupos_table)
Ya con este código se logra el mapeo de las tablas existenes con sus campos.
Ahora se crea un archivo llamado prueba-db.py que va a realizar la sesión a la base de datos por medio del módulo model.py donde se realizará unas consultas, inserciones y remociones de datos.
#!/usr/bin/env python # -*- coding: utf-8 -*- import model from sqlalchemy import orm from sqlalchemy import create_engine #Crear un engine y crear todas las tablas necesarias engine = create_engine('sqlite:///tutorial.db', echo=False) model.metadata.bind = engine model.metadata.create_all() # Configurar la sesion sm = orm.sessionmaker(bind=engine, autoflush=True, autocommit=False, expire_on_commit=True) session = orm.scoped_session(sm) #Se realiza una consulta a la tabla grupos print "Consulta inicial de la tabla contactos" consulta = session.query(model.Contactos).all() for lista in consulta: print lista.nombre,lista.telefono print "--------------------------------" #Agregar un contacto contacto = model.Contactos() contacto.nombre = u"Luisa Gonzalez" contacto.telefono = u"04155555555" contacto.grupo_id = 2 session.add(contacto) session.flush() session.commit() #Se realiza una consulta a la tabla grupos print "Consulta la tabla contactos con el dato incorporado" consulta = session.query(model.Contactos).all() for lista in consulta: print lista.nombre,lista.telefono print "--------------------------------" #Borrar un contacto session.delete(contacto) session.flush() session.commit() #Se realiza una consulta a la tabla grupos print "Consulta la tabla contactos luego de borrar el dato" consulta = session.query(model.Contactos).all() for lista in consulta: print lista.nombre,lista.telefono print "--------------------------------"
El resultado de ejecutar el script pruebas-db.py se muestra a continuación:
Consulta inicial de la tabla contactos Ernesto Crespo 04155673029 Pedro Perez 0295212223 Jhon Doe 04184488484 Jane Doe 04184488482 Pepito de los palotes 04184588484 -------------------------------- Consulta la tabla contactos con el dato incorporado Ernesto Crespo 04155673029 Pedro Perez 0295212223 Jhon Doe 04184488484 Jane Doe 04184488482 Pepito de los palotes 04184588484 Luisa Gonzalez 04155555555 -------------------------------- Consulta la tabla contactos luego de borrar el dato Ernesto Crespo 04155673029 Pedro Perez 0295212223 Jhon Doe 04184488484 Jane Doe 04184488482 Pepito de los palotes 04184588484 --------------------------------
1 comentario:
Da error
File "/home/vvillalobos/Code/Python/Tutoriales/sqlalchemy.py", line 11, in
db = create_engine('sqlite:///tutorial.db')
Publicar un comentario