2011-01-30 2 views
4

Voici comment je configurer ma base de données pour une application (en Flask):déclarative SQLAlchemy CREATE SQLITE dans les tables de mémoire

from sqlalchemy.engine import create_engine 
from sqlalchemy.orm import scoped_session, create_session 
from sqlalchemy.ext.declarative import declarative_base 

engine = None 
db_session = scoped_session(lambda: create_session(bind=engine, 
                autoflush=False, autocommit=False, expire_on_commit=True)) 

Base = declarative_base() 
Base.query = db_session.query_property() 

def init_engine(uri, **kwargs): 
    global engine 
    engine = create_engine(uri, **kwargs) 

    Base.metadata.create_all(bind=engine) 

    return engine 

Si je me connecte à une base de données de fichiers qui a eu des tables créées déjà, tout fonctionne bien, mais en utilisant sqlite: ///: mémoire: comme base de données cible me donne:

OperationalError: (OperationalError) no such table: users u'DELETE FROM users'() 

lors de l'interrogation comme tant d'ex .:

UsersTable.query.delete() 
db_session.commit() 

J'accède à ce code à partir d'un test unitaire. Quel est le problème?

Merci

Edit:

configuration de travail de l'application:

app = Flask(__name__) 
app.config.from_object(__name__) 
app.secret_key = 'XXX' 

# presenters 
from presenters.users import users 

# register modules (presenters) 
app.register_module(users) 

# initialize the database 
init_engine(db) 
+0

Quelle est la sortie si vous ajoutez "print Base.metadata.tables.keys()" juste avant .create_all()? –

Répondre

2

Le code affiché ne contient aucune table de déclaration/classe. Êtes-vous sûr que la déclaration est faite avant l'appel de init_engine()?

+0

Vous avez raison! J'ai mis à jour la question avec l'ordre d'exécution «correct». Merci @jd – Radek

Questions connexes