AttributeError:'int'objecthasnoattribute'_sa_instance_state'=>flask+sqlalchemy+many-to-many+WTFSelectMultipleField
创始人
2024-09-21 23:01:38
0

这个错误可能是因为使用不正确的查询,以及尝试在 Int 实例上设置实例状态。解决方法是确保你正在正确查询对象,并在选择多个字段中使用字符串而不是整数作为值。或者,如果你真的想使用整数,请首先将其转换为字符串。下面是使用 Flask,SQLAlchemy 和 WTF SelectMultipleField 的示例代码,可以帮助避免这个错误:

from flask import Flask, render_template, request
from flask_sqlalchemy import SQLAlchemy
from wtforms import SelectMultipleField, widgets

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///test.db'
db = SQLAlchemy(app)

association_table = db.Table('association', db.Model.metadata,
    db.Column('student_id', db.Integer, db.ForeignKey('student.id')),
    db.Column('class_id', db.Integer, db.ForeignKey('class.id'))
)

class Student(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50))
    classes = db.relationship('Class', secondary=association_table, backref=db.backref('students', lazy='dynamic'))

class Class(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50))

class MultiCheckboxField(SelectMultipleField):
    widget = widgets.ListWidget(prefix_label=False)
    option_widget = widgets.CheckboxInput()

@app.route('/', methods=['GET', 'POST'])
def index():
    form = StudentForm(request.form)
    form.classes.choices = [(str(c.id), c.name) for c in Class.query.all()]
    if request.method == 'POST' and form.validate():
        student = Student(name=form.name.data)
        for class_id in form.classes.data:
            student.classes.append(Class.query.get(int(class_id)))
        db.session.add(student)
        db.session.commit()
    students = Student.query.all()
    return render_template('index.html', form=form, students=students)

class StudentForm(FlaskForm):
    name = StringField('Name')
    classes = MultiCheckboxField('Classes')

if __name__ ==

相关内容

热门资讯

1分钟实锤!智星德州菠萝外挂(... 1分钟实锤!智星德州菠萝外挂(德州)总是真的是有挂(详细辅助AA德州教程);1、任何智星德州菠萝外挂...
2分钟实锤!智星德州菠萝外挂(... 2分钟实锤!智星德州菠萝外挂(来玩德州)竟然是真的有挂(详细辅助技巧教程)1、任何智星德州菠萝外挂a...
第8分钟实锤!智星德州菠萝辅助... 第8分钟实锤!智星德州菠萝辅助器(德州ai)总是真的是有挂(详细辅助介绍教程)1、用户打开应用后不用...
8分钟实锤!德扑之星猫腻(德州... 8分钟实锤!德扑之星猫腻(德州wepower)确实真的是有挂(详细辅助第三方教程)1、德扑之星猫腻系...
第2分钟实锤!智星德州菠萝(线... 第2分钟实锤!智星德州菠萝(线上德州)切实有挂(详细辅助第三方教程)第2分钟实锤!智星德州菠萝(线上...
3分钟实锤!德扑ai助手(nz... 3分钟实锤!德扑ai助手(nzt德州)确实是有挂(详细辅助透明挂教程);1、玩家可以在德扑ai助手软...
第二分钟实锤!德扑之星有猫腻(... 第二分钟实锤!德扑之星有猫腻(德州app)本来真的有挂(详细辅助wpk教程)1、第二分钟实锤!德扑之...
第十分钟实锤!德州之星外挂(德... 第十分钟实锤!德州之星外挂(德州nzt)果然真的有挂(详细辅助AI教程)该软件可以轻松地帮助玩家将德...
第3分钟实锤!智星德州菠萝有挂... 第3分钟实锤!智星德州菠萝有挂吗(nzt德州)其实有挂(详细辅助科技教程)1、点击下载安装,智星德州...
第6分钟实锤!德扑之星有作弊(... 第6分钟实锤!德扑之星有作弊(nzt德州)真是存在有挂(详细辅助黑科技教程)进入游戏-大厅左侧-新手...