Таблица связи Flask-SQLAlchemy - PullRequest
0 голосов
/ 27 января 2019

Я делаю приложение оплаты за обучение, используя 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')

Итак,как это сделать? .. любая помощь будет высоко ценится.

1 Ответ

0 голосов
/ 28 января 2019

Я уже знаю концепцию своего вопроса, я должен составить таблицу Школа и Родитель и унаследовать ее от таблицы Пользователь , здесь приведен фрагменткод:

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'))
...