gpt4 book ai didi

python - 声明式 SQLAlchemy 在内存表中创建 SQLITE

转载 作者:IT王子 更新时间:2023-10-29 06:29:20 28 4
gpt4 key购买 nike

这是我为应用程序设置数据库的方式(在 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()

我正在通过单元测试访问此代码。有什么问题?

谢谢

编辑:

应用程序的工作设置:

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)

最佳答案

您发布的代码不包含任何表/类声明。您确定在调用 init_engine() 之前完成声明吗?

关于python - 声明式 SQLAlchemy 在内存表中创建 SQLITE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4840324/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com