如何解决SQLAlchemy 更新对象树
我正在尝试构建对象树。这个类看起来像这样:
class Node(BaseModel,db.Model):
'''Node model'''
__tablename__ = 'network_nodes'
id = Column(String(10),primary_key=True)
parent_id = Column(String(10),ForeignKey('network_nodes.id'))
parent = relationship("Node",foreign_keys=[parent_id],lazy='dynamic')
left_id = Column(String(10),ForeignKey('network_nodes.id'))
left = relationship("Node",lazy='dynamic')
right_id = Column(String(10),ForeignKey('network_nodes.id'))
right = relationship("Node",lazy='dynamic')
node.left_id = element_id
left = Node(id=element_id,parent_id=node.id)
db.session.add(left)
在某些时候,我使用 db.session.commit()
提交所有更改。在 commit()
点,我看到会话中的脏对象和新对象。但是提交失败并出现错误:
(MysqLdb._exceptions.IntegrityError) (1452,'无法添加或更新子行:外键约束失败 (db
.network_nodes
,CONSTRAINT network_nodes_ibfk_2
FOREIGN KEY ({ {1}}) 参考 left_id
(network_nodes
))')
[sql: UPDATE network_nodes SET left_id=%s,right_id=%s WHERE network_nodes.id = %s]
[参数:('S5837124','S5839010','S5832131')]
我假设脏对象在新对象之前提交。因此,id
指的是尚不存在的记录。
如何在脏对象之前提交新对象?
解决方法
如何在脏对象之前提交新对象?
您可以添加所有对象,刷新新对象,然后提交整个批次:
left = Node(id=element_id,parent_id=node.id)
session.add(left)
node.left_id = element_id
session.flush(session.new)
session.commit()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。