Flask sqlalchemy RuntimeError Working outside of application context报错 解决方案

在使用Flask-SQLAlchemy创建数据库表时遇到RuntimeError,问题在于缺少应用上下文。解决方案是在withapp.app_context()中执行db.create_all(),以确保在正确的上下文中操作。这是由于新版本的Flask要求明确设置应用程序上下文。
摘要由CSDN通过智能技术生成

RuntimeError Working outside of application context 解决方案

前言

最近做了一个前后端分离的博客网站项目,后端采用了python轻量级框架Flask,在调用Flask sqlalchemy 的时候出现了问题。

报错

from flask import Flask
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///articles.sqlite'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False

# 数据库
db = SQLAlchemy(app)
# 数据模型
class Article(db.Model):
    __tablename__ = "article_table"
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100))
    info = db.Column(db.String(100))
    datahtml = db.Column(db.Text(65536))
    time = db.Column(db.Date())

class User(db.Model):
    __tablename__ = "user_table"
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(100))
    password = db.Column(db.String(100))
    token = db.Column(db.String(100))
    token_time = db.Column(db.String(100))

//运行到这里就报错
db.create_all()

报错信息为:

line 47, in <module>
    db.create_all()
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.

在查看报错信息后发现是缺少上下文,需要在with app.app_context()下运行。
解决方案:

with app.app_context():
	db.create_all()

总结

在查阅Flask sqlalchemy官方文档后,才知道新版本需要特别声明上下文。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

很大园霖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值