В Django (2.x) у меня есть форма ввода, модель здесь:
from django.db import models
from django.contrib.auth.models import User
from django.conf import settings
class Sample(models.Model):
sample_id = models.AutoField(primary_key=True)
area_easting = models.IntegerField()
area_northing = models.IntegerField()
context_number = models.IntegerField()
sample_number = models.IntegerField()
# taken_by = models.IntegerField()
taken_by = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete = models.PROTECT)
def __str__(self):
return str(self.sample_id)
class Meta:
db_table = 'samples\".\"sample'
#ordering = ["sample_id"]
managed = False
#verbose_name_plural = "samples"
Это работает, как и ожидалось, список имен пользователей выпадает вниз (в то время как я хотел бы отформатировать - firstnameФамилия).Однако, когда я возвращаюсь на главную страницу просмотра, я вижу ошибку.
django.db.utils.ProgrammingError: column sample.taken_by_id does not exist
LINE 1: ...text_number", "samples"."sample"."sample_number", "samples"....
^
HINT: Perhaps you meant to reference the column "sample.taken_by".
Очевидно, что Django добавляет _id
к имени таблицы, вызывая ошибку, я ожидаю, потому что это внешний ключ.
Есть идеи, как исправить это поведение?