Декларативная SQLAlchemy CREATE SQLITE в таблицах памяти - PullRequest
5 голосов
/ 30 января 2011

Вот как я настраиваю свою базу данных для приложения (во Flask):

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

Если я подключаюсь к файловой базе данных, в которой уже созданы таблицы, все работает нормально, но использование sqlite: ///: memory: в качестве целевой базы данных дает мне

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

при запросе, например, так:

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

Я получаю доступ к этому коду из модульного теста. В чем проблема?

Спасибо

Edit:

Рабочая настройка приложения:

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)

1 Ответ

3 голосов
/ 31 января 2011

Код, который вы разместили, не содержит декларации таблицы / класса. Вы уверены, что объявление сделано до вызова init_engine ()?

...