python - 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 的新手
解决方案
确保检查以下 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}
使用您的应用名称更改应用名称。
推荐阅读
- r - 计算矩阵中非零列的数量
- java - Array 帮助行的求和
- i2c - 如何让 i2cget 读取一个单词?
- autohotkey - 笔记本电脑没有 fn 锁,什么脚本可以让我的功能键像有 fn 锁一样工作?
- python - 当我尝试安装 bob.blitz 时,如何解决以下错误?
- for-loop - 如何在火花数据框中使用 for 循环?
- git - 减少历史 Git 对象
- java - @primary 注解不适用于 JUnit 测试
- javascript - Sitecore 给出值,我需要在 jQuery 中添加
- python - 一个数字加上两个字符的正则表达式,如“1st”、“2nd”、“10th”、“22nd”?