flask-alchemy在进行了3.0.0的版本大更新后,原本的链接数据库方式有了稍微的变化,它使会话的范围限定为当前应用上下文,而不是线程,这要求应用上下文处于活动状态。这个确保清理会话在每次请求后。
所以它要求你每次进行前要
with app.app_context():(虽然其实还是不太明白这是咋样推入进去的,但是前面加上这个就可以运行了)
也可以app.test_request_context(): #这个好像是在测试时使用的推入应用上下文
不然就会报错:RuntimeError: Working outside of application context.
This typically means that you attempted to use functionality that needed
the current application. To solve this, set up an application context
with app.app_context(). See the documentation for more information.
而在之前的版本如2.5.0,你要链接可以直接:
app=Flask(__name__)
app.config[SQLALCHEMY_DATABASE_URI]=DB_URI #这就是去配置好,你要链接的数据库,DB_URI包括用户名,密码,IP,端口,数据库
db=SQLAlchemy(app)
Class User......(省略)
db.create_all()
就可以直接创建表了
扩展 db=sqlalchemy()
db.init_app(app)也可以这样
相当于db.sqlalchemy(app)
(其实自己也不太弄的明白)