我使用Flask和Flask-SQLAlchemy for ORM制作了一个学费支付应用程序。
我有一个User
表,我正在使用该表登录学校帐户和父母帐户。当我将学生数据存储在表Student
中时,学生没有登录帐户。
我要问的是如何将Student
表与SCOOL_ID
和PARENT_ID
建立关系。而父母帐户和学校帐户位于同一张表User
中。
一名学生有一名父母,一名学生有一所学校。
我必须在学校和家长之间分开桌子吗??
到目前为止,我已经使用Flask-SQLAlchemy做到了这一点,但是我不确定这样做是否很好。
class User(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(200))
email = db.Column(db.String(120), index=True, unique=True)
password = db.Column(db.String(255))
active = db.Column(db.Boolean())
created_at = db.Column(db.DateTime, default=datetime.utcnow())
updated_at = db.Column(db.DateTime, default=datetime.utcnow())
association_roles = db.Table('association_roles',
db.Column('parent_id', db.Integer, db.ForeignKey('user.id')),
db.Column('school_id', db.Integer, db.ForeignKey('user.id'))
)
class Student(db.Model):
id = db.Column(db.Integer, primary_key=True)
student_registration_number = db.Column(db.String(120), index=True, unique=True)
name = db.Column(db.String(100))
major = db.Column(db.String(50))
created_at = db.Column(db.DateTime, default=datetime.utcnow())
updated_at = db.Column(db.DateTime, default=datetime.utcnow())
association_roles = db.relationship(
'Student', secondary=association_roles,
primaryjoin=(association_roles.c.parent_id == id),
secondaryjoin=(association_roles.c.school_id == id),
backref=db.backref('student', lazy='dynamic'), lazy='dynamic')
那么,该怎么做..?,任何帮助将不胜感激。
答案 0 :(得分:0)
我已经知道问题的概念,我必须创建一个表学校和父母,并从表 User 继承它是代码段:
class User(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(200))
roles = db.relationship('Role', secondary=roles_users,
default='parent',
backref=db.backref('users', lazy='dynamic'))
__mapper_args__ = {
'polymorphic_identity': 'user',
'with_polymorphic': '*'
}
class Parent(User):
id = db.Column(db.Integer, primary_key=True)
user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
school_id = db.Column(db.Integer, db.ForeignKey('school.id'))
__mapper_args__ = {
'polymorphic_identity': 'parent',
'with_polymorphic': '*'
}
class School(User):
id = db.Column(db.Integer, primary_key=True)
user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
__mapper_args__ = {
'polymorphic_identity': 'school',
'with_polymorphic': '*'
}
class Student(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(100))
school_id = db.Column(db.Integer, db.ForeignKey('school.id'))
parent_id = db.Column(db.Integer, db.ForeignKey('parent.id'))
parent = db.relationship('Parent', backref=db.backref('Student', lazy='dynamic'))