Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/329.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 烧瓶及;SqlAlchemy-alembic session.add#all()结果为AttributeError:';布尔';对象没有属性';清除';错误_Python_Flask_Sqlalchemy_Flask Sqlalchemy_Alembic - Fatal编程技术网

Python 烧瓶及;SqlAlchemy-alembic session.add#all()结果为AttributeError:';布尔';对象没有属性';清除';错误

Python 烧瓶及;SqlAlchemy-alembic session.add#all()结果为AttributeError:';布尔';对象没有属性';清除';错误,python,flask,sqlalchemy,flask-sqlalchemy,alembic,Python,Flask,Sqlalchemy,Flask Sqlalchemy,Alembic,我正在尝试插入一些数据作为部署的一部分。我创建了以下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 sqlalche

我正在尝试插入一些数据作为部署的一部分。我创建了以下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”对象没有属性“clear”错误。
有什么线索吗?

结果是,设置
会话。\u model\u changes=False
对炼金术的关注不够。您需要完全注销它注册的事件处理程序

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)

你以前吃过吗?