Flask与SqlAlchemy - alembic session.add_all()导致AttributeError: 'bool'对象没有'clear'属性错误
我正在尝试在部署时插入一些数据。我创建了以下的 alembic 版本脚本:
revision = '59891ffc8502'
down_revision = '349540cf9cef'
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import mysql
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker, relationship
Session = sessionmaker()
Base = declarative_base()
class Colours(Base):
__tablename__ = 'colours'
id = sa.Column(sa.Integer, primary_key=True)
name = sa.Column('name', sa.Unicode(length=25), nullable=False)
code = sa.Column('code', sa.Unicode(length=2), nullable=False)
def upgrade():
bind = op.get_bind()
session = Session(bind=bind)
session._model_changes = False
op.alter_column('colours', 'code', new_column_name='code', existing_type=mysql.VARCHAR(length=25))
col = [
{ "name": "Black", "code": "ff00cc" },
{ "name": "Blue", "code": "ff00cc" },
{ "name": "Brown", "code": "ff00cc" },
{ "name": "Gold", "code": "ff00cc" },
{ "name": "Green", "code": "ff00cc" }
]
# populate colours table
colours = { c['name']: Colours(name=unicode(c['name']), code=c['code']) for c in col}
session.add_all(colours.values())
session.commit()
# ### end Alembic commands ###
但是,当我运行升级命令时,出现了一个错误,提示 AttributeError: 'bool' object has no attribute 'clear'。有人知道这是怎么回事吗?
1 个回答
1
结果发现,设置 session._model_changes = False
并不能完全解决 Flask-SQLAlchemy 的问题。你需要彻底取消它注册的事件处理器。
from flask_sqlalchemy import _SessionSignalEvents
from sqlalchemy import event
from sqlalchemy.orm import Session as BaseSession
Session = sessionmaker()
event.remove(BaseSession, 'before_commit', _SessionSignalEvents.session_signal_before_commit)
event.remove(BaseSession, 'after_commit', _SessionSignalEvents.session_signal_after_commit)
event.remove(BaseSession, 'after_rollback', _SessionSignalEvents.session_signal_after_rollback)