1、问题描述
在使用flask web框架过程中,在视图之外的一个脚本中想要使用db,但是显示为
<SQLAlchemy engine=None>
使用查询操作就会报这样的操作
exceptions.RuntimeError: application not registered on db instance and no application bound to current context
2、解决思路
通过错误信息分析可以知道是我们的app没有注册db这个对象,没有应用程序绑定到当前上下文。
所以考虑是不是这里没有获取程序上下文。
疑问:
为什么在视图函数中,不用做任何修改就能直接把如request、g这些变量当做全局可访问(当然这里的全局是线程隔离的),怎么在我们自定义的脚本中就不能?
搜索了一番发现在falsk视图函数中,这是会自动进行的,但是在交互式shell中或者在一些脚本中需要手动完成。https://github.com/gnu4cn/flaskLearnings/blob/master/10_flask-SQLAlchemy.md
这样就很明确了,我需要在我的脚本中获取应用上下文环境。
app.app_context().push() # 推送应用上下文环境
3、解决方法
在脚本中推送应用上下文环境。
End
这个问题给的教训就是对一些小知识不能够重视,在这样的小坑里多花了时间!