0

我在我的 Flask 项目中添加了一种“迁移”功能。最初,我想添加与以下多对多相关的用户和角色:

users_to_roles_association_table = db.Table('users_to_roles',
    db.Column('user_id', db.Integer, db.ForeignKey('users.id')),
    db.Column('role_id', db.Integer, db.ForeignKey('roles.id')))

class User(db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer, db.Sequence('user_id_seq'), primary_key=True)
    ..................
    roles = relationship('Role', secondary=users_to_roles_association_table, lazy='dynamic')

class Role(db.Model):
    __tablename__ = 'roles'
    id = db.Column(db.Integer, db.Sequence('role_id_seq'), primary_key=True)
    rolename = db.Column(db.String(128), unique=False)
    ..................

这是我的迁移up方法:

def up(self):
  try:
    user = User.query.filter_by(nickname='alp').first()

    if not user:
      user = User(email='some@email.com', nickname='admin', status=USER.Active)
      password = raw_input("Input password for user %s: " % user.nickname)
      user.set_password(password)
      db.session.add(user)

    role = Role.query.filter_by(rolename='Admin').first()
    if not role:
      role = Role(rolename='Admin')
      db.session.add(role)  //HERE

    if not user.is_in_role('Admin'):
      user.roles.append(role)


  except Exception, e:
    print "Rolling back changes"
    db.session.rollback()
    raise

当我运行它时,我遇到了一个例外:sqlalchemy.exc.InvalidRequestError: Object '<Role at 0x331db50>' is already attached to session '3' (this is '2') 如果我注释掉行db.session.add(role)错误消失了Role,但不会添加到数据库中。

我需要这个逻辑,因为其他一些记录可能在表中,所以我不能保证数据库中不存在特定角色。

如何处理这个错误?

4

1 回答 1

0

我找到了解决方案。由于对内部 Flask 架构的了解不足,我似乎踩到了耙子。

在我的迁移文件(我使用Flask-Evolution)的顶部有几行:

db = SQLAlchemy(current_app)
db.metadata.bind = main.db.engine

我使用这个变量db来操作我的记录,但是由于未知的原因,它有自己的会话与我的不同(我在main.py:中定义了我自己的数据库处理程序db = SQLAlchemy(app) )。当我db.session....main.db.session...all 替换行时,一切正常。如果有人能解释这种情况,我会很高兴。

于 2013-05-20T09:31:02.670 回答