sqlalchemy.ex c .OperationalError: (sqlite3.OperationalError) нет такой таблицы: пользователь. Не могу сделать таблицу для пользователя - PullRequest
0 голосов
/ 06 февраля 2020

Это мой файл 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}')"

Я не вижу, что не так. Я создал формы для ввода данных для имени пользователя и адреса электронной почты.

Мой route.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)

Пожалуйста, помогите мне. Я новичок в flask и SQLAlchemy

1 Ответ

0 голосов
/ 06 февраля 2020

Обязательно проверьте следующие 3 вещи:

1.) Таблица создана с правильным именем.

2.) Таблица импортирована из модели в rout.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}

Измените имя приложения на имя вашего приложения.

...