sqlalchemy.exc.OperationalError:sqlite3.OperationalError没有这样的列

问题描述

我正在尝试使用SQLAlchemy(使用Flask)创建模型,但是我无法在互联网上找到解决问题的方法。

它给我的错误是

sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) no such column: users.access

但是我从文档和教程中看到,初始化列的语法是正确的。

instances.py

from flask import Flask,redirect,url_for,render_template,request,session,flash
from datetime import timedelta
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)  # Create an instance of Flask
app.secret_key = "website"
app.config["SQLALCHEMY_DATABASE_URI"] = 'sqlite:///users.sqlite3'
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
app.permanent_session_lifetime = timedelta(days=4)

db = SQLAlchemy(app)

ACCESS = {
    'guest': 0,'user': 1,'admin': 2
}

class users(db.Model):
    # every row has ID of type integer and it is unique (primary_key)
    _id = db.Column("id",db.Integer,primary_key=True)
    name = db.Column("name",db.String(100))
    email = db.Column("email",db.String(100))
    access = db.Column("access",db.Integer)

    def __init__(self,name,email,access=ACCESS["user"]):
        self.name = name
        self.email = email
        self.access = access

    def is_admin(self):
        return self.access == ACCESS["admin"]

    def allowed(self,access_level):
        return self.access >= access_level


app.register_blueprint(admin,url_prefix="/admin")

并且当我尝试到达访问在 main.py 中定义的数据库(例如/ login)的路由时出现错误:

from flask import Flask,flash
import instances

def load_admins(filename='admin_names.txt'):
    file = open(filename,'r+')
    content = file.read()
    lines = content.split("\n")
    print("ADMINS: ",lines)
    return lines

admins = load_admins()
  

@instances.app.route("/home")#
def home():
    return render_template("index.html")

@instances.app.route("/login",methods=["POST","GET"])
def login():
    print("LOGIN FORM: ",request.form)
    if request.method == "POST":
        session.permanent = True
        user = request.form["name"]
        session["user"] = user #store data as dict
        session["access"] = 1
        print(session)
        found_user = instances.users.query.filter_by(name=user).first()
        if found_user:
            session["email"] = found_user.email
            if found_user.email in admins:
                session["access"]=2
        else:
            usr = instances.users(user,"",1)
            print(usr)
            instances.db.session.add(usr)  # add user to database
            instances.db.session.commit()
        print(session)
        flash("Login successful")
        print("Session: ",session)
        return redirect(url_for("user"))
    else:
        if "user" in session:
            #flash("Already logged in")
            print("Session: ",session)
            return redirect(url_for("user"))
        return render_template("login.html")

if __name__=="__main__":
    instances.db.create_all()
    instances.app.run(debug=True)

经过无数次调试会议和在线研究,由于某种原因,我认为它不初始化“ access = db.Column(“ access”,db.Integer)“行中的列。 预先感谢。

解决方法

您是对的,access = db.Column("access",db.Integer)尚未更改数据库-。有两种方法可以做到这一点。一种是使用db.create_all() method,它查看您定义的模型并创建它们。这对于快速而又肮脏的方法是很好的,但是在现实世界中却不建议这样做,因为您不知道它的作用,并且不能保证本地服务器和生产服务器具有相同的模式。

一种更可靠的方法是使用Flask-Migrate为您完成此操作。它与Flask和SQLAlchemy很好地集成在一起,即使需要阅读一些内容,也可以很好地控制数据库。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...