объединить две таблицы в django admin, чтобы получить столбцы для display_list - PullRequest
0 голосов
/ 22 сентября 2018

У меня проблема с list_display / соединением двух таблиц для интерфейса администратора django.

Я хочу иметь столбцы - имя_программы и is_active из Схемы модель с имя_параметра, описание_параметра из VisVisitParameters модель в админке django.У меня есть те столбцы, которые я использую с возвратом в каждой из этих моделей.Я пытался получить помощь по вопросу , который уже был задан.Но все же я не смог понять это.

class SchPrograms(models.Model):
  program_id = models.AutoField(primary_key=True)
  program_name = models.CharField(max_length=200, blank=True, null=True)
  creation_timestamp = models.DateTimeField(blank=True, null=True)
  is_active = models.IntegerField()

  class Meta:
      managed = True
      db_table = 'sch_programs'
      app_label = 'polls'

  def __str__(self):
      return self.program_name

class VisVisitParameters(models.Model):
   vparameter_id = models.AutoField(primary_key=True)
   parameter_name = models.CharField(max_length=300, blank=True, null=True)
   parameter_description = models.TextField(blank=True, null=True)
   is_active = models.IntegerField(choices=STATUS_CHOICES)

   class Meta:
       managed = False
       db_table = 'vis_visit_parameters'

   def __str__(self):
       return str(self.vparameter_id)
       app_label = 'polls'


class VisVisitParameterMappings(models.Model):
    vp_map_id = models.AutoField(primary_key=True)
    vparameter =  models.ForeignKey(VisVisitParameters,on_delete=models.CASCADE)
    program = models.ForeignKey(SchPrograms,on_delete=models.CASCADE)
    display_order = models.IntegerField(blank=True, null=True)
    is_active = models.IntegerField()

    class Meta:
       managed = False
       db_table = 'vis_visit_parameter_mappings'
       app_label = 'polls'

    def __str__(self):
       return str(self.parameter_name)

model.py

class VisVisitParameterMappings_admin(admin.ModelAdmin):
    list_display =   ('program_name','is_active','parameter_name','parameter_description ')

1 Ответ

0 голосов
/ 22 сентября 2018

Для отображения необходимых элементов на странице отображения списка вы можете написать свои собственные методы, как описано здесь .

Например, для вашего поля с именем имя_программы Вы можете иметь:

def program_name(self, obj):
    if obj.program:
        return obj.program.program_name

program_name.short_description = 'Program name'

, а для другого поля модели с именем имя_параметра вы можете иметь:

def parameter_name(self, obj):
    if obj.vparameter:
        return obj.vparameter.parameter_name

parameter_name.short_description = 'Parameter Name'

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...