У меня есть следующие таблицы таблиц:
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.Что происходит?