from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
@app.listener('before_server_start')
async def before_server_start(app, loop):
# database config
app.engine = create_engine(app.config['SQLALCHEMY_DATABASE_URI'], echo=app.config['SQLALCHEMY_TRACK_MODIFICATIONS'])
app.Base = declarative_base(bind=app.engine)
Session = sessionmaker(bind=app.engine)
app.db_session = Session()
app.Base.metadata.create_all()
这是我的一段代码,listener('before_server_start') 在服务启动前运行, 我把 sqlalchemy 所必须的几个对象和类变成 app ( Sanic 的对象)的属性后, 当我想要在 models 中想要类似这样定义的时候:
class User(app.Base)
却报错。
也就是说,模块加载的时间在 app.listener('before_server_start')运行之前。
不知道有用 Sanic+sqlalchemy 你们怎么做的?
文档给的一个 example。
1
ltoddy OP 有没有人知道怎么删帖,我想删除了,自己解决了。
|
2
cszhiyue 2018-06-21 21:05:43 +08:00 via Android
应该考虑是怎么解决的给后人一点提示
|
3
keysona 2018-06-21 21:07:04 +08:00
清空内容
转移节点至水 点击下沉 基本就可以了。 |
4
WildCat 2018-06-21 21:24:29 +08:00
说个不相关的话题,sanic 并不好用,我自己的开源项目都想换 tornado 了。
|
5
billgreen1 2018-06-22 00:18:11 +08:00
@ltoddy 最讨厌你这样的,不会的时候发帖问,自己有解决方案了就藏着掖着
|