Django несколько первичных ключей для ошибки таблицы

Мое приложение 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',)

Что вызывает эту ошибку и как ее решить?

Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
0
736
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Чтобы исправить это, вам необходимо удалить все файлы миграции в папке migrations приложения, в котором существует модель ProductList, за исключением файла __init__.py, и запустить ./manage.py makemigrations для создания новых миграций. Затем зафиксируйте эти миграции и отправьте их в Heroku.

Отлично, чувак! Спасибо еще раз за помощь!

Matheus Sant'ana 05.12.2018 18:14

После этого я получаю эту ошибку: столбец Clientes_productlist.id_new не существует. СТРОКА 1: ВЫБЕРИТЕ «Список клиентов_продукта». «Id_new», «Clientes_productlis ... У вас есть какие-нибудь подсказки по этому поводу?

Matheus Sant'ana 05.12.2018 18:51

Я предполагаю, что у Clientes есть FK для ProductList. Таким образом, у него была миграция, которая была связана с миграциями ProductList или зависела от них. Поскольку миграции ProductList были созданы позже, возникла проблема. Возможно, будет лучше, если вы удалите все файлы миграции из проекта (кроме файлов __init__.py внутри каталога миграции), запустите makemigrations и зафиксируйте их. также сбросьте БД в героку, прежде чем выполнять миграции и запускать их в героку. Возможно этот документ поможет сбросить db: gist.github.com/zulhfreelancer/ea140d8ef9292fa9165e

ruddra 05.12.2018 19:20

Теперь у меня появляется эта ошибка, когда я пытаюсь получить доступ к любой странице: отношение "django_session" не существует СТРОКА 1: ... ession_data "," django_session "." Expire_date "FROM" django_se ...

Matheus Sant'ana 05.12.2018 19:45

Неважно, я просто удалил всю базу данных в Heroku и отодвинул назад. Сейчас все нормально!

Matheus Sant'ana 05.12.2018 20:03

Другие вопросы по теме