Объект «NoneType» не имеет атрибута «владелец» при попытке доступа к отношениям

Я пытаюсь загрузить значение отношения Toy.owner. Это мои модели:

class User(db.Model):
    __tablename__ = 'User'
    id = db.Column(db.Integer, primary_key=True)
    type = db.Column(db.String(50))
    nickname = db.Column(db.String(255))
    email = db.Column(db.String(255))
    password = db.Column(db.String(255))

    __mapper_args__ = {
        "polymorphic_on":type,
        'polymorphic_identity':'user',
        'with_polymorphic':'*'
    }

class Owner(User):
    __tablename__ = 'Owner'
    id = db.Column(db.Integer, db.ForeignKey('User.id', ondelete='CASCADE'), primary_key=True)
    owner_id = db.Column(db.Integer, autoincrement=True, primary_key=True, unique=True)  
    toys = db.relationship('Toy', backref='owner', lazy='dynamic')

    __mapper_args__ = {'polymorphic_identity':'owner'}

class Toy(db.Model):
    __tablename__ = 'Toy'
    id = db.Column(db.Integer, primary_key=True)
    owner_id = db.Column(db.Integer, db.ForeignKey('Owner.owner_id'))

Это представление должно использовать clicked_toy.owner_id:

@app.route('/<path:toy_id>', methods=['GET','POST'])
def toy_info(toy_id):
    clicked_toy = db.session.query(Toy).filter(Toy.id == toy_id).first()
    owner = db.session.query(Owner).filter(Owner.owner_id == clicked_toy.owner.owner_id).first()
    return render_template('toy_info.html', clicked_toy=clicked_toy, owner=owner)

Это не работает, я получил ошибку:

File ".../controller.py", line 67, in toy_info
owner = db.session.query(Owner).filter(Owner.owner_id == clicked_toy.owner.owner_id).first()
AttributeError: 'NoneType' object has no attribute 'owner'

Когда я попытался вместо этого вызвать clicked_toy.owner_id, я получил ту же ошибку:

 File ".../controller.py", line 67, in toy_info
 owner = db.session.query(Owner).filter(Owner.owner_id == clicked_toy.owner_id).first()
 AttributeError: 'NoneType' object has no attribute 'owner_id'

Что мне не хватает и как я могу это исправить?


person DE.G    schedule 30.01.2015    source источник


Ответы (1)


.first() возвращает None, если результатов не было. Таким образом, ваш запрос для clicked_toy не дал результатов.

Вы можете использовать get вместо filter, когда все, что вы делаете, это фильтрация по первичному ключу. Flask-SQLAlchemy делает еще один шаг вперед, позволяя вам поднять 404, если нет результата.

clicked_toy = Toy.query.get_or_404(toy_id)
person davidism    schedule 30.01.2015