SQLAlchemy добавляет дочерний элемент к родительскому: связь один-ко-многим с сопоставленными столбцами ⇐ Python
SQLAlchemy добавляет дочерний элемент к родительскому: связь один-ко-многим с сопоставленными столбцами
Я просмотрел подобные вопросы по stackoverflow, но не нашел рабочего решения для моего конкретного случая. У меня есть связь «один ко многим» в database_models.py:
класс UserBase(Base): """ Учетная запись для хранения и доступа к нескольким учебным карточкам """ __tablename__ = 'пользователи' id = Столбец (Целое число, Primary_key = True, автоинкремент = True) telegram_id = Столбец (Строка, уникальный = Истина) имя пользователя = Столбец (Строка (100), уникальный = Истина) имя = Столбец (Строка (200)) фамилия = Столбец (Строка (200)) my_cards: Mapped[list['CardBase']] = отношения() класс CardBase(База): """ Обучающая карточка с текстом на лицевой и оборотной сторонах, привязанная к конкретному пользователю """ __tablename__ = 'карты' id: Mapped[int] = mapped_column(Целое число, Primary_key=True, автоинкремент=True) user_id: Mapped[int] = mapped_column(ForeignKey('users.id', ondelete='CASCADE'), обнуляемый = Ложь) имя = сопоставленный_столбец (текст) фронт = сопоставленный_столбец (текст) назад = сопоставленный_столбец (текст) Однако когда я пытаюсь выполнить следующее:
асинхронно с my_async_session.begin() в качестве сеанса: пытаться: родитель = ожидайте session.execute (запрос) родитель = родитель.первый() print(f'\n\n\n\n{родитель}\n\n\n\n') ожидайте родитель.дети.append(ребенок) кроме SQLAlchemyError как exc: печать (искл.) поднимать окончательно: дождитесь сеанса.закрыть() Сеанс откатывается. Я попытался заменить children на my_cards, но все равно получаю ошибку KeyError. Полная трассировка:
Traceback (самый последний вызов — последний): Файл «/home/user/bots/bot/venv/lib/python3.10/site-packages/sqlalchemy/engine/result.py», строка 202, в _key_not_found self._key_fallback(ключ, нет) Файл «/home/user/bots/bot/venv/lib/python3.10/site-packages/sqlalchemy/engine/result.py», строка 141, в _key_fallback поднять KeyError(ключ) из ошибки Ключевая ошибка: «мои_карты» Я либо не понимаю синтаксис, либо неправильно создал базу данных. Любая помощь приветствуется. Готов предоставить дополнительную информацию по запросу.
Я просмотрел подобные вопросы по stackoverflow, но не нашел рабочего решения для моего конкретного случая. У меня есть связь «один ко многим» в database_models.py:
класс UserBase(Base): """ Учетная запись для хранения и доступа к нескольким учебным карточкам """ __tablename__ = 'пользователи' id = Столбец (Целое число, Primary_key = True, автоинкремент = True) telegram_id = Столбец (Строка, уникальный = Истина) имя пользователя = Столбец (Строка (100), уникальный = Истина) имя = Столбец (Строка (200)) фамилия = Столбец (Строка (200)) my_cards: Mapped[list['CardBase']] = отношения() класс CardBase(База): """ Обучающая карточка с текстом на лицевой и оборотной сторонах, привязанная к конкретному пользователю """ __tablename__ = 'карты' id: Mapped[int] = mapped_column(Целое число, Primary_key=True, автоинкремент=True) user_id: Mapped[int] = mapped_column(ForeignKey('users.id', ondelete='CASCADE'), обнуляемый = Ложь) имя = сопоставленный_столбец (текст) фронт = сопоставленный_столбец (текст) назад = сопоставленный_столбец (текст) Однако когда я пытаюсь выполнить следующее:
асинхронно с my_async_session.begin() в качестве сеанса: пытаться: родитель = ожидайте session.execute (запрос) родитель = родитель.первый() print(f'\n\n\n\n{родитель}\n\n\n\n') ожидайте родитель.дети.append(ребенок) кроме SQLAlchemyError как exc: печать (искл.) поднимать окончательно: дождитесь сеанса.закрыть() Сеанс откатывается. Я попытался заменить children на my_cards, но все равно получаю ошибку KeyError. Полная трассировка:
Traceback (самый последний вызов — последний): Файл «/home/user/bots/bot/venv/lib/python3.10/site-packages/sqlalchemy/engine/result.py», строка 202, в _key_not_found self._key_fallback(ключ, нет) Файл «/home/user/bots/bot/venv/lib/python3.10/site-packages/sqlalchemy/engine/result.py», строка 141, в _key_fallback поднять KeyError(ключ) из ошибки Ключевая ошибка: «мои_карты» Я либо не понимаю синтаксис, либо неправильно создал базу данных. Любая помощь приветствуется. Готов предоставить дополнительную информацию по запросу.
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
JQuery при нажатии на дочерний элемент добавляет класс к непрямому родительскому элементу
Anonymous » » в форуме Jquery - 0 Ответы
- 56 Просмотры
-
Последнее сообщение Anonymous
-