【问题标题】:Could not determine join condition with many-to-many join Sqlalchemy无法使用多对多连接 Sqlalchemy 确定连接条件
【发布时间】:2017-08-18 20:46:14
【问题描述】:

我在 SQLAlchemy 中收到以下错误:

无法确定父/子表之间的连接条件 关系 Membership.user - 没有链接这些的外键 表。确保引用列与 ForeignKey 或 ForeignKeyConstraint,或指定一个 'primaryjoin' 表达。

我正在尝试在用户表和事件表之间创建多对多关系。目标是将用户添加为事件的“成员”。该事件也由一个用户“拥有”,但这是一种不同的一对多关系。

class Membership(db.Model):
    __tablename__ = 'event_membership'

    id = db.Column(db.Integer, primary_key = True, unique=True)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), primary_key=True),
    event_id = db.Column(db.Integer, db.ForeignKey('event.id'), primary_key=True),
    time_created = db.Column(db.DateTime,nullable = False, default = func.now())

    user = db.relationship("Event",back_populates="memberships",foreign_keys=[])
    event = db.relationship("User",back_populates="members")


class User(db.Model,UserMixin):
    __tablename__ = 'user'
    id = db.Column(db.Integer(),primary_key =True)
    firstname = db.Column(db.String(50))
    lastname = db.Column(db.String(50))
    password = db.Column(db.String(255))
    username = db.Column(db.String(50), index = True)
    email = db.Column(db.String(255), index = True)
    create_date = db.Column(db.DateTime())
    questions = db.relationship('Question',backref='user',lazy='dynamic')
    events = db.relationship('Event',backref='owner',lazy='dynamic')
    admin = db.Column(db.Boolean,nullable=False,default=False)
    #moderating_events = db.Column(db.Integer(),db.ForeignKey('event.id'))
    authenticated = db.Column(db.Boolean,nullable=False,default=False)
    lastseen = db.Column(db.DateTime)
    validated = db.Column(db.Boolean,nullable=False,default=False)

    memberships = db.relationship("Membership", back_populates= "user" )

class Event(db.Model):
    __tablename__ = 'event'
    id = db.Column(db.Integer(),primary_key = True)
    name = db.Column(db.String(255))
    event_code = db.Column(db.String(30))
    description = db.Column(db.Text())
    owner_id = db.Column(db.Integer(),db.ForeignKey('user.id'))
    #owner = db.relationship("User",back_populates="events")
    questions = db.relationship('Question',backref='event',lazy='dynamic')
    create_date = db.Column(db.DateTime())
    active_date = db.Column(db.DateTime())
    active = db.Column(db.Boolean())
    meeting_time = db.Column(db.DateTime())
    #moderators = db.relationship('User', backref='event_moderator',lazy='dynamic')
    moderate_questions = db.Column(db.Boolean,nullable=False,default=True)
    allow_anonymous = db.Column(db.Boolean,nullable=False,default=True)

    members = db.relationship("Membership", back_populates="event")

【问题讨论】:

    标签: python sqlalchemy flask-sqlalchemy


    【解决方案1】:

    这个错误对我来说并不陌生!我在 2 个月前面对它,我以这种方式解决了多对多关系 您将不得不编辑您的关联表“会员”。 然后你可以将它作为用户关系的次要参数传递

    试试这个代码:

    Membership =db.Table(
    'Membership',
    db.Column('User_id',db.Integer,db.ForeignKey('User.id')),
    db.Column('Event_id', db.Integer, db.ForeignKey('Event.id')),
    

    并在用户表中添加:

     Events = relationship("Event",
                    secondary=Membership)
    

    在 SqlALchemy 的官方文档中找到更多here

    【讨论】:

    • 这可行,但我需要能够向关系表添加一个字段。使其成为关联对象而不仅仅是表。
    • 您可以像在上一个表中一样在关联表中添加一个字段...例如一个可以正常工作的日期
    • 或者您可以在关系属性中添加 backref 参数以便能够将其用作对象
    猜你喜欢
    • 2017-07-16
    • 2020-12-27
    • 1970-01-01
    • 2012-10-20
    • 2021-04-03
    • 2014-05-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多