Как разрешить ошибку - "django.db.utils.ProgrammingError"
'
File "<frozen importlib._bootstrap>", line 1006, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 688, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 883, in exec_module
File "<frozen importlib._bootstrap>", line 241, in _call_with_frames_removed
File "/Users/mihirshah/Desktop/api/create_area_api/urls.py", line 3, in <module>
from create_area_api.views import api_create_area
File "/Users/mihirshah/Desktop/api/create_area_api/views.py", line 7, in <module>
class api_create_area(viewsets.ModelViewSet):
File "/Users/mihirshah/Desktop/api/create_area_api/views.py", line 10, in api_create_area
print(queryset.get())
File "/usr/local/lib/python3.10/site-packages/django/db/models/query.py", line 646, in get
num = len(clone)
File "/usr/local/lib/python3.10/site-packages/django/db/models/query.py", line 376, in __len__
self._fetch_all()
File "/usr/local/lib/python3.10/site-packages/django/db/models/query.py", line 1866, in _fetch_all
self._result_cache = list(self._iterable_class(self))
File "/usr/local/lib/python3.10/site-packages/django/db/models/query.py", line 87, in __iter__
results = compiler.execute_sql(
File "/usr/local/lib/python3.10/site-packages/django/db/models/sql/compiler.py", line 1398, in execute_sql
cursor.execute(sql, params)
File "/usr/local/lib/python3.10/site-packages/django/db/backends/utils.py", line 103, in execute
return super().execute(sql, params)
File "/usr/local/lib/python3.10/site-packages/django/db/backends/utils.py", line 67, in execute
return self._execute_with_wrappers(
File "/usr/local/lib/python3.10/site-packages/django/db/backends/utils.py", line 80, in _execute_with_wrappers
return executor(sql, params, many, context)
File "/usr/local/lib/python3.10/site-packages/django/db/backends/utils.py", line 84, in _execute
with self.db.wrap_database_errors:
File "/usr/local/lib/python3.10/site-packages/django/db/utils.py", line 91, in __exit__
raise dj_exc_value.with_traceback(traceback) from exc_value
File "/usr/local/lib/python3.10/site-packages/django/db/backends/utils.py", line 89, in _execute
return self.cursor.execute(sql, params)
django.db.utils.ProgrammingError: relation "accounts_project" does not exist
LINE 1: ...."start_date", "accounts_project"."end_date" FROM "accounts_...
`
Я набрал cmd - "python3 manage.py makemigrations" и столкнулся с вышеупомянутой ошибкой,
- Я попробовал несколько команд и попробовал обновить базу данных, изменив ее,
- Удалил все .pyc в папке migrations и pycache, но все равно получаю ту же проблему.
python3 manage.py makemigrations
Если вы работаете над новым проектом, без данных в базе данных. Вы можете просто удалить все py файлы (а не только pyc файлы) и снова использовать makemigrations
Проблема заключается в строке 10 в api/create_area_api/views.py
, где вы делаете print(queryset.get())
.
Поскольку эта строка не находится в методе, она выполняется при загрузке модуля. Если таблица не существует, это приводит к ошибке, что останавливает выполнение makemigrations и migrate.
Если вы удалите строку print, то, надеюсь, makemigrations запустится.
Если вы удалили файлы .py в папке migrations вместе с файлами .pyc, то ваши миграции и база данных могут быть рассинхронизированы. Это может быть очень трудно исправить.