首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >与私钥不同的字段bulk_update_mappings

与私钥不同的字段bulk_update_mappings
EN

Stack Overflow用户
提问于 2019-09-09 15:15:50
回答 1查看 704关注 0票数 2

我有一个带有db字段的类

代码语言:javascript
复制
id = db.Column(db.BigInteger, primary_key=True) 
uuid = db.Column(
  UUID(as_uuid=True), unique=True, nullable=True, default=uuid.uuid4
) 
name = db.Column(db.String(50), nullable=False)

然后,我想按“uuid”字段进行大容量更新,而不是默认情况下的id:

代码语言:javascript
复制
updates = []
for upd in body['new_data']:
    update = {
        'uuid': upd['uuid'],
        'name': upd['name'],
    }
    updates.append(update)

db.session.bulk_update_mappings(MyClass, updates)

但我有一个错误,没有匹配。如何通过“uuid”字段进行批量更新?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-14 17:05:17

根据官方的SQLAlchemy文档,这是不可能的。

所有存在且不属于主键的键都应用于UPDATE语句的SET子句;所需的主键值应用于WHERE子句。

来源:https://docs.sqlalchemy.org/en/13/orm/session_api.html#sqlalchemy.orm.session.Session.bulk_update_mappings

如果您想要另一种选择,请尝试使用on_conflict_do_update(),它的工作方式类似于一个插入,您可以指定哪个列应该是where子句。

这里是详细解释其工作原理的文档。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57856846

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档