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)
Quelle est la sortie si vous ajoutez "print Base.metadata.tables.keys()" juste avant .create_all()? –