2012-07-02 3 views
0

Я загружаю базу данных для своего приложения Django в Heroku, используя db:push, который преобразует мою базу данных из sqlite в postgres.Преобразование базы данных sqlite в postgres дает DatabaseError: слишком длинное значение для символа типа (50)

Однако в процессе я получаю ошибку:

Taps Server Error: PGError: ERROR: integer out of range

При попытке создать чистую базу данных на сервере Heroku, используя python manage.py syncdb, я получаю подобное сообщение:

Installing index for django_openid.UserOpenidAssociation model 
Installing json fixture 'initial_data' from '/app/.heroku/venv/lib/python2.7/site- packages/oembed/fixtures'. 
Installing json fixture 'initial_data' from '/app/.heroku/venv/lib/python2.7/site- packages/pinax/apps/photos/fixtures'. 
Installing json fixture 'initial_data' from '/app/store/fixtures'. 
Problem installing fixture '/app/store/fixtures/initial_data.json': Traceback (most recent call last): 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/core/management/commands/loaddata.py", line 169, in handle 
obj.save(using=using) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/core/serializers/base.py", line 165, in save 
models.Model.save_base(self.object, using=using, raw=True) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/db/models/base.py", line 501, in save_base 
rows = manager.using(using).filter(pk=pk_val)._update(values) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/db/models/query.py", line 491, in _update 
return query.get_compiler(self.db).execute_sql(None) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 861, in execute_sql 
cursor = super(SQLUpdateCompiler, self).execute_sql(result_type) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 727, in execute_sql 
cursor.execute(sql, params) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/db/backends/util.py", line 15, in execute 
return self.cursor.execute(sql, params) 
File "/app/.heroku/venv/lib/python2.7/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 44, in execute 
return self.cursor.execute(query, args) 
DatabaseError: value too long for type character varying(50) 

Мне кажется, что проблема заключается в исходных данных, но не совсем уверен. Я нашел здесь сообщение, в котором говорилось, что это может быть проблема с кодированием поля, но даже если я должен был изучить, что не совсем точно, как читать сообщение об ошибке, чтобы узнать, что именно вызывает проблему, а также определить, какая таблица/column может вызвать проблему.

+0

У вас есть DDL для вашей базы данных sqlite? как насчет базы данных postgresql? Не могли бы вы также опубликовать это? – swasheck

ответ

2

DatabaseError: value too long for type character varying(50) означает, что вы пытаетесь сохранить строку длиной более 50 символов в формате VARCHAR (50). Вы можете сорвать потенциальных кандидатов, просмотрев ваши модели для CharField s с max_length=50, или SlugField s (по умолчанию max_length=50). Затем просмотрите свои приборы initial_data.json и посмотрите, заметили ли вы какие-либо явно длинные строки, которые хранятся для любого из этих полей.

+0

Спасибо за этот совет ... Я точно определил проблему - но она не решила оригинальную ошибку сервера Taps: PGError: ERROR: целое вне диапазона во время нажатия. Я предполагаю, что это не связано, поэтому я опубликую отдельный вопрос. – user1328021

0

Как @ChrisPratt сказал, у меня была та же проблема, но не удалось выяснить проблему. У меня было только одно приложение в моем проекте, я удалил файлы * py в папке миграции приложения (за исключением init .py-файл) и очистил все таблицы в моем sqlite3 db (в то время у меня не было никаких важных данных) а затем выполнил команду migrate. Это сработало!.

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