방금 South을 추가 한 기존 Django 프로젝트가 있습니다.Django와 Heroku에서 South를 사용하는 데 문제가 있습니다.
- 로컬로 syncdb를 실행했습니다.
- 나는 내가 커밋 로컬
- 을
manage.py migrate app_name --fake
를 실행 - 로컬
manage.py schemamigration app_name
를 실행하고 나는 내가 Heroku가 에
- 에게 Heroku에
manage.py schemamigration app_name
를 실행 - 에게 Heroku에 syncdb 달렸다
- Heroku가 마스터에 밀려
manage.py migrate app_name
를 실행
다음 메시지가 나타납니다.
$ heroku run python notecard/manage.py migrate notecards
Running python notecard/manage.py migrate notecards attached to terminal... up, run.1
Running migrations for notecards:
- Migrating forwards to 0005_initial.
> notecards:0003_initial
Traceback (most recent call last):
File "notecard/manage.py", line 14, in <module>
execute_manager(settings)
File "/app/lib/python2.7/site-packages/django/core/management/__init__.py", line 438, in execute_manager
utility.execute()
File "/app/lib/python2.7/site-packages/django/core/management/__init__.py", line 379, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/app/lib/python2.7/site-packages/django/core/management/base.py", line 191, in run_from_argv
self.execute(*args, **options.__dict__)
File "/app/lib/python2.7/site-packages/django/core/management/base.py", line 220, in execute
output = self.handle(*args, **options)
File "/app/lib/python2.7/site-packages/south/management/commands/migrate.py", line 105, in handle
ignore_ghosts = ignore_ghosts,
File "/app/lib/python2.7/site-packages/south/migration/__init__.py", line 191, in migrate_app
success = migrator.migrate_many(target, workplan, database)
File "/app/lib/python2.7/site-packages/south/migration/migrators.py", line 221, in migrate_many
result = migrator.__class__.migrate_many(migrator, target, migrations, database)
File "/app/lib/python2.7/site-packages/south/migration/migrators.py", line 292, in migrate_many
result = self.migrate(migration, database)
File "/app/lib/python2.7/site-packages/south/migration/migrators.py", line 125, in migrate
result = self.run(migration)
File "/app/lib/python2.7/site-packages/south/migration/migrators.py", line 99, in run
return self.run_migration(migration)
File "/app/lib/python2.7/site-packages/south/migration/migrators.py", line 81, in run_migration
migration_function()
File "/app/lib/python2.7/site-packages/south/migration/migrators.py", line 57, in <lambda>
return (lambda: direction(orm))
File "/app/notecard/notecards/migrations/0003_initial.py", line 15, in forwards
('user', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['auth.User'])),
File "/app/lib/python2.7/site-packages/south/db/generic.py", line 226, in create_table
', '.join([col for col in columns if col]),
File "/app/lib/python2.7/site-packages/south/db/generic.py", line 150, in execute
cursor.execute(sql, params)
File "/app/lib/python2.7/site-packages/django/db/backends/util.py", line 34, in execute
return self.cursor.execute(sql, params)
File "/app/lib/python2.7/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 44, in execute
return self.cursor.execute(query, args)
django.db.utils.DatabaseError: relation "notecards_semester" already exists
세 가지 모델이 있습니다. 섹션, 학기 및 노트 카드. Notecards 모델에 하나의 필드를 추가했는데 Heroku에서 추가 할 수 없습니다.
감사합니다.
저는 manage.py migrate app_name 0005 --fake heroku를 실행합니다. 그리고 manage.py migrate app_name을 실행하면'Nothing to migrate '라는 메시지가 나타납니다. app_name의 초기 데이터로드 중. 비품이 발견되지 않았습니다. ' –
네, 마이그레이션이 완전히 엉망이되었습니다. 마이그레이션 전부터 시작하여 dev 및 prod에 대해 수행 한 작업의 전체적인 내역을 보유하지 않으면 도움이 될 수 없을 것입니다. 세부 사항이 필요합니다. 그들 중 많은 것들. 작성한 모든 코드를 작성한 다음 수정 한 모든 사항, 실행 한 모든 마이그레이션 명령 및 시스템을 입력하십시오. 전체리스트. –
감사합니다. 나는 이것을 할 수있다. 한 가지 더 쉽게 작업 할 수있는 방법은 ... 코드의 모델을 한 번 변경하면됩니다. 단일 필드에 단일 모델을 추가했습니다. 나는이 필드를 쉽게 제거하고 사우스 캐롤라이나 이전 데이터베이스의 원래 상태로 돌아갈 수있었습니다. 이렇게하면 마이그레이션 폴더를 삭제하고 다시 시작할 수 있습니까 - 올바른 방법입니까?그렇지 않다면 최대한 많은 정보를 수집 할 것입니다. 감사! –