簡體   English   中英

SQLAlchemy 和燒瓶 (sqlalchemy.exc.OperationalError:)

[英]SQLAlchemy and flask (sqlalchemy.exc.OperationalError:)

我收到了這條消息:

sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) no such table: user
[SQL: INSERT INTO user (username, email, password) VALUES (?, ?, ?)]
[parameters: ('test', 'test@test.com', 'password')]
(Background on this error at: http://sqlalche.me/e/e3q8)

當我嘗試: db.session.commit() 我正在學習教程並嘗試個性化代碼,但結果不佳。

到目前為止我所做的是:

>>> from lagerut import db
>>> db.create_all()
>>> from models import User
>>> user_1 = User(username='test', email='test@test.com', password='password')
>>> db.session.add(user_1)
>>> db.session.commit()

這里是lagerut.py

from datetime import datetime
from flask import Flask, render_template, url_for, flash, redirect
from flask_sqlalchemy import SQLAlchemy
from form import RegistrationForm, LoginForm


app = Flask(__name__)
app.config['SECRET_KEY'] = '2a1de6eea4126191912d6e702c6aa8f9'
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///lagerut.db'
db = SQLAlchemy(app)

@app.route('/')
@app.route('/home')
def home():
    return render_template ('home.html')

@app.route('/how-it-works')
def howitworks():
    return render_template ('how-it-works.html', title='How it works')

@app.route('/lager-out')
def lagerout():
    return render_template ('lager-out.html', title='Lager out')

@app.route('/lager-in')
def lagerin():
    return render_template ('lager-in.html', title='Lager in')

@app.route("/register", methods=['GET', 'POST'])
def register():
    form = RegistrationForm()
    if form.validate_on_submit():
        flash(f'Account created for {form.username.data}!', 'success')
        return redirect(url_for('home'))
    return render_template('register.html', title='Register', form=form)

@app.route("/login", methods=['GET', 'POST'])
def login():
    form = LoginForm()
    if form.validate_on_submit():
        if form.email.data == 'admin@blog.com' and form.password.data == 'password':
            flash('You have been logged in!', 'success')
            return redirect(url_for('home'))
        else:
            flash('Login Unsuccessful. Please check username and password', 'danger')
    return render_template('login.html', title='Login', form=form)


if __name__ == '__main__':
    app.run(debug=True)

這里是models.py

from datetime import datetime
from lagerut import db

class User(db.Model):
    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)
    password = db.Column(db.String(60), nullable=False)

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

class Items(db.Model):
    item_number = db.Column(db.Integer, primary_key=True)
    description = db.Column(db.String(200), nullable=False)
    date_posted = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
    department = db.Column(db.String(100), nullable=False)
    content = db.Column(db.Text, nullable=False)

    def __repr__(self):
        return f"Items('{self.product}', '{self.date_posted}', '{self.content}', '{self.department}', '{self.content}')"

我應該嘗試再次編寫代碼嗎? 我只是想學習如何為我的工作構建一個小應用程序。

學習編程的好方法是否也適用於 shell?

那是因為您在創建數據庫時沒有創建應用程序上下文,因為您是通過 python shell 執行此操作的,因此您需要添加以下行

with app.app_context():

在此處閱讀更多相關信息https://flask.palletsprojects.com/en/1.0.x/appcontext/

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM