如何解决在迁移后更改 Django 上的 db_table 不起作用,并且添加用户 (AbstractUser) 外键中断 __str__()
这是一个有 2 个问题的帖子,我怀疑它们之间有某种联系。 我在 Django 上的帖子应用程序没有正确迁移(我认为),并且添加“作者”(Users AbstractUser 模型)会破坏我的代码并显示错误:
str 返回非字符串(元组类型)
每当我尝试添加一行时。
我使用 db_table
更改了表的名称(因此它将在管理页面上将 Postss 更改为 Posts)并将输出添加到 __str__
函数,我尝试了一些输出变体str 函数,但它们都不起作用。我什至试图将其注释掉。还是。表名或错误没有变化。我尝试多次更改 str 函数并得到相同的结果。删除 str 函数时,我仍然得到相同的结果。
我对这种情况有一些疯狂的猜测:
- 由于某种原因,它可能不适用于抽象用户类,并且不知道如何解决这个问题以及为什么会发生这种情况。 (删除
author=...
行可以解决此问题,但不会更改表名,但我确实需要用户 fk 在那里)。 - 由于我的环境或 Python 版本
Python 3.9.1
(?),它可能无法正确迁移。
- PS:我所做的每项更改都包括停止服务器运行和运行以下行:
python manage.py migrate
和python manage.py makemigrations
。
posts/models.py:
from django.db import models
from users.models import Users
class Posts(models.Model):
content = models.TextField(max_length=255)
author = models.ForeignKey('users.Users',on_delete=models.CASCADE,null=True)
timestamp = models.DateTimeField(auto_Now_add=True,null=True)
class Meta:
db_table = 'Posts'
def __str__(self):
return self.content + " " + self.author.email + " " + self.timestamp
from django.db import models
from django.contrib.auth.models import AbstractUser
# https://rahmanfadhil.com/django-login-with-email/
class Users(AbstractUser):
USERNAME_FIELD = 'email'
email = models.EmailField(unique=True)
required_FIELDS = ['username'] # removes email from required_FIELDS
def __str__(self):
return (self.email,self.username)
解决方法
尝试将您的 __str__
方法更改为:
def __str__(self):
return self.content + " " + str(self.author.email) + " " + str(self.timestamp)
此外,您只需要在对模型而不是模型方法进行更改时进行迁移。
,您正在尝试返回一个 tuple
,它必须是一个 string
。
def str(自我): 返回(self.email,self.username)
使用 Python 中的新样式格式
试试这个:
class Users(AbstractUser):
...
def __str__(self):
template = '{0.email} {0.username}'
return template.format(self)
class Posts(models.Model):
...
def __str__(self):
template = '{0.content} {0.author.email} {0.timestamp}'
return template.format(self)
或
def __str__(self):
return '{} {} {}'.format(self.content,self.author.email,self.timestamp)
第二个问题:
如果我正确理解您的问题,那么要更改模型的标签,您需要使用 verbose_name
:
class Meta:
verbose_name = 'Post'
verbose_name_plural = 'Posts'
使用选项 db_table,您可以更改用于模型的数据库表的名称。
看看它是如何工作的,来自 Django:如果你有一个应用程序 bookstore
(由 manage.py startapp bookstore
创建),定义为 class Book
的模型将有一个名为 { {1}}。
那么 bookstore_book
必须是:
db_table
要列出 PostgreSQL 的当前数据库中的表,您可以运行:
class Meta:
# your desired table name can you find in your database
db_table = 'appLabel_modelName'
另见 Django db_table
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。