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__ ==

相关内容

热门资讯

详细辅助!闲逸碰胡外桂,火神大... 详细辅助!闲逸碰胡外桂,火神大厅辅助,透视实锤开挂(有挂方略) >>您好:软件加薇136704302...
了解辅助!新西部大厅辅助,老友... 了解辅助!新西部大厅辅助,老友广东辅助工具下载地址,科技介绍开挂(有人有挂)>>您好:软件加薇136...
科技辅助!财神十三章怎样加强运... 科技辅助!财神十三章怎样加强运气,哈糖大菠萝提高胜率,透视安装开挂(有挂解惑) 了解更多开挂安装加(...
原来有辅助!玉海楼茶苑辅助器,... 原来有辅助!玉海楼茶苑辅助器,皇豪互众辅助软件是干嘛的,我来分享开挂(详细教程)《详细加薇13670...
传授辅助!雀姬手机辅助脚本,兴... 传授辅助!雀姬手机辅助脚本,兴动互娱辅助工具,玩家必看科普开挂(有挂攻略);亲,兴动互娱辅助工具这款...
分析辅助!途游休闲铺破解版,越... 较多好评“微乐万能挂官网”开挂(透视)辅助教程 了解更多开挂安装加(136704302)微信号是一款...
实测辅助!关春天跑得快辅助器,... 实测辅助!关春天跑得快辅助器,创思维激k辅助器视频,玩家必备攻略开挂(有挂助手)>>您好:软件加13...
通报辅助!越乡游义乌辅助工具,... 大家好,今天小编来为大家解答越乡游义乌辅助工具这个问题咨询软件客服可以免费测试直接加微信(13670...
推荐辅助!快乐碰胡辅助,心悦踢... 推荐辅助!快乐碰胡辅助,心悦踢辅助软件,一分钟教会你开挂(有挂教程)1、下载安装好心悦踢辅助软件,进...
分析辅助!江西中至黑科技辅助插... 分析辅助!江西中至黑科技辅助插件,拱趴游戏插件,每日必看推荐开挂(真是有挂)>>您好:软件加1367...