Использование таблицы пользователей, вызывающее ошибку - PullRequest
0 голосов
/ 13 февраля 2019

В 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 к имени таблицы, вызывая ошибку, я ожидаю, потому что это внешний ключ.

Есть идеи, как исправить это поведение?

Ответы [ 2 ]

0 голосов
/ 13 февраля 2019

Вы можете явно установить базовый столбец БД через атрибут db_column:

taken_by = models.ForeignKey(settings.AUTH_USER_MODEL, db_column='taken_by', on_delete=models.PROTECT)
0 голосов
/ 13 февраля 2019

https://docs.djangoproject.com/en/2.1/ref/models/fields/#database-representation

^ ссылка на документы, где указано, что она создает поле _id.

на основе опубликованного вами сообщения об ошибке.Похоже, что ваша схема базы данных не обновлена.

вам может потребоваться управлять makemigrations и migrate, чтобы применить изменения вашей модели к вашей схеме БД

, например,

$ python manage.py makemigrations
# to apply the new migrations file
$ python manage.py migrate
...