Python Flask没有从SQLAlchemy数据库中删除正确的id
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python Flask没有从SQLAlchemy数据库中删除正确的id相关的知识,希望对你有一定的参考价值。
我有一个HTML表从SQLAlchemy数据库中提取数据。
在这个表中,对于每一行,我有一个Delete
按钮,当我点击它时应删除该行和数据库条目。
我遇到的问题是,如果我尝试删除此表中的任何行,它只删除第一行(见下图)和数据库中的相关数据。
我想删除的行和数据保持不变(下图中的第3行)。
如果我在表格的第一行单击Delete
,它可以正常工作。
Update
按钮用作缩进(更新正确的条目)
这是我的数据库模型:
class ActualPost(db.Model):
__tablename__ = 'actualpost'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
title_actual = db.Column(db.String(30), nullable=False, default='actual')
category_actual = db.Column(db.String(30), nullable=False, default=None)
actual_amount_name = db.Column(db.String(30), nullable=True)
actual_amount = db.Column(db.Float, nullable=False)
user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)
date_posted = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
comments = db.Column(db.Text, nullable=True)
def __repr__(self):
return f"ActualPost('{self.title_actual}, '{self.category_actual}'
, '{self.actual_amount_name}', '{self.actual_amount}'
, '{self.date_posted}', '{self.comments}')"
这是我的路线(更新和删除)
@posts.route("/post/<int:post_id>/update_actual", methods=['GET', 'POST'])
@login_required
def update_actual_post(post_id):
post = ActualPost.query.get_or_404(post_id)
if post.actual_author != current_user:
abort(403)
form = PostActualForm()
if form.validate_on_submit():
post.title_actual = form.title_actual.data
post.category_actual = form.category_actual.data
post.actual_amount_name = form.actual_amount_name.data.name
post.actual_amount = form.actual_amount.data
post.comments = form.comments.data
db.session.commit()
flash('Your post has been updated!', 'success')
return redirect(url_for('main.actual', post_id=post.id))
elif request.method == 'GET':
form.title_actual.data = post.title_actual
form.category_actual.data= post.category_actual
form.actual_amount_name.data = post.actual_amount_name
form.actual_amount.data = post.actual_amount
form.comments.data = post.comments
return render_template('create_actual_post.html', title='Update Actual',
form=form, legend='Update Actual')
@posts.route("/post/<int:post_id>/delete_actual", methods=['POST'])
@login_required
def delete_actual_post(post_id):
post = ActualPost.query.get_or_404(post_id)
if post.actual_author != current_user:
abort(403)
db.session.delete(post)
db.session.commit()
flash('Your post has been deleted!', 'success')
return redirect(url_for('main.actual', post_id=post.id))
这是我用于删除按钮的HTML代码:
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<form action="{{ url_for('posts.delete_actual_post', post_id = post.id) }}" method="post">
<input class="btn btn-danger" type="submit" value="Delete">
</form>
</div>
答案
这是我通过id删除特定行的代码。您可以将其与您的代码联系起来
SQLalchemy模型:
class Componants(db.Model):
__tablename__ = 'componants'
id = db.Column(db.Integer, primary_key=True)
cmp_options = db.Column(db.Text, default=None)
updated_at = db.Column(db.DateTime, nullable=True)
created_at = db.Column(db.DateTime, nullable=True)
def __init__(self , cmp_options ):
self.cmp_options = cmp_options
self.created_at = datetime.now()
self.updated_at = datetime.now()
def __repr__(self):
return '<id {}>'.format(self.id)
控制器:
@componants_blueprint.route('/delete_component/<component_id>')
@login_required
def delete_component(component_id):
component = Componants.query.filter_by(id=component_id).first_or_404()
db.session.delete(component)
db.session.commit()
return True
视图:
<tbody>
{% for item in all_components %}
<tr>
<td>{{ item.id }}</td>
<td>{{ item.cmp_options }}</td>
<td>{{ item.created_at }}</td>
<td class="text-center">
<a href="{{ url_for('componants.delete_component', component_id=item.id) }}" title="Delete" class="far fa-trash-alt"></a>
</td>
</tr>
{% endfor %}
</tbody>
以上是关于Python Flask没有从SQLAlchemy数据库中删除正确的id的主要内容,如果未能解决你的问题,请参考以下文章
ModuleNotFoundError:没有名为“flask_sqlalchemy.orm”的模块
如何防止 Flask-SQLAlchemy 中的 SQL 注入?有没有更好的方法从 CSV 加载数据?
Python Flask SQLAlchemy 容器无法连接到 MySQL 容器
带有 sqlalchemy 的 python flask_restless 不会生成 api 端点并使用蓝图给出“没有属性扩展”错误