首页 > 解决方案 > sqlalchemy.exc.OperationalError:(sqlite3.OperationalError)没有这样的表:用户。无法为用户制作表格

问题描述

这是我创建用户表的 models.py。

from datetime import datetime
from flaskblog import db, login_manager
from flask_login import UserMixin


@login_manager.user_loader
def load_user(user_id):
    return User.query.get(int(user_id))


class User(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(20), unique=True, nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    posts = db.relationship('PostIntmath', backref='author', lazy=True)
    image_file = db.Column(db.String(20), nullable=False, default='default.jpg')
    password = db.Column(db.String(60), nullable=False)

    def __repr__(self):
        return f"User('{self.username}', '{self.email}', '{self.image_file}')"


class PostIntmath(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100), nullable=False)
    date_posted = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
    content = db.Column(db.Text, nullable=False)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)

    def __repr__(self):
        return f"Post('{self.title}', '{self.date_posted}')"

我看不出有什么问题。我已经制作了表格来输入用户名和电子邮件。

我的 routes.py 看起来也不错,但是每当我尝试登录时,它都会给我一个错误


@app.route("/login", methods=['GET', 'POST'])
def login():
    if current_user.is_authenticated:
        return redirect(url_for('home'))
    form = LoginForm()
    if form.validate_on_submit():
        user = User.query.filter_by(email=form.email.data).first() #error on this line
        if user and bcrypt.check_password_hash(user.password, form.password.data):
            login_user(user, remember=form.remember.data)
            next_page = request.args.get('next')
            return redirect(next_page) if next_page else redirect(url_for('home'))
        else:
            flash('Login Unsuccessful. Please check email and password', 'danger')
    return render_template('login.html', title='Login', form=form)

我得到的错误是:

sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) no such table: user
[SQL: SELECT user.id AS user_id, user.username AS user_username, user.email AS user_email, user.image_file AS user_image_file, user.password AS user_password
FROM user
WHERE user.email = ?
LIMIT ? OFFSET ?]
[parameters: ('abc456@gmail.com', 1, 0)]
(Background on this error at: http://sqlalche.me/e/e3q8)

请帮帮我。我是烧瓶和 SQLAlchemy 的新手

标签: pythonsqliteflasksqlalchemyflask-sqlalchemy

解决方案


确保检查以下 3 件事:

1.) 使用正确的名称创建表。

2.) 从模型导入到 routes.py 的表

from app.models import User

3.) 在“init”文件或具有 shell_content_processor 的文件中添加表名。您应该有以下代码。

from app import app, db
from app.models import User

@app.shell_context_processor
def make_shell_context():
    return {'db': db, 'User': User}

使用您的应用名称更改应用名称。


推荐阅读