Мое приложение Django отлично работает на localhost, но когда я пытаюсь отправить его на Heroku, я получаю следующую ошибку:
remote: django.db.utils.ProgrammingError: несколько первичных ключей для таблицы «Clientes_productlist» не допускаются
Мой файл models.py:
class ProductList(models.Model):
id_new = models.IntegerField(primary_key=True)
sku = models.CharField(max_length=200)
client = models.ForeignKey(get_user_model(), on_delete=models.CASCADE)
name = models.CharField(max_length=256)
description = models.CharField(max_length=1000)
storage = models.CharField(max_length=256)
cost_price = models.CharField(max_length=256)
sell_price = models.CharField(max_length=256)
ncm = models.CharField(max_length=256)
inventory = models.IntegerField(null=True)
class Meta:
unique_together = (('sku', 'client'),)
Я также использую пакет django-import-export. Следовательно, мой resources.py:
class ProductListResource(resources.ModelResource):
class Meta:
model = ProductList
skip_unchanged = True
report_skipped = True
exclude = ('id',)
import_id_fields = ('sku', 'client',)
fields = ('sku', 'client', 'name', 'description', 'storage', 'cost_price', 'sell_price', 'ncm', 'inventory',)
Что вызывает эту ошибку и как ее решить?






Чтобы исправить это, вам необходимо удалить все файлы миграции в папке migrations приложения, в котором существует модель ProductList, за исключением файла __init__.py, и запустить ./manage.py makemigrations для создания новых миграций. Затем зафиксируйте эти миграции и отправьте их в Heroku.
После этого я получаю эту ошибку: столбец Clientes_productlist.id_new не существует. СТРОКА 1: ВЫБЕРИТЕ «Список клиентов_продукта». «Id_new», «Clientes_productlis ... У вас есть какие-нибудь подсказки по этому поводу?
Я предполагаю, что у Clientes есть FK для ProductList. Таким образом, у него была миграция, которая была связана с миграциями ProductList или зависела от них. Поскольку миграции ProductList были созданы позже, возникла проблема. Возможно, будет лучше, если вы удалите все файлы миграции из проекта (кроме файлов __init__.py внутри каталога миграции), запустите makemigrations и зафиксируйте их. также сбросьте БД в героку, прежде чем выполнять миграции и запускать их в героку. Возможно этот документ поможет сбросить db: gist.github.com/zulhfreelancer/ea140d8ef9292fa9165e
Теперь у меня появляется эта ошибка, когда я пытаюсь получить доступ к любой странице: отношение "django_session" не существует СТРОКА 1: ... ession_data "," django_session "." Expire_date "FROM" django_se ...
Неважно, я просто удалил всю базу данных в Heroku и отодвинул назад. Сейчас все нормально!
Отлично, чувак! Спасибо еще раз за помощь!