2017-01-06 4 views
0

Я пишу приложение django, которое в настоящее время развернуто на heroku. Последние миграции, которые я сделал, сделали ошибку, которую я не понимаю, см. Ниже. Эта ошибка не появляется локально, возможно, это потому, что я использую sqlite локально и postgres на heroku, но это только предположение. Я создал миграцию локально и нажал ее.Heroku: ошибка выполнения миграции django

Я использую django 1.10 и виртуальную среду с python 2.7.

Вот мой терминал Ouput, когда я пытаюсь запустить миграцию:

heroku run python manage.py migrate 
Running python manage.py migrate on ⬢ limitless-lake-59470... up, run.3202 (Free) 
Operations to perform: 
    Apply all migrations: admin, auth, contenttypes, jobs, sessions 
Running migrations: 
    Applying jobs.0015_auto_20161230_2039...Traceback (most recent call last): 
    File "manage.py", line 22, in <module> 
    execute_from_command_line(sys.argv) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/__init__.py", line 367, in execute_from_command_line 
    utility.execute() 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/__init__.py", line 359, in execute 
    self.fetch_command(subcommand).run_from_argv(self.argv) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/base.py", line 294, in run_from_argv 
    self.execute(*args, **cmd_options) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/base.py", line 345, in execute 
    output = self.handle(*args, **options) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/commands/migrate.py", line 204, in handle 
    fake_initial=fake_initial, 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/executor.py", line 115, in migrate 
    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/executor.py", line 145, in _migrate_all_forwards 
    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/executor.py", line 244, in apply_migration 
    state = migration.apply(state, schema_editor) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/migration.py", line 129, in apply 
    operation.database_forwards(self.app_label, schema_editor, old_state, project_state) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/operations/fields.py", line 204, in database_forwards 
    schema_editor.alter_field(from_model, from_field, to_field) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/base/schema.py", line 495, in alter_field 
    old_db_params, new_db_params, strict) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/postgresql/schema.py", line 117, in _alter_field 
    new_db_params, strict, 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/base/schema.py", line 649, in _alter_field 
    params, 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/base/schema.py", line 112, in execute 
    cursor.execute(sql, params) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/utils.py", line 79, in execute 
    return super(CursorDebugWrapper, self).execute(sql, params) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/utils.py", line 64, in execute 
    return self.cursor.execute(sql, params) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/utils.py", line 94, in __exit__ 
    six.reraise(dj_exc_type, dj_exc_value, traceback) 
    File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/utils.py", line 64, in execute 
    return self.cursor.execute(sql, params) 
django.db.utils.DataError: invalid input syntax for integer: "" 
+1

«, может быть, это потому, что я использую SQLite локально и postgres on heroku, но это только предположение ». скорее всего. sqlite не применяет типы. Postgresql делает. Пожалуйста, опубликуйте данный режим – e4c5

+0

Весь файл models.py довольно большой, и я не знаю, что вызывает проблемы. В любом случае **, я исправил это **, очистив весь db и применив миграцию с нуля. Не знаю, почему это помогло, но так оно и было. – nielsrolf

ответ

0

ошибка исчезала после очистки БД и применения всех миграций с нуля

Смежные вопросы