【发布时间】:2021-10-10 23:52:17
【问题描述】:
我有一个简单的 FastApi 端点,它使用 SqlAlchemy 连接到 MySQL 数据库(基于教程:https://fastapi.tiangolo.com/tutorial/sql-databases/)
我使用以下方法创建会话:
engine = create_engine(
SQLALCHEMY_DATABASE_URL
)
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
我创建了依赖:
def get_db():
db = SessionLocal()
try:
yield db
finally:
db.close()
在我的路线中,我想执行任意 SQL 语句,但我不确定如何正确处理会话、连接、游标等(包括关闭),我通过艰难的方式了解到对于正确的性能非常重要
@app.get("/get_data")
def get_data(db: Session = Depends(get_db)):
???
最终的原因是我的表包含机器学习功能,其列是事先未确定的。如果有一种方法可以使用“所有列”定义 Base 模型也可以,但我也找不到。
【问题讨论】:
标签: sqlalchemy fastapi feature-engineering