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

SQLAlchemy:通过关联对象的自引用、多对多、对称相同属性关系

如何解决SQLAlchemy:通过关联对象的自引用、多对多、对称相同属性关系

我想在 sqlAlchemy (v1.4) 中对类 Sibling 的自引用、多对多关系建模,其中每个 Sibling 可以有多个 {{1} }.这种关系是完全对称的(两者之间没有层次结构),所以我们的想法是在 siblings 中只有一个 siblings 属性。两个兄弟姐妹之间的一个 Sibling 都有一些额外的数据 AssociationsqlAlchemy 文档建议在这种情况下使用 Association Object

这个想法是有一个 extra_data 表,在这个例子中只存储 ID,还有一个 Sibling 链接器表,其中一对同级 ID 与附加数据一起存储。兄弟 ID 的顺序应该无关紧要,因此无序 ID 对应该是唯一的。

我不知道如何解决这个问题,尽管我在这里找到了一些与我的情况非常接近的帖子,但并不完全:要么使用了关联对象,但存在层次结构,因此有两个使用不同的属性(如 Self-Referential Association Relationship SQLalchemy 中),或者是对称关系,但不需要额外的列,因此不使用关联对象(如 How can I achieve a self-referencing many-to-many relationship on the SQLAlchemy ORM back referencing to the same attribute? 中)。

我想象的代码有点像下面:

Association

我想我知道如何直接使用 sql 表达式来执行此操作,但我确定必须为此使用 sqlAlchemy 模式。我只是没有足够的经验来了解如何。我更喜欢只有两个表的解决方案,这在理论上应该是可能的。我真的很感激这方面的帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。