【发布时间】: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