Django.db.utils.ProgrammingError: колонка accounts_account.username не существует
Я получаю эту ошибку после настройки модели пользователя клиента. и теперь я получаю эту ошибку, когда я пытаюсь войти в панель администратора и когда я пытаюсь создать суперпользователя.
Я пытался сбросить базу данных postgresql под названием skincareryland... но получаю ошибку при входе по паролю... когда я пытаюсь изменить пароль, я получаю эту ошибку... ERROR: роль "postgres" не существует
Я также попытался выполнить эти шаги из сообщения на overstack, но мне не удалось решить проблему... Закомментируйте 'django.contrib.admin' из INSTALLED_APPS в settings.py и закомментируйте # path('admin/', admin.site.urls) в urls.py
выполнить команды:
Python manage.py makemigrations appname
Python manage.py migrate appname
добавьте 'django.contrib.admin' в INSTALLED_APPS в файле settings.py и path('admin/', admin.site.urls) в urls.py
выполните команды снова:
Python manage.py makemigrations appname
Python manage.py migrate appname
from django.db import models
from django.contrib.auth.models import AbstractBaseUser,
BaseUserManager
class MyAccountManager(BaseUserManager):
def create_user(self, first_name, last_name, username, email,
password=None):
if not email:
raise ValueError('User must have an email address')
if not username:
raise ValueError('User must have an username')
user = self.model(
email=self.normalize_email(email),
username=username,
first_name=first_name,
last_name=last_name,
)
user.set_password(password)
user.save(using=self._db)
return user
def create_superuser(self, first_name, last_name, email, username,
password):
user = self.create_user(
email=self.normalize_email(email),
username=username,
password=password,
first_name=first_name,
last_name=last_name,
)
user.is_admin = True
user.is_active = True
user.is_staff = True
user.is_superadmin = True
user.save(using=self._db)
return user
class Account(AbstractBaseUser):
first_name = models.CharField(max_length=50)
last_name = models.CharField(max_length=50)
username = models.CharField(max_length=50, unique=True)
email = models.EmailField(max_length=100, unique=True)
phone_number = models.CharField(max_length=50)
# required
date_joined = models.DateTimeField(auto_now_add=True)
last_login = models.DateTimeField(auto_now_add=True)
is_admin = models.BooleanField(default=False)
is_staff = models.BooleanField(default=False)
is_active = models.BooleanField(default=False)
is_superadmin = models.BooleanField(default=False)
USERNAME_FIELD = 'email'
REQUIRED_FIELDS = ['username', 'first_name', 'last_name']
objects = MyAccountManager()
def full_name(self):
return f'{self.first_name} {self.last_name}'
def __str__(self):
return self.email
def has_perm(self, perm, obj=None):
return self.is_admin
def has_module_perms(self, add_label):
return True
class UserProfile(models.Model):
user = models.OneToOneField(Account, on_delete=models.CASCADE)
address_line_1 = models.CharField(blank=True, max_length=100)
address_line_2 = models.CharField(blank=True, max_length=100)
profile_picture = models.ImageField(blank=True,
upload_to='userprofile')
city = models.CharField(blank=True, max_length=20)
state = models.CharField(blank=True, max_length=20)
country = models.CharField(blank=True, max_length=20)
def __str__(self):
return self.user.first_name
def full_address(self):
return f'{self.address_line_1} {self.address_line_2}'
Вот моя ошибка Traceback:
Возможно, в вашем settings.py нужно добавить строку
AUTH_USER_MODEL = 'your_app.Account'
или
AUTH_USER_MODEL = 'Account'
в зависимости от того, как вы настроили проект.
Также удалите все миграции и сбросьте базу данных, затем сделайте их снова.