gpt4 book ai didi

python - Flask-SQLAlchemy关联表

转载 作者:太空宇宙 更新时间:2023-11-03 21:19:49 26 4
gpt4 key购买 nike

我使用 Flask 并使用 Flask-SQLAlchemy for ORM 制作了一个学费支付应用程序。

我有一个User 表,我使用该表来登录学校帐户和家长帐户。虽然学生数据我将其存储在表 Student 中,但学生没有登录帐户。

我想问的是,如何将Student表与SCOOL_IDPARENT_ID建立关系..?而家长账户和学校账户在同一个表中,即User表。

一名学生有一名家长,一名学生有一所学校。

我是否必须将学校和家长之间的 table 分开......?

到目前为止,我已经用 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')

那么,如何做到这一点..?,任何帮助将不胜感激。

最佳答案

我已经知道我的问题的概念,我必须创建一个表SchoolParent并从表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'))

关于python - Flask-SQLAlchemy关联表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54385077/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com