commit 与do_key('commit_form')区别

34 篇文章 1 订阅
1.commit_form
针对form上面的数据变动进行commit,对于代码中的类似update,insert语句也进行提交;
如果form上面的数据变动和代码中的数据变动有冲突,最后以界面上的为准。
2.do_key('commit_form')
会首先寻找form下的triggers中的KEY-COMMIT这个trigger,并执行KEY-COMMIT中所写的代码。
如果没有KEY-COMMIT这个trigger,则会针对form和代码一起提交。
如果form上面的数据变动和代码中的数据变动有冲突,最后以界面上的为准。
3.commit
对form和数据库进行提交.
如果form上面的数据变动和代码中的数据变动有冲突,最后以界面上的为准。
4.forms_ddl('commit');
只针对代码中的update,insert,delete语句进行提交,form上面的数据变动不提交。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Flask 中使用 Flask-SQLAlchemy 进行数据更新操作,你可以按照以下步骤进行: 1. 导入所需的模块和类: ```python from flask import Flask from flask_sqlalchemy import SQLAlchemy ``` 2. 创建 Flask 应用并配置数据库连接: ```python app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = '数据库连接字符串' db = SQLAlchemy(app) ``` 3. 定义数据模型类,继承自 `db.Model`: ```python class User(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(100)) email = db.Column(db.String(100)) def __init__(self, name, email): self.name = name self.email = email ``` 4. 执行数据库迁移操作(如果尚未创建数据库表): ```bash flask db init # 初始化迁移环境(仅首次需要执行) flask db migrate # 创建数据库迁移脚本 flask db upgrade # 执行数据库迁移脚本并创建表 ``` 5. 在视图函数中执行更新操作: ```python @app.route('/update_user/<int:user_id>', methods=['POST']) def update_user(user_id): user = User.query.get(user_id) if not user: return 'User not found', 404 new_name = request.form.get('name') new_email = request.form.get('email') user.name = new_name user.email = new_email db.session.commit() return 'User updated successfully' ``` 在上述代码中,我们通过 `User.query.get(user_id)` 来获得要更新的用户对象。然后,我们可以从请求中获取新的用户名和电子邮件,并将其赋值给用户对象的相应属性。最后,我们调用 `db.session.commit()` 来提交更改到数据库。 请注意,上述代码只是一个示例,你可能需要根据自己的实际情况进行调整。另外,确保在更新数据之前对用户进行身份验证和授权,以确保只有授权用户可以执行更新操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值