Я делаю приложение оплаты за обучение, используя Flask и Flask-SQLAlchemy для 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')
Итак,как это сделать? .. любая помощь будет высоко ценится.