AttributeError: у объекта «InstrumentedList» нет атрибута - PullRequest
8 голосов
/ 06 октября 2011

У меня есть следующие таблицы таблиц:

class Thing(Base):
    __tablename__ = 'thing'
    id = Column(Integer, primary_key=True)

class User(Base):
    __tablename__ = 'user'
    id = Column(Integer, primary_key=True)

class Voteinfo(Base):
    __tablename__ = 'voteinfo'
    thing_id = Column(Integer, ForeignKey('thing.id'), primary_key=True)
    thing = relationship('Thing', backref='voteinfo')
    upvotes = Column(Integer)
    downvotes = Column(Integer)

    def __init__(self, thing)
        self.thing = thing

class VoteThing(Base):
    __tablename__ = 'votething'
    id = Column(Integer, primary_key=True)
    voter_id = Column(Integer, ForeignKey('voter.id'))
    voter = relationship('Voter', backref='votescast')
    thing_id = Column(Integer, ForeignKey('thing.id'))
    thing = relationship('Thing', backref='votesreceived')
    value = Column(Boolean)

    def __init__(self, voter, thing, value):
        if value is True:
            thing.voteinfo.upvotes += 1
        else:
            thing.voteinfo.downvotes += 1

Когда я пытаюсь запустить это, я получаю этот код ошибки в предложении «if value is True»:

AttributeError: 'InstrumentedList' object has no attribute 'upvotes'

IЯ пытался присвоить Voteinfo свой уникальный идентификатор и добавить uselist = False в отношения.Я пытался заменить отношение к вещам с VoteThing на Voteinfo, но это тоже не помогло.Я не знаю, что такое InstrumentedList.Что происходит?

1 Ответ

13 голосов
/ 06 октября 2011

Как объяснено в документации, здесь: https://docs.sqlalchemy.org/en/latest/orm/basic_relationships.html#one-to-one, вы должны добавить uselist = False не в отношение, а в обратную ссылку.

thing = relationship('Thing', backref=backref('voteinfo', uselist=False))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...