2016-08-29 2 views
2

В столбце одной из таблиц от Integer до String произошел сбой.Изменение типа столбца Alembic дает синтаксическую ошибку

Logic(PBase): 
__tablename__ = "logic" 
Id(Integer, primary_key=True) 

этот столбец изменен на строку

Logic(PBase): 
__tablename__ = "logic" 
Id(String, primary_key=True) 

Теперь я использую перегонный куб для автоматического создания сценария миграции. Для того, чтобы обнаружить изменения типа, я снабдил compare_type = True в env.py

with connectable.connect() as connection: 
    context.configure(
     connection=connection, 
     target_metadata=target_metadata, 
     compare_type=True 
    ) 

Поступая таким образом, сценарий миграции генерируется штрафом. Вот содержание сгенерированной миграции сценария:

from alembic import op  # noqa 
import sqlalchemy as sa  # noqa 


def upgrade(): 
    ### commands auto generated by Alembic - please adjust! ### 
    op.alter_column('logics', 'id', 
        existing_type=sa.INTEGER(), 
        type_=sa.String()) 
    ### end Alembic commands ### 


def downgrade(): 
    ### commands auto generated by Alembic - please adjust! ### 
    op.alter_column('logics', 'id', 
        existing_type=sa.String(), 
        type_=sa.INTEGER()) 
    ### end Alembic commands ### 

Но когда я запускаю команду обновления я получаю ошибку синтаксиса (здесь концевая часть TRACEBACK):

File "/Users/amit/.virtualenvs/be_new/lib/python2.7/site-packages/sqlalchemy/engine/default.py", line 436, in do_execute cursor.execute(statement, parameters) sqlalchemy.exc.OperationalError: (OperationalError) near "ALTER": syntax error u'ALTER TABLE logics ALTER COLUMN id TYPE VARCHAR'()

Что может быть проблема Вот?

+0

Эй, @amrx Я добавил несколько поздний ответ, посмотрите! –

ответ

0

У меня была аналогичная проблема, которую я решена с помощью следующего синтаксиса:

def upgrade(): 
    ### commands auto generated by Alembic - please adjust! ### 
    op.alter_column('logics', 'id', type_=sa.String, existing_type=sa.INTEGER) 
    ### end Alembic commands ### 


def downgrade(): 
    ### commands auto generated by Alembic - please adjust! ### 
    op.alter_column('logics', 'id', type_=sa.INTEGER, existing_type=sa.VARCHAR) 
    ### end Alembic commands ### 

По существу я опущена скобки после заявлений типа и на downgrade я использовал тип VARCHAR потому, что String не является типом данных SQL.

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