python sqlalchemy AttributeError: у объекта 'BaseQuery' нет атрибута 'id' - PullRequest
0 голосов
/ 10 октября 2019

Я пытаюсь установить столбец foreign_key таблицы, используя данные из другой таблицы 'Nutritional Values'

class NutritionalValues(db.Model):
    __tablename__ = 'nutritionalvalues'
    id = db.Column(db.Integer, primary_key=True)
    item = db.Column(db.String(200), nullable=False)
    calories = db.Column(db.Float, nullable=False)
    totalfat = db.Column(db.Float, nullable=False)

, используя

consumed_nutrionalvalue_id = NutritionalValues.query.filter_by(item=consumed_item).id

, где 'потребляется_item'некоторая строка, которая точно совпадает со строкой значения 'item' для одной строки таблицы NutritionalValues ​​

, но я получаю ошибку

AttributeError: 'BaseQuery' object has no attribute 'id'

Traceback (most recent call last)
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 2463, in __call__
return self.wsgi_app(environ, start_response)
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 2449, in wsgi_app
response = self.handle_exception(e)
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 1866, in handle_exception
reraise(exc_type, exc_value, tb)
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/_compat.py", line 39, in reraise
raise value
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 2446, in wsgi_app
response = self.full_dispatch_request()
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 1951, in full_dispatch_request
rv = self.handle_user_exception(e)
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 1820, in handle_user_exception
reraise(exc_type, exc_value, tb)
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/_compat.py", line 39, in reraise
raise value
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 1949, in full_dispatch_request
rv = self.dispatch_request()
File "/Users/benjamattesjaroen/helloPython/env/lib/python3.7/site-packages/flask/app.py", line 1935, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)
File "/Users/benjamattesjaroen/helloPython/app.py", line 65, in index
consumed_nutrionalvalue_id = NutritionalValues.query.filter_by(item=consumed_item).id
AttributeError: 'BaseQuery' object has no attribute 'id'

, но при очистке 'Nutritional Values' есть столбецназывается "id"? Как я могу получить доступ к целому числу, хранящемуся в этом столбце таблицы для моего запроса?

1 Ответ

1 голос
/ 10 октября 2019

Ниже приведен запрос

NutritionalValues.query.filter_by(item=consumed_item)

Чтобы получить объект (это o в orm), вы можете использовать .first() или для многих результатов .all()

NutritionalValues.query.filter_by(item=consumed_item).first()

Вытеперь есть нормальный объект, к которому вы можете применять pythonic методы, такие как доступ к элементу.

Это интересно, потому что вы можете создавать динамические запросы до выполнения, которое получает результаты.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...