SQLAlchemy добавляет дочерний элемент к родительскому: связь один-ко-многим с сопоставленными столбцамиPython

Программы на 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(ключ) из ошибки Ключевая ошибка: «мои_карты» Я либо не понимаю синтаксис, либо неправильно создал базу данных. Любая помощь приветствуется. Готов предоставить дополнительную информацию по запросу.
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»