【发布时间】:2021-05-22 06:21:25
【问题描述】:
我正在尝试构建对象树。该类如下所示:
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", foreign_keys=[parent_id], lazy='dynamic')
right_id = Column(String(10), ForeignKey('network_nodes.id'))
right = relationship("Node", foreign_keys=[parent_id], 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, CONSTRAINTnetwork_nodes_ibfk_2FOREIGN KEY (left_id) 参考@987654329 @ (id))') [SQL: UPDATE network_nodes SET left_id=%s, right_id=%s WHERE network_nodes.id = %s] [参数:('S5837124','S5839010','S5832131')]
我假设脏对象在新对象之前提交。因此left_id 指的是尚未存在的记录。
如何在脏对象之前提交新对象?
【问题讨论】:
标签: python sqlalchemy mysql-python