Python.SQL Alchemy NotImplementedError: Оператор 'getitem' не поддерживается в этом выражении - PullRequest
0 голосов
/ 05 февраля 2019

Создаю запись в БД через sql alchemy.Следующим шагом является попытка записи идентификатора созданного объекта в другую таблицу с fk для созданного объекта (assign_resource_to_user).Это мой код:

from dev_tools.models.user import User
from dev_tools.models.resource Resource

resource = Resource(
    code=self.message_body['code'],
    description=self.message_body['description'],
    crew_id=None,
    catalog_resource_type_id=self.message_body['catalog_resource_type_id'],
    catalog_resource_status_id=self.message_body['catalog_resource_status_id'],
    created_at=datetime.utcnow(),
    created_by=None,
    is_available=self.message_body['is_available'],
)
self.db_session.add(resource)
self.db_session.flush()

assign_resource_to_user = self.db_session.query(
    User
).filter(
    User.id == self.user_info.id
).update(
    User.resource_id == resource.id
)
self.db_session.add(assign_resource_to_user)

У меня есть ошибка:

Traceback (most recent call last):
  File "/home/Документы/project/ResourseManagment/rm-private-application-server/apps/controller/helpers/data_processing/action/custom/resource_from_a_user.py", line 227, in <module>
    resources.create_record_in_db()
  File "/home/Документы/project/ResourseManagment/rm-private-application-server/apps/controller/helpers/data_processing/action/custom/resource_from_a_user.py", line 211, in create_record_in_db
    User.resource_id == resource.id
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/orm/query.py", line 3486, in update
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/orm/persistence.py", line 1334, in exec_
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/orm/persistence.py", line 1405, in _do_pre_synchronize
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/orm/persistence.py", line 1540, in _additional_evaluators
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/orm/persistence.py", line 1473, in _resolved_values_keys_as_propnames
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/orm/persistence.py", line 1457, in _resolved_values
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/sql/operators.py", line 411, in __getitem__
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/sql/elements.py", line 694, in operate
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/sql/operators.py", line 411, in __getitem__
  File "<string>", line 1, in <lambda>
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/sql/type_api.py", line 63, in operate
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/sql/default_comparator.py", line 192, in _getitem_impl
  File "/home/Документы/project/venv/lib/python3.7/site-packages/SQLAlchemy-1.2.14-py3.7-linux-x86_64.egg/sqlalchemy/sql/default_comparator.py", line 197, in _unsupported_impl
NotImplementedError: Operator 'getitem' is not supported on this expression

Ошибка в этой строке:

).update(
    User.resource_id == resource.id
)

Может быть, кто-то знает, как это исправить или есть такие жепроблема и может помочь мне решить ее.Благодаря.

1 Ответ

0 голосов
/ 05 февраля 2019

Query.update() ожидает сопоставления атрибутов со значениями в качестве первого позиционного аргумента, но вы передали ему объект языка выражений SQL.Обратите внимание, что Query.update() - это массовая операция, которая не возвращает экземпляр модели или что-то подобное, но количество совпадающих строк.Так что вместо этого:

self.db_session.query(
    User
).filter(
    User.id == self.user_info.id
).update(
    {User.resource_id: resource.id},
    synchronize_session=False  # Change this according to your needs
)
# No add
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...