2016-08-29 10 views
2

テーブルの1つの列の型がIntegerからStringに変更されました。Alembic Alembic列の変更によって構文エラーが発生する

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

この列には、今、私は移行スクリプトを自動生成するアレンビックを使用しています文字列に

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

を変更しました。型の変更を検出するために、env.pyでcompare_type = Trueを指定しました。

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 ### 

は、しかし、私はupgradeコマンドを実行したときに、私は(ここではトレースバックの端部である)構文エラーを取得する:どのような多分問題

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

私は、次の構文を用いて解決同様の問題だった:StringはSQLタイプではないので、基本的に、私は型宣言の後に括弧を省略し、downgradeに私はタイプVARCHARを使用

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 ### 

を。

関連する問題