【问题标题】:SQLAlchemy relationship with association_proxy problemsSQLAlchemy 与关联代理问题的关系
【发布时间】:2013-04-18 06:08:52
【问题描述】:

我一直在浏览许多网站以试图了解发生了什么,但我真的需要一些直接的帮助。如果我错过了文档中明显的内容,我深表歉意。

这就是我想要做的(除了基本代码,我已经删掉了所有内容):

Base = declarative_base()

class User(Base):
    __tablename__ = 'user'
    login = Column(String(60), primary_key=True, nullable=False)

    groups = association_proxy('user_to_groups', 'group', creator=lambda group: UserToGroup(group_name=group.name))

    def __init__(self, login, groups=None):
        self.login = login
        if groups:
            for group in groups:
                self.groups.append(group)


class Group(Base):
    __tablename__ = 'group'
    name = Column(String(100), primary_key=True, nullable=False)
    description = Column(String(100), nullable=True)

    users = association_proxy('group_to_user', 'user', creator=lambda user: UserToGroup(user_login=user.login))

    def __eq__(self, other):
        return self.name == other.name


class UserToGroup(Base):
    __tablename__ = 'user_to_group'
    user_login = Column(String(60), ForeignKey(User.login), primary_key=true)
    group_name = Column(String(100), ForeignKey(Group.name), primary_key=true)

    user = relationship(User, backref='user_to_groups', cascade='all') #, cascade="all, delete"  #, delete-orphan ?
    group = relationship(Group, backref='group_to_user', cascade='all') #, cascade="all, delete"  #, delete-orphan ?


group1 = Group(name ="g:superadmin")
group2 = Group(name ="g:admin")
session.add_all([group1, group2])
session.flush()
user1 = User(login = "test", groups=[group1, group2])
session.add(user1)
session.flush()


user1 = session.query(User).filter(User.login=='test').one()
print(user1.user_to_groups)
print(type(user1.groups), dir(user1.groups))
user1.groups.remove(Group(name='g:admin'))

这是尝试运行user1.groups.remove(Group(name='g:admin')) 后的响应回溯:

AssertionError: 依赖规则试图清除实例“”上的主键列“user_to_group.user_login”

我想要它做的只是删除user_to_group 表中的行并相应地更新对象以反映更改。

在关系表未映射到对象but I need it to be mapped to an object to use inheritance 之前,我已经让它工作了

【问题讨论】:

    标签: python sqlalchemy


    【解决方案1】:

    级联从拥有父对象到被删除的子对象,因此 User.user_to_groups、Group.group_to_user:

    class UserToGroup(Base):
        __tablename__ = 'user_to_group'
        user_login = Column(String(60), ForeignKey(User.login), primary_key=True)
        group_name = Column(String(100), ForeignKey(Group.name), primary_key=True)
    
        user = relationship(User, backref=backref('user_to_groups', cascade='all, delete-orphan'))
        group = relationship(Group, backref=backref('group_to_user', cascade='all, delete-orphan'))
    

    【讨论】:

    • 谢谢!有时我在浏览文档时感觉自己快要淹死了。不过,我不认为你可以做些什么来让它变得更好,这只是一个包含很多细节的话题。
    猜你喜欢
    • 2018-11-24
    • 1970-01-01
    • 2017-11-22
    • 2013-08-27
    • 1970-01-01
    • 1970-01-01
    • 2015-01-21
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多