微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQLAlchemy 更新对象树

如何解决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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?