テーブルの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'()
ここに?
ちょっと、@amrx少し遅い答えを追加しました。 –