使用用户 table,导致错误
Making use of the users table, causing an error
在 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"
这按预期工作,用户名列表下拉(虽然我想格式化 - 名字姓氏)。但是,当我 return 到主查看页面时,我看到一个错误。
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
添加到 table 名称导致错误,我预计是因为它是一个外键。
有什么办法可以纠正这种行为吗?
https://docs.djangoproject.com/en/2.1/ref/models/fields/#database-representation
^ link 到指定创建 _id
字段的文档。
根据您发布的错误消息。您的数据库架构似乎没有更新。
您可能需要执行管理 makemigrations
和 migrate
以将您的模型更改应用到您的数据库架构
例如
$ python manage.py makemigrations
# to apply the new migrations file
$ python manage.py migrate
您可以通过 db_column
属性显式设置基础数据库列:
taken_by = models.ForeignKey(settings.AUTH_USER_MODEL, db_column='taken_by', on_delete=models.PROTECT)
在 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"
这按预期工作,用户名列表下拉(虽然我想格式化 - 名字姓氏)。但是,当我 return 到主查看页面时,我看到一个错误。
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
添加到 table 名称导致错误,我预计是因为它是一个外键。
有什么办法可以纠正这种行为吗?
https://docs.djangoproject.com/en/2.1/ref/models/fields/#database-representation
^ link 到指定创建 _id
字段的文档。
根据您发布的错误消息。您的数据库架构似乎没有更新。
您可能需要执行管理 makemigrations
和 migrate
以将您的模型更改应用到您的数据库架构
例如
$ python manage.py makemigrations
# to apply the new migrations file
$ python manage.py migrate
您可以通过 db_column
属性显式设置基础数据库列:
taken_by = models.ForeignKey(settings.AUTH_USER_MODEL, db_column='taken_by', on_delete=models.PROTECT)