Flask - Flask-Admin - One-To-Many - Cascade

Обновить

November 2018

Просмотры

3.2k раз

4

В настоящее время я начинаю проект с Колбой. Я в настоящее время переживает колбовую Admin.

Я пытаюсь установить связь с 2-х уровнях. Для каждого «Кандидат» Я хотел бы связать язык и уровень (уровень этого языка) для этого языка.

Вот мой models.py

from app import db

class Candidat(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    firstname = db.Column(db.String(128))
    lastname = db.Column(db.String(128))
    birthdate = db.Column(db.DateTime)
    languages = db.relationship("CandidatLanguage", backref="candidat")

    def __repr__(self):
        return '<Nom %r>' % self.lastname


class Language(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(128))

    def __repr__(self):
        return '<Langues %r>' % self.name

class Languagelevel(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(128))

    def __repr__(self):
        return '<Niveau : %r>' % self.name

class CandidatLanguage(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    candidat_id = db.Column(db.Integer, db.ForeignKey('candidat.id'))
    language_id = db.Column(db.Integer, db.ForeignKey('language.id'))
    langguage_level_id = db.Column(db.Integer, db.ForeignKey('languagelevel.id'))

Вот мой views.py

from models import Candidat, Languagelevel, Language, CandidatLanguage

from flask.ext.admin import Admin, BaseView, expose
class MyView(BaseView):
    @expose('/')
    def index(self):
        return self.render('adm-index.html')

admin = Admin(app)
admin.add_view(MyView(name='Hello'))

from flask.ext.admin.contrib.sqla import ModelView

admin.add_view(ModelView(Candidat, db.session))
admin.add_view(ModelView(CandidatLanguage, db.session))
admin.add_view(ModelView(Language, db.session))
admin.add_view(ModelView(Languagelevel, db.session))

То, что я хотел бы иметь это форма Кандидат которым выглядит следующим образом:

Имя: _ __ _

Lastname: _ __ _ _

Язык:

  • DropDown для языка:

    • Язык 1
    • Язык 2
  • Выпадающий уровень этого языка:

    • 1-й уровень
    • Уровень 2

За один «кандидатом», один язык может быть связан только с одним уровнем этого языка.

Я попробовал column_auto_select_related, column_display_all_relationsи, конечно , ни один из них не работает , как я думал. Конечно , это моя ошибка.

Если кто-то может показать мне правильный путь для достижения своей цели, было бы очень полезно.

Заранее спасибо.

С уважением

1 ответы

3

Наконец, я нашел свое решение в следующем посте

Мои ошибки были:

  • положить db.relationship(CandidatLanguage) в моем Candidat классе. Вместо этого, я поставил отношения в моей «сводной» таблицы (CandidatLanguage).
  • как сказал IfLoop в должности, я должен «переключиться с обычного многие-ко-многим с„Объект Ассоциации“. Я не„“понял почему, но это работает, используя объект ассоциации.

Тогда мой models.py теперь выглядит следующим образом:

class Candidat(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    firstname = db.Column(db.String(128))
    lastname = db.Column(db.String(128))
    birthdate = db.Column(db.Date)
    categories = db.relationship('Category', secondary=category_candidat,
                                 backref=db.backref('candidat', lazy='dynamic'))

    def __repr__(self):
        return '<Nom %r>' % self.lastname


class Language(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(128))

    def __repr__(self):
        return '%s' % unicode(self.name)


class Languagelevel(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(128))

    def __repr__(self):
        return '%s' % self.name

class CandidatLanguage(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    candidat_id = db.Column(db.Integer, db.ForeignKey('candidat.id'))
    language_id = db.Column(db.Integer, db.ForeignKey('language.id'))
    language_level_id = db.Column(db.Integer, db.ForeignKey('languagelevel.id'))

    language = db.relationship(Language, backref="Candidat")
    candidat = db.relationship(Candidat, backref="Langue")
    languagelevel = db.relationship(Languagelevel, backref="Candidat")

И мой views.py так:

from flask.ext.admin import Admin, BaseView, expose
class MyView(BaseView):
    @expose('/')
    def index(self):
        return self.render('adm-index.html')

admin = Admin(app)
admin.add_view(MyView(name='Hello'))

from flask.ext.admin.contrib.sqla import ModelView

class CandidatView(ModelView):
    column_auto_select_related = True
    inline_models = (CandidatLanguage,)

admin.add_view(CandidatView(Candidat, db.session))
admin.add_view(ModelView(Language, db.session))
admin.add_view(ModelView(Languagelevel, db.session))

При том, что все работает нормально и у меня есть встроенный вид, как я хочу.

Я не все понял, но это работает. если кто-нибудь может объяснить, что это из coruse прием.

С уважением