MPTT, дерево услуг. Админка отлично работает, услуги достаются, всё хорошо.
Теперь надо сделать доступ к данным из микросервиса, там применяется ORM алхимии, модель описана так:
class Service(Base):
__tablename__ = 'producers_service'
id = Column(UUID(as_uuid=True), primary_key=True) # для remote_side
parent_id = Column(UUID(as_uuid=True), ForeignKey('producers_service.id'))
parent = relationship('Service',
backref=backref('children', remote_side=[id]),
collection_class=attribute_mapped_collection('id'))
Есть две услуги, одна потомок другой, дальше начинается странность:
В Django:
>>> o = BSL.objects.get(pk='db2de318-a978-4c8e-99e5-df7a6d039cec')
>>> o.service.level
4
>>> o.service.parent.level
3
В микросервисе:
(Pdb) p parent_service.level
4
(Pdb) p bsl.service.level
3
parent указывает на потомка в алхимии!
Неправильно сделал определение в модели ORM?
Если два приложения лазят в одну БД - это не микросервисы, а один распоеделнный монолит. Такое лучше избегать, либо по крайней мере использовать в обоих одни технологии
Джанго там только миграции обеспечивает и техническую админку. Но вопрос был про алхимию ,)
разобрался
И в чём проблема была?
Обсуждают сегодня