Я строю приложение генеалогического древа в Джанго, где мне нужно представлять в браках симметрично. Каждый брак должен иметь только одну запись, а отношения должны включать обоих партнеров без дублирования данных. Вот соответствующая структура модели: < /p>
class Person(models.Model):
first_name = models.CharField(max_length=100)
last_name = models.CharField(max_length=100)
spouses = models.ManyToManyField(
'self', through="Marriage", symmetrical=True, related_name="partners"
)
class Marriage(models.Model):
person1 = models.ForeignKey(Person, on_delete=models.CASCADE, related_name="marriages_as_person1")
person2 = models.ForeignKey(Person, on_delete=models.CASCADE, related_name="marriages_as_person2")
start_date = models.DateField(null=True, blank=True)
end_date = models.DateField(null=True, blank=True)
< /code>
Я хочу: < /p>
[*] Убедитесь, что оба партнера появляются как супруги друг для друга симметрично. < /li>
Избегайте дублирующихся записей для одного и того же брака. < /li>
Эффективно запросить всех супругов человека. > Вот код, который я использую для запроса супругов: < /p>
# Query spouses for a person
p1 = Person.objects.create()
p2 = Person.objects.create()
Marriage.objects.create(person1=p1, person2=p2)
p1.spouses.all() # Returns list containing p2
p2.spouses.all() # Returns empty list
Однако я столкнулся с проблемами:
Если запрашиваются супруги p1, он должен содержать p2 и если запрашиваются супруги p2, он должен содержать p1
[*]Оба запроса не симметричны
Вопросы:
[*]Правильна ли структура моей модели для симметричного представления браков? Если нет, то какие улучшения мне следует внести?
[*]Как я могу эффективно запрашивать всех супругов человека с помощью оптимизированной базы данных, обеспечивая при этом симметрию?
Мой вариант использования — вернуть список или человека, имеющего pids (идентификатор партнера) в виде списка идентификаторов, как показано ниже, с использованием DRF
[
{
id: 1,
full_name: ‘John’,
pids: [2]
},
{
id: 2,
full_name: ‘Mary’,
pids: [1]
}
]
Подробнее здесь: https://stackoverflow.com/questions/793 ... amily-tree
Django: как представлять и запрашивать симметричные отношения для генеалогического древа? ⇐ Python
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Django: как представлять и запрашивать симметричные отношения для генеалогического древа?
Anonymous » » в форуме Python - 0 Ответы
- 19 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Django: как представлять и запрашивать симметричные отношения для генеалогического древа?
Anonymous » » в форуме Python - 0 Ответы
- 11 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Джанго: Как представлять и запросить симметричные отношения для семейного древа?
Anonymous » » в форуме Python - 0 Ответы
- 15 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Лучший способ реализации генеалогического древа в Java с использованием структуры данных
Anonymous » » в форуме JAVA - 0 Ответы
- 15 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Лучший способ реализации генеалогического древа в Java с использованием структуры данных
Anonymous » » в форуме JAVA - 0 Ответы
- 8 Просмотры
-
Последнее сообщение Anonymous
-