Afl*_*loz 5 python flask wtforms flask-sqlalchemy flask-wtforms
sqlalchemy.exc.InterfaceError: <unprintable InterfaceError object>我正在尝试 Flask,但在提交 wtforms 时遇到错误。模型类是:
class Post(db.Model):
__tablename__ = 'blog_posts'
id = db.Column(db.Integer, unique=True, primary_key=True)
title = db.Column(db.String(50), unique=False)
content = db.Column(db.Text, unique=False)
user_id = db.Column(db.String, db.ForeignKey('users.username'))
@staticmethod
def post_new_entry(title, content, user_id):
""" Post new entry to database """
new_post = Post(title=title, content=content, user_id=user_id)
db.session.add(new_post)
db.session.commit()
return new_post
def __repr__(self):
return 'PostID {}: {} by {}'.format(self.id, self.title, self.user_id)
Run Code Online (Sandbox Code Playgroud)
对于我的表格,我有以下内容:
class PostForm(Form):
title = StringField('Title', validators=[DataRequired(), Length(10, 65)])
post_content = TextAreaField('Content', validators=[DataRequired(), Length(50, 500)])
submit = SubmitField('Publish Post')
Run Code Online (Sandbox Code Playgroud)
路线是:
@main.route('/new_post/', methods=['GET', 'POST'])
@login_required
def add_post():
form = PostForm()
if form.validate_on_submit():
Post.post_new_entry(title=form.title.data,
content=form.post_content.data,
user_id=current_user)
flash("Amazing stuff! Thanks for your submission.")
return redirect(url_for('main.index'))
return render_template('single.html', form=form)
Run Code Online (Sandbox Code Playgroud)
在我的 html 上,我导入了wtf.htmlFlask-bootstrap 的页面:
{{ wtf.quick_form(form) }}
Run Code Online (Sandbox Code Playgroud)
表单显示正确,但我在提交表单时收到上述错误。有关如何继续的任何提示或想法都会有所帮助。
在表类定义中,您需要再添加一行来完成外键关系。
class Post(db.Model):
__tablename__ = 'blog_posts'
id = db.Column(db.Integer, unique=True, primary_key=True)
title = db.Column(db.String(50), unique=False)
content = db.Column(db.Text, unique=False)
user_id = db.Column(db.String, db.ForeignKey('users.username'))
# Setup the relationship to the User table
users = db.relationship(User)
Run Code Online (Sandbox Code Playgroud)
我在一个应用程序中遇到了相同的错误消息,该应用程序有一天工作,然后第二天就不行了。让我发疯的是,解决方案是我在某处删除了一个关系()。