【python】flask查询更新指定的某一条记录

PackageRecord.query.filter_by(id=package_id).update(json_data) 这段代码的问题在于它不能正确地更新指定的记录。这是因为 update() 方法是 SQLAlchemy 提供的一种批量更新的方法,他通过接收一个字典对象来更新记录。但是在你的代码中,json_data 应该是一个 JSON 字符串,而不是一个字典对象。

为了解决这个问题,你可以尝试通过手动修改对象属性来实现单个记录的更新,或者使用 SQLAlchemy 的 session 对象来更新记录。下面是两种解决方案的示例代码:

  1. 手动修改对象属性进行更新:

    record = PackageRecord.query.filter_by(id=package_id).first()
    if record:
    record.attribute1 = new_value1
    record.attribute2 = new_value2
    # ...
    db.session.commit()

  2. 使用 session 对象进行更新:

    record = db.session.query(PackageRecord).filter_by(id=package_id).first()
    if record:
    db.session.query(PackageRecord).filter_by(id=package_id).update(json.loads(json_data))
    db.session.commit()

在这两种解决方案中,PackageRecord 是你的数据模型类,db 是你的数据库会话对象,package_id 是要更新的记录的 ID,new_value1new_value2 等是要更新的属性的新值。

相关推荐
ERP老兵_冷溪虎山32 分钟前
Python/JS/Go/Java同步学习(第十三篇)四语言“字符串转码解码“对照表: 财务“小南“纸式转码术处理凭证乱码崩溃(附源码/截图/参数表/避坑指南)
java·后端·python
okra-1 小时前
如何进行WEB安全性测试
数据库
独行soc1 小时前
2025年渗透测试面试题总结-67(题目+回答)
网络·python·安全·web安全·网络安全·adb·渗透测试
eybk2 小时前
用python的socket写一个局域网传输文件的程序
服务器·网络·python
程序员的世界你不懂2 小时前
【Flask】实现一个前后端一体的项目-脚手架
后端·python·flask
island13142 小时前
【Redis#9】其他数据结构
数据结构·数据库·redis
花酒锄作田2 小时前
[MCP][01]简介与概念
python·llm·mcp
Python私教2 小时前
Django全栈班v1.04 Python基础语法 20250912 上午
后端·python·django
言之。2 小时前
Django REST框架:ModelViewSet全面解析
数据库·python·django
-Xie-2 小时前
Mysql杂志(十四)——Mysql逻辑架构
数据库·mysql·架构